/* * 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 partition.inl * \brief Inline file for partition.h. */ #include #include #include #include #include #include namespace thrust { template ForwardIterator partition(const thrust::detail::execution_policy_base &exec, ForwardIterator first, ForwardIterator last, Predicate pred) { using thrust::system::detail::generic::partition; return partition(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, pred); } // end partition() template ForwardIterator partition(const thrust::detail::execution_policy_base &exec, ForwardIterator first, ForwardIterator last, InputIterator stencil, Predicate pred) { using thrust::system::detail::generic::partition; return partition(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, stencil, pred); } // end partition() template thrust::pair partition_copy(const thrust::detail::execution_policy_base &exec, InputIterator first, InputIterator last, OutputIterator1 out_true, OutputIterator2 out_false, Predicate pred) { using thrust::system::detail::generic::partition_copy; return partition_copy(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, out_true, out_false, pred); } // end partition_copy() template thrust::pair partition_copy(const thrust::detail::execution_policy_base &exec, InputIterator1 first, InputIterator1 last, InputIterator2 stencil, OutputIterator1 out_true, OutputIterator2 out_false, Predicate pred) { using thrust::system::detail::generic::partition_copy; return partition_copy(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, stencil, out_true, out_false, pred); } // end partition_copy() template ForwardIterator stable_partition(const thrust::detail::execution_policy_base &exec, ForwardIterator first, ForwardIterator last, Predicate pred) { using thrust::system::detail::generic::stable_partition; return stable_partition(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, pred); } // end stable_partition() template ForwardIterator stable_partition(const thrust::detail::execution_policy_base &exec, ForwardIterator first, ForwardIterator last, InputIterator stencil, Predicate pred) { using thrust::system::detail::generic::stable_partition; return stable_partition(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, stencil, pred); } // end stable_partition() template thrust::pair stable_partition_copy(const thrust::detail::execution_policy_base &exec, InputIterator first, InputIterator last, OutputIterator1 out_true, OutputIterator2 out_false, Predicate pred) { using thrust::system::detail::generic::stable_partition_copy; return stable_partition_copy(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, out_true, out_false, pred); } // end stable_partition_copy() template thrust::pair stable_partition_copy(const thrust::detail::execution_policy_base &exec, InputIterator1 first, InputIterator1 last, InputIterator2 stencil, OutputIterator1 out_true, OutputIterator2 out_false, Predicate pred) { using thrust::system::detail::generic::stable_partition_copy; return stable_partition_copy(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, stencil, out_true, out_false, pred); } // end stable_partition_copy() template ForwardIterator partition_point(const thrust::detail::execution_policy_base &exec, ForwardIterator first, ForwardIterator last, Predicate pred) { using thrust::system::detail::generic::partition_point; return partition_point(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, pred); } // end partition_point() template bool is_partitioned(const thrust::detail::execution_policy_base &exec, InputIterator first, InputIterator last, Predicate pred) { using thrust::system::detail::generic::is_partitioned; return is_partitioned(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, pred); } // end is_partitioned() template ForwardIterator partition(ForwardIterator first, ForwardIterator last, Predicate pred) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System; System system; return thrust::partition(select_system(system), first, last, pred); } // end partition() template ForwardIterator partition(ForwardIterator first, ForwardIterator last, InputIterator stencil, Predicate 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::partition(select_system(system1,system2), first, last, stencil, pred); } // end partition() template ForwardIterator stable_partition(ForwardIterator first, ForwardIterator last, Predicate pred) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System; System system; return thrust::stable_partition(select_system(system), first, last, pred); } // end stable_partition() template ForwardIterator stable_partition(ForwardIterator first, ForwardIterator last, InputIterator stencil, Predicate 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::stable_partition(select_system(system1,system2), first, last, stencil, pred); } // end stable_partition() template thrust::pair partition_copy(InputIterator first, InputIterator last, OutputIterator1 out_true, OutputIterator2 out_false, Predicate 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; System1 system1; System2 system2; System3 system3; return thrust::partition_copy(select_system(system1,system2,system3), first, last, out_true, out_false, pred); } // end partition_copy() template thrust::pair partition_copy(InputIterator1 first, InputIterator1 last, InputIterator2 stencil, OutputIterator1 out_true, OutputIterator2 out_false, Predicate 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::partition_copy(select_system(system1,system2,system3,system4), first, last, stencil, out_true, out_false, pred); } // end partition_copy() template thrust::pair stable_partition_copy(InputIterator first, InputIterator last, OutputIterator1 out_true, OutputIterator2 out_false, Predicate 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; System1 system1; System2 system2; System3 system3; return thrust::stable_partition_copy(select_system(system1,system2,system3), first, last, out_true, out_false, pred); } // end stable_partition_copy() template thrust::pair stable_partition_copy(InputIterator1 first, InputIterator1 last, InputIterator2 stencil, OutputIterator1 out_true, OutputIterator2 out_false, Predicate 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::stable_partition_copy(select_system(system1,system2,system3,system4), first, last, stencil, out_true, out_false, pred); } // end stable_partition_copy() template ForwardIterator partition_point(ForwardIterator first, ForwardIterator last, Predicate pred) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System; System system; return thrust::partition_point(select_system(system), first, last, pred); } // end partition_point() template bool is_partitioned(InputIterator first, InputIterator last, Predicate pred) { using thrust::system::detail::generic::select_system; typedef typename thrust::iterator_system::type System; System system; return thrust::is_partitioned(select_system(system), first, last, pred); } // end is_partitioned() } // end thrust