// Copyright (c) 2007-2011 INRIA Sophia-Antipolis (France). // All rights reserved. // // This file is part of CGAL (www.cgal.org); you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public License as // published by the Free Software Foundation; either version 3 of the License, // or (at your option) any later version. // // Licensees holding a valid commercial license may use this file in // accordance with the commercial license agreement provided with the software. // // This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE // WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. // // $URL$ // $Id$ // // Author(s) : Christophe Delage // #ifndef CGAL_HILBERT_SORT_H #define CGAL_HILBERT_SORT_H #include #include #include #include #include #include #include #include #include namespace CGAL { namespace internal { template void hilbert_sort (RandomAccessIterator begin, RandomAccessIterator end, const Kernel &k, Policy /*policy*/, typename Kernel::Point_2 *) { boost::rand48 random; boost::random_number_generator rng(random); #if defined(CGAL_HILBERT_SORT_WITH_MEDIAN_POLICY_CROSS_PLATFORM_BEHAVIOR) CGAL::random_shuffle(begin,end, rng); #else std::random_shuffle(begin,end, rng); #endif (Hilbert_sort_2 (k))(begin, end); } template void hilbert_sort (RandomAccessIterator begin, RandomAccessIterator end, const Kernel &k, Policy /*policy*/, typename Kernel::Point_3 *) { boost::rand48 random; boost::random_number_generator rng(random); #if defined(CGAL_HILBERT_SORT_WITH_MEDIAN_POLICY_CROSS_PLATFORM_BEHAVIOR) CGAL::random_shuffle(begin,end, rng); #else std::random_shuffle(begin,end, rng); #endif (Hilbert_sort_3 (k))(begin, end); } template void hilbert_sort (RandomAccessIterator begin, RandomAccessIterator end, const Kernel &k, Policy /*policy*/, typename Kernel::Point_d *) { boost::rand48 random; boost::random_number_generator rng(random); #if defined(CGAL_HILBERT_SORT_WITH_MEDIAN_POLICY_CROSS_PLATFORM_BEHAVIOR) CGAL::random_shuffle(begin,end, rng); #else std::random_shuffle(begin,end, rng); #endif (Hilbert_sort_d (k))(begin, end); } } template void hilbert_sort (RandomAccessIterator begin, RandomAccessIterator end) { typedef std::iterator_traits ITraits; typedef typename ITraits::value_type value_type; typedef CGAL::Kernel_traits KTraits; typedef typename KTraits::Kernel Kernel; internal::hilbert_sort(begin, end, Kernel(), Hilbert_sort_median_policy(), static_cast (0)); } template void hilbert_sort (RandomAccessIterator begin, RandomAccessIterator end, const Kernel &k) { typedef std::iterator_traits ITraits; typedef typename ITraits::value_type value_type; internal::hilbert_sort(begin, end, k, Hilbert_sort_median_policy(), static_cast (0)); } template void hilbert_sort (RandomAccessIterator begin, RandomAccessIterator end, Hilbert_sort_median_policy policy) { typedef std::iterator_traits ITraits; typedef typename ITraits::value_type value_type; typedef CGAL::Kernel_traits KTraits; typedef typename KTraits::Kernel Kernel; internal::hilbert_sort(begin, end, Kernel(), policy, static_cast (0)); } template void hilbert_sort (RandomAccessIterator begin, RandomAccessIterator end, Hilbert_sort_middle_policy policy) { typedef std::iterator_traits ITraits; typedef typename ITraits::value_type value_type; typedef CGAL::Kernel_traits KTraits; typedef typename KTraits::Kernel Kernel; internal::hilbert_sort(begin, end, Kernel(), policy, static_cast (0)); } template void hilbert_sort (RandomAccessIterator begin, RandomAccessIterator end, const Kernel &k, Policy policy) { typedef std::iterator_traits ITraits; typedef typename ITraits::value_type value_type; internal::hilbert_sort(begin, end, k, policy, static_cast (0)); } } // namespace CGAL #endif//CGAL_HILBERT_SORT_H