13#include <Kokkos_Macros.hpp>
15#include "ddc/detail/type_seq.hpp"
16#include "ddc/discrete_element.hpp"
17#include "ddc/discrete_vector.hpp"
24template <
class... DDims>
32template <
class... Tags>
43template <
class... Tags>
46 using type = TypeSeq<Tags...>;
49template <
class T,
class U>
52template <
class... DDims,
class... ODDims>
60template <
class... ODDims>
65 return DiscreteVector<ODDims...>((get<ODDims>(lhs) * get<ODDims>(rhs))...);
68template <
class... DDims>
75 using discrete_element_type = DiscreteElement<DDims...>;
80 DiscreteElement<DDims...> m_element_begin;
89 return sizeof...(DDims);
97 class = std::enable_if_t<(is_strided_discrete_domain_v<DDoms> && ...)>>
99 : m_element_begin(domains.front()...)
100 , m_extents(domains.extents()...)
101 , m_strides(domains.strides()...)
106
107
108
109
111 discrete_element_type
const& element_begin,
112 discrete_vector_type
const& extents,
113 discrete_vector_type
const& strides)
114 : m_element_begin(element_begin)
131 template <
class... ODims>
134 if (
empty() && other.empty()) {
137 return m_element_begin == other.m_element_begin && m_extents == other.m_extents
138 && m_strides == other.m_strides;
141#if !defined(__cpp_impl_three_way_comparison) || __cpp_impl_three_way_comparison < 201902L
143 template <
class...
ODims>
146 return !(*
this ==
other);
152 return (1UL * ... * get<DDims>(m_extents));
165 template <
class QueryDDim>
173 return m_element_begin;
178 return discrete_element_type(
179 (uid<DDims>(m_element_begin)
180 + (get<DDims>(m_extents) - 1) * get<DDims>(m_strides))...);
204 discrete_vector_type n1,
205 discrete_vector_type n2)
const
213 return m_element_begin + prod(dvect, m_strides);
216 template <
class... DElems>
220 sizeof...(DDims) == (0 + ... + DElems::size()),
221 "Invalid number of dimensions");
222 static_assert((is_discrete_element_v<DElems> && ...),
"Expected DiscreteElements");
224 = ((DiscreteElement<DDims>(take<DDims>(delems...))
225 >= DiscreteElement<DDims>(m_element_begin))
228 = ((DiscreteElement<DDims>(take<DDims>(delems...))
229 < (DiscreteElement<DDims>(m_element_begin)
233 = ((((DiscreteElement<DDims>(take<DDims>(delems...))
234 - DiscreteElement<DDims>(m_element_begin))
238 return test1 && test2 && test3;
241 template <
class... DElems>
243 DElems
const&... delems)
const noexcept
246 sizeof...(DDims) == (0 + ... + DElems::size()),
247 "Invalid number of dimensions");
248 static_assert((is_discrete_element_v<DElems> && ...),
"Expected DiscreteElements");
249 assert(contains(delems...));
251 ((DiscreteElement<DDims>(take<DDims>(delems...))
252 - DiscreteElement<DDims>(m_element_begin))
267 std::size_t N =
sizeof...(DDims),
268 class DDim0 = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
275 std::size_t N =
sizeof...(DDims),
276 class DDim0 = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
280 DDim0>(m_element_begin + m_extents * m_strides, m_strides);
284 std::size_t N =
sizeof...(DDims),
285 class DDim0 = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
292 std::size_t N =
sizeof...(DDims),
293 class DDim0 = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
297 DDim0>(m_element_begin + m_extents * m_strides, m_strides);
301 std::size_t N =
sizeof...(DDims),
302 class = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
309 std::size_t N =
sizeof...(DDims),
310 class = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
324 using discrete_element_type = DiscreteElement<>;
336 template <
class... ODDims>
343
344
345
346
348 [[
maybe_unused]] discrete_element_type
const& element_begin,
371#if !defined(__cpp_impl_three_way_comparison) || __cpp_impl_three_way_comparison < 201902L
375 return !(*
this ==
other);
467template <
class... QueryDDims,
class... DDims>
472 DiscreteElement<QueryDDims...>(domain.front()),
480struct ConvertTypeSeqToStridedDiscreteDomain;
482template <
class... DDims>
483struct ConvertTypeSeqToStridedDiscreteDomain<detail::TypeSeq<DDims...>>
489using convert_type_seq_to_strided_discrete_domain_t =
490 typename ConvertTypeSeqToStridedDiscreteDomain<T>::type;
495template <
class... DDimsA,
class... DDimsB>
500 using TagSeqA = detail::TypeSeq<DDimsA...>;
501 using TagSeqB = detail::TypeSeq<DDimsB...>;
503 using type_seq_r = type_seq_remove_t<TagSeqA, TagSeqB>;
504 return detail::convert_type_seq_to_strided_discrete_domain_t<type_seq_r>(DDom_a);
510template <
class... DDimsB,
class... DDimsA>
514 using TagSeqA = detail::TypeSeq<DDimsA...>;
515 using TagSeqB = detail::TypeSeq<DDimsB...>;
517 using type_seq_r = type_seq_remove_t<TagSeqA, TagSeqB>;
518 return detail::convert_type_seq_to_strided_discrete_domain_t<type_seq_r>(DDom_a);
524template <
typename DDim1,
typename DDim2,
typename DDimA,
typename... DDimsB>
525KOKKOS_FUNCTION
constexpr std::conditional_t<
526 std::is_same_v<DDimA, DDim1>,
533 if constexpr (std::is_same_v<DDimA, DDim1>) {
543template <
typename DDim1,
typename DDim2,
typename... DDimsA,
typename... DDimsB>
549 using TagSeqA = detail::TypeSeq<DDimsA...>;
550 using TagSeqB = detail::TypeSeq<DDim1>;
551 using TagSeqC = detail::TypeSeq<DDim2>;
553 using type_seq_r =
ddc::type_seq_replace_t<TagSeqA, TagSeqB, TagSeqC>;
554 return ddc::detail::convert_type_seq_to_strided_discrete_domain_t<type_seq_r>(
555 detail::replace_dim_of_1d<
562template <
class... QueryDDims,
class... DDims>
569template <
class... QueryDDims,
class... DDims>
576template <
class... QueryDDims,
class... DDims>
587 DiscreteElement<DDim> m_value = DiscreteElement<DDim>();
592 using iterator_category = std::random_access_iterator_tag;
594 using value_type = DiscreteElement<DDim>;
596 using difference_type = std::ptrdiff_t;
601 DiscreteElement<DDim> value,
615 m_value.uid() += m_stride.value();
628 m_value.uid() -= m_stride.value();
641 if (n >= difference_type(0)) {
642 m_value.uid() +=
static_cast<DiscreteElementType>(n) * m_stride.value();
644 m_value.uid() -=
static_cast<DiscreteElementType>(-n) * m_stride.value();
651 if (n >= difference_type(0)) {
652 m_value.uid() -=
static_cast<DiscreteElementType>(n) * m_stride.value();
654 m_value.uid() +=
static_cast<DiscreteElementType>(-n) * m_stride.value();
661 return m_value + n * m_stride.value();
668 return xx.m_value == yy.m_value;
671#if !defined(__cpp_impl_three_way_comparison) || __cpp_impl_three_way_comparison < 201902L
685 return xx.m_value < yy.m_value;
734 return (yy.m_value > xx.m_value) ? (-
static_cast<difference_type>(yy.m_value - xx.m_value))
735 : (xx.m_value - yy.m_value);
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteElement()=default
KOKKOS_FUNCTION constexpr bool operator!=(DiscreteVector< OTags... > const &rhs) const noexcept
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteVector()=default
static KOKKOS_FUNCTION DiscreteVector distance_from_front() noexcept
KOKKOS_DEFAULTED_FUNCTION StridedDiscreteDomain & operator=(StridedDiscreteDomain &&x)=default
static KOKKOS_FUNCTION constexpr std::size_t size()
KOKKOS_FUNCTION constexpr StridedDiscreteDomain(discrete_element_type const &element_begin, discrete_vector_type const &size, discrete_vector_type const &strides)
Construct a StridedDiscreteDomain starting from element_begin with size points.
static KOKKOS_FUNCTION bool contains(DiscreteElement<>) noexcept
KOKKOS_FUNCTION constexpr StridedDiscreteDomain remove_first(discrete_vector_type n) const
static KOKKOS_FUNCTION constexpr discrete_element_type front() noexcept
KOKKOS_FUNCTION constexpr StridedDiscreteDomain remove(discrete_vector_type n1, discrete_vector_type n2) const
static KOKKOS_FUNCTION bool contains() noexcept
KOKKOS_FUNCTION constexpr StridedDiscreteDomain remove_last(discrete_vector_type n) const
KOKKOS_FUNCTION constexpr StridedDiscreteDomain take_last(discrete_vector_type n) const
static KOKKOS_FUNCTION constexpr discrete_vector_type extents() noexcept
static KOKKOS_FUNCTION constexpr std::size_t rank()
KOKKOS_DEFAULTED_FUNCTION StridedDiscreteDomain(StridedDiscreteDomain &&x)=default
static KOKKOS_FUNCTION DiscreteVector distance_from_front(DiscreteElement<>) noexcept
KOKKOS_DEFAULTED_FUNCTION constexpr StridedDiscreteDomain()=default
KOKKOS_FUNCTION constexpr operator bool()
static KOKKOS_FUNCTION constexpr bool empty() noexcept
KOKKOS_DEFAULTED_FUNCTION StridedDiscreteDomain(StridedDiscreteDomain const &x)=default
KOKKOS_FUNCTION constexpr DiscreteElement operator()(DiscreteVector<> const &) const noexcept
static KOKKOS_FUNCTION constexpr discrete_element_type back() noexcept
KOKKOS_FUNCTION constexpr bool operator==(StridedDiscreteDomain const &other) const
KOKKOS_DEFAULTED_FUNCTION ~StridedDiscreteDomain()=default
KOKKOS_FUNCTION constexpr StridedDiscreteDomain take_first(discrete_vector_type n) const
KOKKOS_FUNCTION constexpr StridedDiscreteDomain(StridedDiscreteDomain< ODDims... > const &domain)
KOKKOS_DEFAULTED_FUNCTION StridedDiscreteDomain & operator=(StridedDiscreteDomain const &x)=default
KOKKOS_DEFAULTED_FUNCTION StridedDiscreteDomain & operator=(StridedDiscreteDomain const &x)=default
KOKKOS_FUNCTION constexpr discrete_vector_type extents() const noexcept
KOKKOS_FUNCTION constexpr operator bool()
KOKKOS_FUNCTION constexpr StridedDiscreteDomain take_first(discrete_vector_type n) const
KOKKOS_FUNCTION constexpr DiscreteVector< QueryDDim > extent() const noexcept
KOKKOS_FUNCTION constexpr discrete_element_type front() const noexcept
KOKKOS_FUNCTION bool contains(DElems const &... delems) const noexcept
KOKKOS_FUNCTION constexpr std::size_t size() const
KOKKOS_FUNCTION auto cend() const
KOKKOS_FUNCTION constexpr StridedDiscreteDomain(DDoms const &... domains)
Construct a StridedDiscreteDomain by copies and merge of domains.
KOKKOS_FUNCTION DiscreteVector< DDims... > distance_from_front(DElems const &... delems) const noexcept
KOKKOS_DEFAULTED_FUNCTION StridedDiscreteDomain(StridedDiscreteDomain &&x)=default
KOKKOS_FUNCTION constexpr discrete_vector_type strides() const noexcept
KOKKOS_DEFAULTED_FUNCTION StridedDiscreteDomain & operator=(StridedDiscreteDomain &&x)=default
KOKKOS_FUNCTION constexpr StridedDiscreteDomain remove(discrete_vector_type n1, discrete_vector_type n2) const
KOKKOS_FUNCTION constexpr StridedDiscreteDomain remove_first(discrete_vector_type n) const
KOKKOS_FUNCTION constexpr discrete_element_type back() const noexcept
KOKKOS_DEFAULTED_FUNCTION StridedDiscreteDomain()=default
KOKKOS_FUNCTION constexpr DiscreteElement< DDims... > operator()(DiscreteVector< DDims... > const &dvect) const noexcept
friend class StridedDiscreteDomain
KOKKOS_FUNCTION auto begin() const
KOKKOS_FUNCTION auto end() const
KOKKOS_FUNCTION constexpr StridedDiscreteDomain remove_last(discrete_vector_type n) const
KOKKOS_FUNCTION constexpr StridedDiscreteDomain take_last(discrete_vector_type n) const
KOKKOS_DEFAULTED_FUNCTION ~StridedDiscreteDomain()=default
KOKKOS_DEFAULTED_FUNCTION StridedDiscreteDomain(StridedDiscreteDomain const &x)=default
KOKKOS_FUNCTION constexpr bool operator==(StridedDiscreteDomain< ODims... > const &other) const
KOKKOS_FUNCTION constexpr decltype(auto) operator[](std::size_t n)
static KOKKOS_FUNCTION constexpr std::size_t rank()
KOKKOS_FUNCTION auto cbegin() const
KOKKOS_FUNCTION constexpr bool empty() const noexcept
KOKKOS_FUNCTION constexpr decltype(auto) operator[](std::size_t n) const
KOKKOS_FUNCTION constexpr StridedDiscreteDomain(discrete_element_type const &element_begin, discrete_vector_type const &extents, discrete_vector_type const &strides)
Construct a StridedDiscreteDomain starting from element_begin with size points.
The top-level namespace of DDC.
KOKKOS_FUNCTION constexpr auto remove_dims_of(StridedDiscreteDomain< DDimsA... > const &DDom_a, StridedDiscreteDomain< DDimsB... > const &DDom_b) noexcept
KOKKOS_FUNCTION constexpr DiscreteElement< QueryDDims... > front(StridedDiscreteDomain< DDims... > const &domain) noexcept
KOKKOS_FUNCTION constexpr DiscreteVector< QueryDDims... > extents(StridedDiscreteDomain< DDims... > const &domain) noexcept
KOKKOS_FUNCTION constexpr DiscreteElement< QueryDDims... > back(StridedDiscreteDomain< DDims... > const &domain) noexcept
KOKKOS_FUNCTION constexpr StridedDiscreteDomain< QueryDDims... > select(StridedDiscreteDomain< DDims... > const &domain)
KOKKOS_FUNCTION constexpr auto remove_dims_of(StridedDiscreteDomain< DDimsA... > const &DDom_a) noexcept
Remove the dimensions DDimsB from DDom_a.
constexpr bool is_strided_discrete_domain_v
KOKKOS_FUNCTION DiscreteVector< ODDims... > prod(DiscreteVector< ODDims... > const &lhs, DiscreteVector< ODDims... > const &rhs) noexcept
KOKKOS_FUNCTION constexpr auto replace_dim_of(StridedDiscreteDomain< DDimsA... > const &DDom_a, StridedDiscreteDomain< DDimsB... > const &DDom_b) noexcept
friend KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator operator-(StridedDiscreteDomainIterator i, difference_type n)
KOKKOS_FUNCTION constexpr DiscreteElement< DDim > operator*() const noexcept
KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator & operator++()
friend KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator operator+(difference_type n, StridedDiscreteDomainIterator i)
KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator & operator-=(difference_type n)
KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator operator++(int)
friend KOKKOS_FUNCTION constexpr bool operator<(StridedDiscreteDomainIterator const &xx, StridedDiscreteDomainIterator const &yy)
KOKKOS_DEFAULTED_FUNCTION StridedDiscreteDomainIterator()=default
KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator operator--(int)
friend KOKKOS_FUNCTION constexpr bool operator==(StridedDiscreteDomainIterator const &xx, StridedDiscreteDomainIterator const &yy)
KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator(DiscreteElement< DDim > value, DiscreteVector< DDim > stride)
KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator & operator+=(difference_type n)
KOKKOS_FUNCTION constexpr DiscreteElement< DDim > operator[](difference_type n) const
friend KOKKOS_FUNCTION constexpr difference_type operator-(StridedDiscreteDomainIterator const &xx, StridedDiscreteDomainIterator const &yy)
KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator & operator--()
friend KOKKOS_FUNCTION constexpr bool operator>=(StridedDiscreteDomainIterator const &xx, StridedDiscreteDomainIterator const &yy)
friend KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator operator+(StridedDiscreteDomainIterator i, difference_type n)
friend KOKKOS_FUNCTION constexpr bool operator>(StridedDiscreteDomainIterator const &xx, StridedDiscreteDomainIterator const &yy)
friend KOKKOS_FUNCTION constexpr bool operator!=(StridedDiscreteDomainIterator const &xx, StridedDiscreteDomainIterator const &yy)
friend KOKKOS_FUNCTION constexpr bool operator<=(StridedDiscreteDomainIterator const &xx, StridedDiscreteDomainIterator const &yy)