-
Notifications
You must be signed in to change notification settings - Fork 0
StdSorting
Header File: Kokkos_Core.hpp
All algorithms are currently in the Kokkos::Experimental namespace.
Currently supported (see below the full details):
//
// overload set accepting iterators
//
template <class ExecutionSpace, class IteratorType>
bool is_sorted(const ExecutionSpace& exespace, (1)
IteratorType first, IteratorType last);
template <class ExecutionSpace, class IteratorType>
bool is_sorted(const std::string& label, const ExecutionSpace& exespace, (2)
IteratorType first, IteratorType last);
template <class ExecutionSpace, class IteratorType, class ComparatorType>
bool is_sorted(const ExecutionSpace& exespace, (3)
IteratorType first, IteratorType last,
ComparatorType comp);
template <class ExecutionSpace, class IteratorType, class ComparatorType>
bool is_sorted(const std::string& label, const ExecutionSpace& exespace, (4)
IteratorType first, IteratorType last,
ComparatorType comp);
//
// overload set accepting views
//
template <class ExecutionSpace, class DataType, class... Properties>
bool is_sorted(const ExecutionSpace& exespace, (5)
const ::Kokkos::View<DataType, Properties...>& view);
template <class ExecutionSpace, class DataType, class... Properties>
bool is_sorted(const std::string& label, const ExecutionSpace& exespace, (6)
const ::Kokkos::View<DataType, Properties...>& view);
template <
class ExecutionSpace,
class DataType, class... Properties, class ComparatorType>
bool is_sorted(const ExecutionSpace& exespace, (7)
const ::Kokkos::View<DataType, Properties...>& view,
ComparatorType comp);
template <
class ExecutionSpace,
class DataType, class... Properties, class ComparatorType>
bool is_sorted(const std::string& label, const ExecutionSpace& exespace, (8)
const ::Kokkos::View<DataType, Properties...>& view,
ComparatorType comp);-
(1,2,5,6): checks if the elements in the range
[first, last)(1,2) or inview(5,6) are sorted in non-descending order usingoperator<to compare two elements. -
(3,4,7,8): checks if the elements in the range
[first, last)(3,4) or inview(7,8) are sorted in non-descending order using the binary functorcompto compare two elements.
-
exespace:- execution space instance
-
label:- used to name the implementation kernels for debugging purposes
- for 1,3 the default string is: "Kokkos::is_sorted_iterator_api_default"
- for 5,7 the default string is: "Kokkos::is_sorted_view_api_default"
-
first,last:- range of elements to examine
- must be random access iterators
- must represent a valid range, i.e.,
last >= first(checked in debug mode) - must be accessible from
exespace
-
view:- Kokkos view to examine
- must be rank-1, and have
LayoutLeft,LayoutRight, orLayoutStride - must be accessible from
exespace
-
comp:-
binary functor returning
trueif the first argument is less than the second argument;comp(a,b)must be valid to be called from the execution space passed, and convertible to bool for every pair of argumentsa,bof typevalue_type, wherevalue_typeis the value type ofIteratorType(for 1,2,3,4) or the value type ofview(for 5,6,7,8) and must not modifya,b. - must conform to:
struct Comparator { KOKKOS_INLINE_FUNCTION bool operator()(const value_type & a, const value_type & b) const { return /* true if a is less than b, based on your logic of "less than" */; } KOKKOS_INLINE_FUNCTION bool operator()(const volatile value_type a, const volatile value_type b) const { return /* true if a is less than b, based on your logic of "less than" */; } };
- the volatile overload is needed because the algorithm is
currently implemented as a reduction, where the
compfunctor is used as the ``joiner'' to join two values. The current Kokkos implementation of reductions requires any custom joiner to have a volatile overload: see this wiki page for more info on reductions.
-
binary functor returning
True if the elements are sorted in descending order.
//
// overload set accepting iterators
//
template <class ExecutionSpace, class IteratorType>
IteratorType is_sorted_until(const ExecutionSpace& exespace, (1)
IteratorType first, IteratorType last);
template <class ExecutionSpace, class IteratorType>
IteratorType is_sorted_until(const std::string& label, (2)
const ExecutionSpace& exespace,
IteratorType first, IteratorType last);
template <class ExecutionSpace, class IteratorType, class ComparatorType>
IteratorType is_sorted_until(const ExecutionSpace& exespace, (3)
IteratorType first, IteratorType last,
ComparatorType comp);
template <class ExecutionSpace, class IteratorType, class ComparatorType>
IteratorType is_sorted_until(const std::string& label, (4)
const ExecutionSpace& exespace,
IteratorType first, IteratorType last,
ComparatorType comp);
//
// overload set accepting views
//
template <class ExecutionSpace, class DataType, class... Properties>
auto is_sorted_until(const ExecutionSpace& exespace, (5)
const ::Kokkos::View<DataType, Properties...>& view);
template <class ExecutionSpace, class DataType, class... Properties>
auto is_sorted_until(const std::string& label, const ExecutionSpace& exespace, (6)
const ::Kokkos::View<DataType, Properties...>& view);
template <
class ExecutionSpace,
class DataType, class... Properties, class ComparatorType>
auto is_sorted_until(const ExecutionSpace& exespace, (7)
const ::Kokkos::View<DataType, Properties...>& view,
ComparatorType comp);
template <
class ExecutionSpace,
class DataType, class... Properties, class ComparatorType>
auto is_sorted_until(const std::string& label, const ExecutionSpace& exespace, (8)
const ::Kokkos::View<DataType, Properties...>& view,
ComparatorType comp);-
(1,2,5,6): finds the largest range beginning at
first(1,2) or atKokkos::Experimental::begin(view)(5,6) in which the elements are sorted in non-descending order. Comparison between elements is done viaoperator<. -
(3,4,7,8): finds the largest range beginning at
first(3,4) or atKokkos::Experimental::begin(view)(7,8) in which the elements are sorted in non-descending order. Comparison between elements is done via the binary functorcomp.
-
exespace,first,last,view,comp: same as inis_sorted -
label:- used to name the implementation kernels for debugging purposes
- for 1,3 the default string is: "Kokkos::is_sorted_until_iterator_api_default"
- for 5,7 the default string is: "Kokkos::is_sorted_until_view_api_default"
- must be rank-1, and have
LayoutLeft,LayoutRight, orLayoutStride - must be accessible from
exespace
-
(1,2,3,4): the last iterator
itfor which range[first, it)is sorted, and where the following is true:std::is_same_v<decltype(it), IteratorType>. -
(5,6,7,8): the last iterator
itfor which range[Kokkos::Experimental::begin(view), it)is sorted. Note thatitis computed as:Kokkos::Experimental::begin(view) + incrementwhereincrementis found in the algoritm.