thrust::unique
Defined in thrust/unique.h
-
template<typename DerivedPolicy, typename ForwardIterator, typename BinaryPredicate>
ForwardIterator thrust::unique(const thrust::detail::execution_policy_base<DerivedPolicy> &exec, ForwardIterator first, ForwardIterator last, BinaryPredicate binary_pred) For each group of consecutive elements in the range
[first, last)
with the same value,unique
removes all but the first element of the group. The return value is an iteratornew_last
such that no two consecutive elements in the range[first, new_last)
are equal. The iterators in the range[new_last, last)
are all still dereferenceable, but the elements that they point to are unspecified.unique
is stable, meaning that the relative order of elements that are not removed is unchanged.This version of
unique
uses the function objectbinary_pred
to test for equality.The algorithm’s execution is parallelized as determined by
exec
.The following code snippet demonstrates how to use
unique
to compact a sequence of numbers to remove consecutive duplicates using thethrust::host
execution policy for parallelization:#include <thrust/unique.h> #include <thrust/execution_policy.h> ... const int N = 7; int A[N] = {1, 3, 3, 3, 2, 2, 1}; int *new_end = thrust::unique(thrust::host, A, A + N, thrust::equal_to<int>()); // The first four values of A are now {1, 3, 2, 1} // Values beyond new_end are unspecified.
See also
unique_copy
- Parameters
exec – The execution policy to use for parallelization.
first – The beginning of the input range.
last – The end of the input range.
binary_pred – The binary predicate used to determine equality.
- Template Parameters
DerivedPolicy – The name of the derived execution policy.
ForwardIterator – is a model of Forward Iterator, and
ForwardIterator
is mutable, andForwardIterator's
value_type
is convertible toBinaryPredicate's
first_argument_type
and toBinaryPredicate's
second_argument_type
.BinaryPredicate – is a model of Binary Predicate.
- Returns
The end of the unique range
[first, new_last)