/* * Copyright 2008-2012 NVIDIA Corporation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /*! \file unique.inl * \brief Inline file for unique.h. */ #include #include #include #include #include #include #include #include namespace thrust { template ForwardIterator unique(const thrust::detail::execution_policy_base &exec, ForwardIterator first, ForwardIterator last) { using thrust::system::detail::generic::unique; return unique(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last); } // end unique() template ForwardIterator unique(const thrust::detail::execution_policy_base &exec, ForwardIterator first, ForwardIterator last, BinaryPredicate binary_pred) { using thrust::system::detail::generic::unique; return unique(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, binary_pred); } // end unique() template OutputIterator unique_copy(const thrust::detail::execution_policy_base &exec, InputIterator first, InputIterator last, OutputIterator output) { using thrust::system::detail::generic::unique_copy; return unique_copy(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, output); } // end unique_copy() template OutputIterator unique_copy(const thrust::detail::execution_policy_base &exec, InputIterator first, InputIterator last, OutputIterator output, BinaryPredicate binary_pred) { using thrust::system::detail::generic::unique_copy; return unique_copy(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, output, binary_pred); } // end unique_copy() template thrust::pair unique_by_key(const thrust::detail::execution_policy_base &exec, ForwardIterator1 keys_first, ForwardIterator1 keys_last, ForwardIterator2 values_first) { using thrust::system::detail::generic::unique_by_key; return unique_by_key(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), keys_first, keys_last, values_first); } // end unique_by_key() template thrust::pair unique_by_key(const thrust::detail::execution_policy_base &exec, ForwardIterator1 keys_first, ForwardIterator1 keys_last, ForwardIterator2 values_first, BinaryPredicate binary_pred) { using thrust::system::detail::generic::unique_by_key; return unique_by_key(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), keys_first, keys_last, values_first, binary_pred); } // end unique_by_key() template thrust::pair unique_by_key_copy(const thrust::detail::execution_policy_base &exec, InputIterator1 keys_first, InputIterator1 keys_last, InputIterator2 values_first, OutputIterator1 keys_output, OutputIterator2 values_output) { using thrust::system::detail::generic::unique_by_key_copy; return unique_by_key_copy(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), keys_first, keys_last, values_first, keys_output, values_output); } // end unique_by_key_copy() template thrust::pair unique_by_key_copy(const thrust::detail::execution_policy_base &exec, InputIterator1 keys_first, InputIterator1 keys_last, InputIterator2 values_first, OutputIterator1 keys_output, OutputIterator2 values_output, BinaryPredicate binary_pred) { using thrust::system::detail::generic::unique_by_key_copy; return unique_by_key_copy(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), keys_first, keys_last, values_first, keys_output, values_output, binary_pred); } // end unique_by_key_copy() template ForwardIterator unique(ForwardIterator first, ForwardIterator last) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System; System system; return thrust::unique(select_system(system), first, last); } // end unique() template ForwardIterator unique(ForwardIterator first, ForwardIterator last, BinaryPredicate binary_pred) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System; System system; return thrust::unique(select_system(system), first, last, binary_pred); } // end unique() template OutputIterator unique_copy(InputIterator first, InputIterator last, OutputIterator output) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System1; typedef typename thrust::iterator_system::type System2; System1 system1; System2 system2; return thrust::unique_copy(select_system(system1,system2), first, last, output); } // end unique_copy() template OutputIterator unique_copy(InputIterator first, InputIterator last, OutputIterator output, BinaryPredicate binary_pred) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System1; typedef typename thrust::iterator_system::type System2; System1 system1; System2 system2; return thrust::unique_copy(select_system(system1,system2), first, last, output, binary_pred); } // end unique_copy() template thrust::pair unique_by_key(ForwardIterator1 keys_first, ForwardIterator1 keys_last, ForwardIterator2 values_first) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System1; typedef typename thrust::iterator_system::type System2; System1 system1; System2 system2; return thrust::unique_by_key(select_system(system1,system2), keys_first, keys_last, values_first); } // end unique_by_key() template thrust::pair unique_by_key(ForwardIterator1 keys_first, ForwardIterator1 keys_last, ForwardIterator2 values_first, BinaryPredicate binary_pred) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System1; typedef typename thrust::iterator_system::type System2; System1 system1; System2 system2; return thrust::unique_by_key(select_system(system1,system2), keys_first, keys_last, values_first, binary_pred); } // end unique_by_key() template thrust::pair unique_by_key_copy(InputIterator1 keys_first, InputIterator1 keys_last, InputIterator2 values_first, OutputIterator1 keys_output, OutputIterator2 values_output) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System1; typedef typename thrust::iterator_system::type System2; typedef typename thrust::iterator_system::type System3; typedef typename thrust::iterator_system::type System4; System1 system1; System2 system2; System3 system3; System4 system4; return thrust::unique_by_key_copy(select_system(system1,system2,system3,system4), keys_first, keys_last, values_first, keys_output, values_output); } // end unique_by_key_copy() template thrust::pair unique_by_key_copy(InputIterator1 keys_first, InputIterator1 keys_last, InputIterator2 values_first, OutputIterator1 keys_output, OutputIterator2 values_output, BinaryPredicate binary_pred) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System1; typedef typename thrust::iterator_system::type System2; typedef typename thrust::iterator_system::type System3; typedef typename thrust::iterator_system::type System4; System1 system1; System2 system2; System3 system3; System4 system4; return thrust::unique_by_key_copy(select_system(system1,system2,system3,system4), keys_first, keys_last, values_first, keys_output, values_output, binary_pred); } // end unique_by_key_copy() } // end namespace thrust