/* * Copyright 2008-2013 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. */ #pragma once #include #if defined(_CCCL_IMPLICIT_SYSTEM_HEADER_GCC) # pragma GCC system_header #elif defined(_CCCL_IMPLICIT_SYSTEM_HEADER_CLANG) # pragma clang system_header #elif defined(_CCCL_IMPLICIT_SYSTEM_HEADER_MSVC) # pragma system_header #endif // no system header #include #include #include #include #include THRUST_NAMESPACE_BEGIN _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE ForwardIterator lower_bound( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, const LessThanComparable& value) { using thrust::system::detail::generic::lower_bound; return lower_bound(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, value); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE ForwardIterator lower_bound( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp) { using thrust::system::detail::generic::lower_bound; return lower_bound(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, value, comp); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE ForwardIterator upper_bound( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, const LessThanComparable& value) { using thrust::system::detail::generic::upper_bound; return upper_bound(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, value); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE ForwardIterator upper_bound( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp) { using thrust::system::detail::generic::upper_bound; return upper_bound(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, value, comp); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE bool binary_search( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, const LessThanComparable& value) { using thrust::system::detail::generic::binary_search; return binary_search(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, value); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE bool binary_search( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp) { using thrust::system::detail::generic::binary_search; return binary_search(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, value, comp); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE thrust::pair equal_range( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp) { using thrust::system::detail::generic::equal_range; return equal_range(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, value, comp); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE thrust::pair equal_range( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, const LessThanComparable& value) { using thrust::system::detail::generic::equal_range; return equal_range(thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, value); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE OutputIterator lower_bound( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output) { using thrust::system::detail::generic::lower_bound; return lower_bound( thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, values_first, values_last, output); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE OutputIterator lower_bound( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output, StrictWeakOrdering comp) { using thrust::system::detail::generic::lower_bound; return lower_bound( thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, values_first, values_last, output, comp); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE OutputIterator upper_bound( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output) { using thrust::system::detail::generic::upper_bound; return upper_bound( thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, values_first, values_last, output); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE OutputIterator upper_bound( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output, StrictWeakOrdering comp) { using thrust::system::detail::generic::upper_bound; return upper_bound( thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, values_first, values_last, output, comp); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE OutputIterator binary_search( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output) { using thrust::system::detail::generic::binary_search; return binary_search( thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, values_first, values_last, output); } _CCCL_EXEC_CHECK_DISABLE template _CCCL_HOST_DEVICE OutputIterator binary_search( const thrust::detail::execution_policy_base& exec, ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output, StrictWeakOrdering comp) { using thrust::system::detail::generic::binary_search; return binary_search( thrust::detail::derived_cast(thrust::detail::strip_const(exec)), first, last, values_first, values_last, output, comp); } ////////////////////// // Scalar Functions // ////////////////////// template ForwardIterator lower_bound(ForwardIterator first, ForwardIterator last, const LessThanComparable& value) { using thrust::system::detail::generic::select_system; using System = typename thrust::iterator_system::type; System system; return thrust::lower_bound(select_system(system), first, last, value); } template ForwardIterator lower_bound(ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp) { using thrust::system::detail::generic::select_system; using System = typename thrust::iterator_system::type; System system; return thrust::lower_bound(select_system(system), first, last, value, comp); } template ForwardIterator upper_bound(ForwardIterator first, ForwardIterator last, const LessThanComparable& value) { using thrust::system::detail::generic::select_system; using System = typename thrust::iterator_system::type; System system; return thrust::upper_bound(select_system(system), first, last, value); } template ForwardIterator upper_bound(ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp) { using thrust::system::detail::generic::select_system; using System = typename thrust::iterator_system::type; System system; return thrust::upper_bound(select_system(system), first, last, value, comp); } template bool binary_search(ForwardIterator first, ForwardIterator last, const LessThanComparable& value) { using thrust::system::detail::generic::select_system; using System = typename thrust::iterator_system::type; System system; return thrust::binary_search(select_system(system), first, last, value); } template bool binary_search(ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp) { using thrust::system::detail::generic::select_system; using System = typename thrust::iterator_system::type; System system; return thrust::binary_search(select_system(system), first, last, value, comp); } template thrust::pair equal_range(ForwardIterator first, ForwardIterator last, const LessThanComparable& value) { using thrust::system::detail::generic::select_system; using System = typename thrust::iterator_system::type; System system; return thrust::equal_range(select_system(system), first, last, value); } template thrust::pair equal_range(ForwardIterator first, ForwardIterator last, const T& value, StrictWeakOrdering comp) { using thrust::system::detail::generic::select_system; using System = typename thrust::iterator_system::type; System system; return thrust::equal_range(select_system(system), first, last, value, comp); } ////////////////////// // Vector Functions // ////////////////////// template OutputIterator lower_bound( ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output) { using thrust::system::detail::generic::select_system; using System1 = typename thrust::iterator_system::type; using System2 = typename thrust::iterator_system::type; using System3 = typename thrust::iterator_system::type; System1 system1; System2 system2; System3 system3; return thrust::lower_bound(select_system(system1, system2, system3), first, last, values_first, values_last, output); } template OutputIterator lower_bound( ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output, StrictWeakOrdering comp) { using thrust::system::detail::generic::select_system; using System1 = typename thrust::iterator_system::type; using System2 = typename thrust::iterator_system::type; using System3 = typename thrust::iterator_system::type; System1 system1; System2 system2; System3 system3; return thrust::lower_bound( select_system(system1, system2, system3), first, last, values_first, values_last, output, comp); } template OutputIterator upper_bound( ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output) { using thrust::system::detail::generic::select_system; using System1 = typename thrust::iterator_system::type; using System2 = typename thrust::iterator_system::type; using System3 = typename thrust::iterator_system::type; System1 system1; System2 system2; System3 system3; return thrust::upper_bound(select_system(system1, system2, system3), first, last, values_first, values_last, output); } template OutputIterator upper_bound( ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output, StrictWeakOrdering comp) { using thrust::system::detail::generic::select_system; using System1 = typename thrust::iterator_system::type; using System2 = typename thrust::iterator_system::type; using System3 = typename thrust::iterator_system::type; System1 system1; System2 system2; System3 system3; return thrust::upper_bound( select_system(system1, system2, system3), first, last, values_first, values_last, output, comp); } template OutputIterator binary_search( ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output) { using thrust::system::detail::generic::select_system; using System1 = typename thrust::iterator_system::type; using System2 = typename thrust::iterator_system::type; using System3 = typename thrust::iterator_system::type; System1 system1; System2 system2; System3 system3; return thrust::binary_search(select_system(system1, system2, system3), first, last, values_first, values_last, output); } template OutputIterator binary_search( ForwardIterator first, ForwardIterator last, InputIterator values_first, InputIterator values_last, OutputIterator output, StrictWeakOrdering comp) { using thrust::system::detail::generic::select_system; using System1 = typename thrust::iterator_system::type; using System2 = typename thrust::iterator_system::type; using System3 = typename thrust::iterator_system::type; System1 system1; System2 system2; System3 system3; return thrust::binary_search( select_system(system1, system2, system3), first, last, values_first, values_last, output, comp); } THRUST_NAMESPACE_END