thrust::replace_copy_if
Defined in thrust/replace.h
- 
template<typename DerivedPolicy, typename InputIterator1, typename InputIterator2, typename OutputIterator, typename Predicate, typename T>
 OutputIterator thrust::replace_copy_if(const thrust::detail::execution_policy_base<DerivedPolicy> &exec, InputIterator1 first, InputIterator1 last, InputIterator2 stencil, OutputIterator result, Predicate pred, const T &new_value)
- This version of - replace_copy_ifcopies elements from the range- [first, last)to the range- [result, result + (last-first)), except that any element whose corresponding stencil element causes- predto be- trueis not copied;- new_valueis copied instead.- More precisely, for every integer - nsuch that- 0 <= n < last-first,- replace_copy_ifperforms the assignment- *(result+n) = new_valueif- pred(*(stencil+n)), and- *(result+n) = *(first+n)otherwise.- The algorithm’s execution is parallelized as determined by - exec.- #include <thrust/replace.h> #include <thrust/device_vector.h> #include <thrust/execution_policy.h> struct is_less_than_zero { __host__ __device__ bool operator()(int x) { return x < 0; } }; ... thrust::device_vector<int> A(4); A[0] = 10; A[1] = 20; A[2] = 30; A[3] = 40; thrust::device_vector<int> S(4); S[0] = -1; S[1] = 0; S[2] = -1; S[3] = 0; thrust::device_vector<int> B(4); is_less_than_zero pred; thrust::replace_if(thrust::device, A.begin(), A.end(), S.begin(), B.begin(), pred, 0); // B contains [0, 20, 0, 40] - See also - replace_copy- See also - replace_if- Parameters
- exec – The execution policy to use for parallelization. 
- first – The beginning of the sequence to copy from. 
- last – The end of the sequence to copy from. 
- stencil – The beginning of the stencil sequence. 
- result – The beginning of the sequence to copy to. 
- pred – The predicate to test on every value of the range - [stencil, stencil + (last - first)).
- new_value – The replacement value to assign when - pred(*s)evaluates to- true.
 
- Template Parameters
- DerivedPolicy – The name of the derived execution policy. 
- InputIterator1 – is a model of Input Iterator. 
- InputIterator2 – is a model of Input Iterator and - InputIterator2's- value_typeis convertible to- Predicate'sargument type.
- OutputIterator – is a model of Output Iterator. 
- Predicate – is a model of Predicate. 
- T – is a model of Assignable, and - Tis convertible to- OutputIterator's- value_type.
 
- Returns
- result + (last-first)
- Pre
- firstmay equal- result, but the ranges- [first, last)and- [result, result + (last - first))shall not overlap otherwise.
- Pre
- stencilmay equal- result, but the ranges- [stencil, stencil + (last - first))and- [result, result + (last - first))shall not overlap otherwise.