|
thrust
|
Functions | |
| template<typename InputIterator , typename UnaryFunction > | |
| InputIterator | thrust::for_each (InputIterator first, InputIterator last, UnaryFunction f) |
| template<typename InputIterator , typename Size , typename UnaryFunction > | |
| InputIterator | thrust::for_each_n (InputIterator first, Size n, UnaryFunction f) |
| InputIterator thrust::for_each | ( | InputIterator | first, |
| InputIterator | last, | ||
| UnaryFunction | f | ||
| ) |
for_each applies the function object f to each element in the range [first, last); f's return value, if any, is ignored. Unlike the C++ Standard Template Library function std::for_each, this version offers no guarantee on order of execution. For this reason, this version of for_each does not return a copy of the function object.
| first | The beginning of the sequence. |
| last | The end of the sequence. |
| f | The function object to apply to the range [first, last). |
| InputIterator | is a model of Input Iterator, and InputIterator's value_type is convertible to UnaryFunction's argument_type. |
| UnaryFunction | is a model of Unary Function, and UnaryFunction does not apply any non-constant operation through its argument. |
The following code snippet demonstrates how to use for_each to print the elements of a device_vector.
#include <thrust/for_each.h> #include <thrust/device_vector.h> #include <stdio.h> struct printf_functor { __host__ __device__ void operator()(int x) { // note that using printf in a __device__ function requires // code compiled for a GPU with compute capability 2.0 or // higher (nvcc --arch=sm_20) printf("%d\n"); } }; ... thrust::device_vector<int> d_vec(3); d_vec[0] = 0; d_vec[1] = 1; d_vec[2] = 2; thrust::for_each(d_vec.begin(), d_vec.end(), printf_functor()); // 0 1 2 is printed to standard output in some unspecified order
| InputIterator thrust::for_each_n | ( | InputIterator | first, |
| Size | n, | ||
| UnaryFunction | f | ||
| ) |
for_each_n applies the function object f to each element in the range [first, first + n); f's return value, if any, is ignored. Unlike the C++ Standard Template Library function std::for_each, this version offers no guarantee on order of execution.
| first | The beginning of the sequence. |
| n | The size of the input sequence. |
| f | The function object to apply to the range [first, first + n). |
first + n| InputIterator | is a model of Input Iterator, and InputIterator's value_type is convertible to UnaryFunction's argument_type. |
| Size | is an integral type. |
| UnaryFunction | is a model of Unary Function, and UnaryFunction does not apply any non-constant operation through its argument. |
The following code snippet demonstrates how to use for_each_n to print the elements of a device_vector.
#include <thrust/for_each.h> #include <thrust/device_vector.h> #include <stdio.h> struct printf_functor { __host__ __device__ void operator()(int x) { // note that using printf in a __device__ function requires // code compiled for a GPU with compute capability 2.0 or // higher (nvcc --arch=sm_20) printf("%d\n"); } }; ... thrust::device_vector<int> d_vec(3); d_vec[0] = 0; d_vec[1] = 1; d_vec[2] = 2; thrust::for_each_n(d_vec.begin(), d_vec.size(), printf_functor()); // 0 1 2 is printed to standard output in some unspecified order
1.7.4