/* * 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 binary_search.inl * \brief Inline file for binary_search.h. */ #include #include #include #include #include #include namespace thrust { template 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); } template 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); } template 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); } template 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); } template 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); } template 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); } template 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); } template 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); } template 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); } template 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); } template 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); } template 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); } template 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); } template 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; typedef typename thrust::iterator_system::type System; 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; typedef typename thrust::iterator_system::type System; 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; typedef typename thrust::iterator_system::type System; 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; typedef typename thrust::iterator_system::type System; 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; typedef typename thrust::iterator_system::type System; 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; typedef typename thrust::iterator_system::type System; 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; typedef typename thrust::iterator_system::type System; 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; typedef typename thrust::iterator_system::type System; 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; 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::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; 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::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; 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::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; 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::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; 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::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; 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::binary_search(select_system(system1,system2,system3), first, last, values_first, values_last, output, comp); } } // end namespace thrust