DDC 0.5.0
Loading...
Searching...
No Matches
strided_discrete_domain.hpp
1// Copyright (C) The DDC development team, see COPYRIGHT.md file
2//
3// SPDX-License-Identifier: MIT
4
5#pragma once
6
7#include <cassert>
8#include <cstddef>
9#include <iterator>
10#include <tuple>
11#include <type_traits>
12
13#include <Kokkos_Macros.hpp>
14
15#include "ddc/detail/type_seq.hpp"
16#include "ddc/discrete_element.hpp"
17#include "ddc/discrete_vector.hpp"
18
19namespace ddc {
20
21template <class DDim>
23
24template <class... DDims>
26
27template <class T>
28struct is_strided_discrete_domain : std::false_type
29{
30};
31
32template <class... Tags>
33struct is_strided_discrete_domain<StridedDiscreteDomain<Tags...>> : std::true_type
34{
35};
36
37template <class T>
39
40
41namespace detail {
42
43template <class... Tags>
44struct ToTypeSeq<StridedDiscreteDomain<Tags...>>
45{
46 using type = TypeSeq<Tags...>;
47};
48
49template <class T, class U>
50struct RebindDomain;
51
52template <class... DDims, class... ODDims>
53struct RebindDomain<StridedDiscreteDomain<DDims...>, detail::TypeSeq<ODDims...>>
54{
55 using type = StridedDiscreteDomain<ODDims...>;
56};
57
58} // namespace detail
59
60template <class... ODDims>
62 DiscreteVector<ODDims...> const& lhs,
63 DiscreteVector<ODDims...> const& rhs) noexcept
64{
65 return DiscreteVector<ODDims...>((get<ODDims>(lhs) * get<ODDims>(rhs))...);
66}
67
68template <class... DDims>
70{
71 template <class...>
72 friend class StridedDiscreteDomain;
73
74public:
75 using discrete_element_type = DiscreteElement<DDims...>;
76
77 using discrete_vector_type = DiscreteVector<DDims...>;
78
79private:
80 DiscreteElement<DDims...> m_element_begin;
81
82 DiscreteVector<DDims...> m_extents;
83
84 DiscreteVector<DDims...> m_strides;
85
86public:
87 static KOKKOS_FUNCTION constexpr std::size_t rank()
88 {
89 return sizeof...(DDims);
90 }
91
93
94 /// Construct a StridedDiscreteDomain by copies and merge of domains
95 template <
96 class... DDoms,
97 class = std::enable_if_t<(is_strided_discrete_domain_v<DDoms> && ...)>>
98 KOKKOS_FUNCTION constexpr explicit StridedDiscreteDomain(DDoms const&... domains)
99 : m_element_begin(domains.front()...)
100 , m_extents(domains.extents()...)
101 , m_strides(domains.strides()...)
102 {
103 }
104
105 /** Construct a StridedDiscreteDomain starting from element_begin with size points.
106 * @param element_begin the lower bound in each direction
107 * @param extents the number of points in each direction
108 * @param strides the step between two elements
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)
115 , m_extents(extents)
116 , m_strides(strides)
117 {
118 }
119
121
123
125
127 = default;
128
130
131 template <class... ODims>
132 KOKKOS_FUNCTION constexpr bool operator==(StridedDiscreteDomain<ODims...> const& other) const
133 {
134 if (empty() && other.empty()) {
135 return true;
136 }
137 return m_element_begin == other.m_element_begin && m_extents == other.m_extents
138 && m_strides == other.m_strides;
139 }
140
141#if !defined(__cpp_impl_three_way_comparison) || __cpp_impl_three_way_comparison < 201902L
142 // In C++20, `a!=b` shall be automatically translated by the compiler to `!(a==b)`
143 template <class... ODims>
144 KOKKOS_FUNCTION constexpr bool operator!=(StridedDiscreteDomain<ODims...> const& other) const
145 {
146 return !(*this == other);
147 }
148#endif
149
150 KOKKOS_FUNCTION constexpr std::size_t size() const
151 {
152 return (1UL * ... * get<DDims>(m_extents));
153 }
154
155 KOKKOS_FUNCTION constexpr discrete_vector_type extents() const noexcept
156 {
157 return m_extents;
158 }
159
160 KOKKOS_FUNCTION constexpr discrete_vector_type strides() const noexcept
161 {
162 return m_strides;
163 }
164
165 template <class QueryDDim>
166 KOKKOS_FUNCTION constexpr DiscreteVector<QueryDDim> extent() const noexcept
167 {
168 return DiscreteVector<QueryDDim>(uid<QueryDDim>(m_extents));
169 }
170
171 KOKKOS_FUNCTION constexpr discrete_element_type front() const noexcept
172 {
173 return m_element_begin;
174 }
175
176 KOKKOS_FUNCTION constexpr discrete_element_type back() const noexcept
177 {
178 return discrete_element_type(
179 (uid<DDims>(m_element_begin)
180 + (get<DDims>(m_extents) - 1) * get<DDims>(m_strides))...);
181 }
182
183 KOKKOS_FUNCTION constexpr StridedDiscreteDomain take_first(discrete_vector_type n) const
184 {
185 return StridedDiscreteDomain(front(), n, m_strides);
186 }
187
188 KOKKOS_FUNCTION constexpr StridedDiscreteDomain take_last(discrete_vector_type n) const
189 {
190 return StridedDiscreteDomain(front() + prod(extents() - n, m_strides), n, m_strides);
191 }
192
193 KOKKOS_FUNCTION constexpr StridedDiscreteDomain remove_first(discrete_vector_type n) const
194 {
195 return StridedDiscreteDomain(front() + prod(n, m_strides), extents() - n, m_strides);
196 }
197
198 KOKKOS_FUNCTION constexpr StridedDiscreteDomain remove_last(discrete_vector_type n) const
199 {
200 return StridedDiscreteDomain(front(), extents() - n, m_strides);
201 }
202
204 discrete_vector_type n1,
205 discrete_vector_type n2) const
206 {
207 return StridedDiscreteDomain(front() + prod(n1, m_strides), extents() - n1 - n2, m_strides);
208 }
209
210 KOKKOS_FUNCTION constexpr DiscreteElement<DDims...> operator()(
211 DiscreteVector<DDims...> const& dvect) const noexcept
212 {
213 return m_element_begin + prod(dvect, m_strides);
214 }
215
216 template <class... DElems>
217 KOKKOS_FUNCTION bool contains(DElems const&... delems) const noexcept
218 {
219 static_assert(
220 sizeof...(DDims) == (0 + ... + DElems::size()),
221 "Invalid number of dimensions");
222 static_assert((is_discrete_element_v<DElems> && ...), "Expected DiscreteElements");
223 auto const test1
224 = ((DiscreteElement<DDims>(take<DDims>(delems...))
225 >= DiscreteElement<DDims>(m_element_begin))
226 && ...);
227 auto const test2
228 = ((DiscreteElement<DDims>(take<DDims>(delems...))
229 < (DiscreteElement<DDims>(m_element_begin)
230 + DiscreteVector<DDims>(m_extents) * DiscreteVector<DDims>(m_strides)))
231 && ...);
232 auto const test3
233 = ((((DiscreteElement<DDims>(take<DDims>(delems...))
234 - DiscreteElement<DDims>(m_element_begin))
235 % DiscreteVector<DDims>(m_strides))
236 == 0)
237 && ...);
238 return test1 && test2 && test3;
239 }
240
241 template <class... DElems>
243 DElems const&... delems) const noexcept
244 {
245 static_assert(
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...));
250 return DiscreteVector<DDims...>(
251 ((DiscreteElement<DDims>(take<DDims>(delems...))
252 - DiscreteElement<DDims>(m_element_begin))
253 / DiscreteVector<DDims>(m_strides))...);
254 }
255
256 KOKKOS_FUNCTION constexpr bool empty() const noexcept
257 {
258 return size() == 0;
259 }
260
261 KOKKOS_FUNCTION constexpr explicit operator bool()
262 {
263 return !empty();
264 }
265
266 template <
267 std::size_t N = sizeof...(DDims),
268 class DDim0 = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
269 KOKKOS_FUNCTION auto begin() const
270 {
271 return StridedDiscreteDomainIterator<DDim0>(front(), m_strides);
272 }
273
274 template <
275 std::size_t N = sizeof...(DDims),
276 class DDim0 = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
277 KOKKOS_FUNCTION auto end() const
278 {
280 DDim0>(m_element_begin + m_extents * m_strides, m_strides);
281 }
282
283 template <
284 std::size_t N = sizeof...(DDims),
285 class DDim0 = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
286 KOKKOS_FUNCTION auto cbegin() const
287 {
288 return StridedDiscreteDomainIterator<DDim0>(front(), m_strides);
289 }
290
291 template <
292 std::size_t N = sizeof...(DDims),
293 class DDim0 = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
294 KOKKOS_FUNCTION auto cend() const
295 {
297 DDim0>(m_element_begin + m_extents * m_strides, m_strides);
298 }
299
300 template <
301 std::size_t N = sizeof...(DDims),
302 class = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
303 KOKKOS_FUNCTION constexpr decltype(auto) operator[](std::size_t n)
304 {
305 return begin()[n];
306 }
307
308 template <
309 std::size_t N = sizeof...(DDims),
310 class = std::enable_if_t<N == 1, std::tuple_element_t<0, std::tuple<DDims...>>>>
311 KOKKOS_FUNCTION constexpr decltype(auto) operator[](std::size_t n) const
312 {
313 return begin()[n];
314 }
315};
316
317template <>
319{
320 template <class...>
321 friend class StridedDiscreteDomain;
322
323public:
324 using discrete_element_type = DiscreteElement<>;
325
326 using discrete_vector_type = DiscreteVector<>;
327
328 static KOKKOS_FUNCTION constexpr std::size_t rank()
329 {
330 return 0;
331 }
332
334
335 // Construct a StridedDiscreteDomain from a reordered copy of `domain`
336 template <class... ODDims>
337 KOKKOS_FUNCTION constexpr explicit StridedDiscreteDomain(
338 [[maybe_unused]] StridedDiscreteDomain<ODDims...> const& domain)
339 {
340 }
341
342 /** Construct a StridedDiscreteDomain starting from element_begin with size points.
343 * @param element_begin the lower bound in each direction
344 * @param size the number of points in each direction
345 * @param strides the step between two elements
346 */
348 [[maybe_unused]] discrete_element_type const& element_begin,
349 [[maybe_unused]] discrete_vector_type const& size,
350 [[maybe_unused]] discrete_vector_type const& strides)
351 {
352 }
353
355
357
359
361 = default;
362
364
365 KOKKOS_FUNCTION constexpr bool operator==(
366 [[maybe_unused]] StridedDiscreteDomain const& other) const
367 {
368 return true;
369 }
370
371#if !defined(__cpp_impl_three_way_comparison) || __cpp_impl_three_way_comparison < 201902L
372 // In C++20, `a!=b` shall be automatically translated by the compiler to `!(a==b)`
373 KOKKOS_FUNCTION constexpr bool operator!=(StridedDiscreteDomain const& other) const
374 {
375 return !(*this == other);
376 }
377#endif
378
379 static KOKKOS_FUNCTION constexpr std::size_t size()
380 {
381 return 1;
382 }
383
384 static KOKKOS_FUNCTION constexpr discrete_vector_type extents() noexcept
385 {
386 return {};
387 }
388
389 static KOKKOS_FUNCTION constexpr discrete_element_type front() noexcept
390 {
391 return {};
392 }
393
394 static KOKKOS_FUNCTION constexpr discrete_element_type back() noexcept
395 {
396 return {};
397 }
398
400 [[maybe_unused]] discrete_vector_type n) const
401 {
402 return *this;
403 }
404
406 [[maybe_unused]] discrete_vector_type n) const
407 {
408 return *this;
409 }
410
412 [[maybe_unused]] discrete_vector_type n) const
413 {
414 return *this;
415 }
416
418 [[maybe_unused]] discrete_vector_type n) const
419 {
420 return *this;
421 }
422
424 [[maybe_unused]] discrete_vector_type n1,
425 [[maybe_unused]] discrete_vector_type n2) const
426 {
427 return *this;
428 }
429
430 KOKKOS_FUNCTION constexpr DiscreteElement<> operator()(
431 DiscreteVector<> const& /* dvect */) const noexcept
432 {
433 return {};
434 }
435
436 static KOKKOS_FUNCTION bool contains() noexcept
437 {
438 return true;
439 }
440
441 static KOKKOS_FUNCTION bool contains(DiscreteElement<>) noexcept
442 {
443 return true;
444 }
445
447 {
448 return {};
449 }
450
451 static KOKKOS_FUNCTION DiscreteVector<> distance_from_front(DiscreteElement<>) noexcept
452 {
453 return {};
454 }
455
456 static KOKKOS_FUNCTION constexpr bool empty() noexcept
457 {
458 return false;
459 }
460
461 KOKKOS_FUNCTION constexpr explicit operator bool()
462 {
463 return true;
464 }
465};
466
467template <class... QueryDDims, class... DDims>
468KOKKOS_FUNCTION constexpr StridedDiscreteDomain<QueryDDims...> select(
469 StridedDiscreteDomain<DDims...> const& domain)
470{
471 return StridedDiscreteDomain<QueryDDims...>(
472 DiscreteElement<QueryDDims...>(domain.front()),
473 DiscreteVector<QueryDDims...>(domain.extents()),
474 DiscreteVector<QueryDDims...>(domain.strides()));
475}
476
477namespace detail {
478
479template <class T>
480struct ConvertTypeSeqToStridedDiscreteDomain;
481
482template <class... DDims>
483struct ConvertTypeSeqToStridedDiscreteDomain<detail::TypeSeq<DDims...>>
484{
485 using type = StridedDiscreteDomain<DDims...>;
486};
487
488template <class T>
489using convert_type_seq_to_strided_discrete_domain_t =
490 typename ConvertTypeSeqToStridedDiscreteDomain<T>::type;
491
492} // namespace detail
493
494// Computes the subtraction DDom_a - DDom_b in the sense of linear spaces(retained dimensions are those in DDom_a which are not in DDom_b)
495template <class... DDimsA, class... DDimsB>
496KOKKOS_FUNCTION constexpr auto remove_dims_of(
497 StridedDiscreteDomain<DDimsA...> const& DDom_a,
498 [[maybe_unused]] StridedDiscreteDomain<DDimsB...> const& DDom_b) noexcept
499{
500 using TagSeqA = detail::TypeSeq<DDimsA...>;
501 using TagSeqB = detail::TypeSeq<DDimsB...>;
502
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);
505}
506
507//! Remove the dimensions DDimsB from DDom_a
508//! @param[in] DDom_a The discrete domain on which to remove dimensions
509//! @return The discrete domain without DDimsB dimensions
510template <class... DDimsB, class... DDimsA>
511KOKKOS_FUNCTION constexpr auto remove_dims_of(
512 StridedDiscreteDomain<DDimsA...> const& DDom_a) noexcept
513{
514 using TagSeqA = detail::TypeSeq<DDimsA...>;
515 using TagSeqB = detail::TypeSeq<DDimsB...>;
516
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);
519}
520
521namespace detail {
522
523// Checks if dimension of DDom_a is DDim1. If not, returns restriction to DDim2 of DDom_b. May not be useful in its own, it helps for replace_dim_of
524template <typename DDim1, typename DDim2, typename DDimA, typename... DDimsB>
525KOKKOS_FUNCTION constexpr std::conditional_t<
526 std::is_same_v<DDimA, DDim1>,
529replace_dim_of_1d(
530 StridedDiscreteDomain<DDimA> const& DDom_a,
531 [[maybe_unused]] StridedDiscreteDomain<DDimsB...> const& DDom_b) noexcept
532{
533 if constexpr (std::is_same_v<DDimA, DDim1>) {
534 return ddc::StridedDiscreteDomain<DDim2>(DDom_b);
535 } else {
536 return DDom_a;
537 }
538}
539
540} // namespace detail
541
542// Replace in DDom_a the dimension Dim1 by the dimension Dim2 of DDom_b
543template <typename DDim1, typename DDim2, typename... DDimsA, typename... DDimsB>
544KOKKOS_FUNCTION constexpr auto replace_dim_of(
545 StridedDiscreteDomain<DDimsA...> const& DDom_a,
546 [[maybe_unused]] StridedDiscreteDomain<DDimsB...> const& DDom_b) noexcept
547{
548 // TODO : static_asserts
549 using TagSeqA = detail::TypeSeq<DDimsA...>;
550 using TagSeqB = detail::TypeSeq<DDim1>;
551 using TagSeqC = detail::TypeSeq<DDim2>;
552
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<
556 DDim1,
557 DDim2,
558 DDimsA,
559 DDimsB...>(ddc::StridedDiscreteDomain<DDimsA>(DDom_a), DDom_b)...);
560}
561
562template <class... QueryDDims, class... DDims>
563KOKKOS_FUNCTION constexpr DiscreteVector<QueryDDims...> extents(
564 StridedDiscreteDomain<DDims...> const& domain) noexcept
565{
566 return DiscreteVector<QueryDDims...>(StridedDiscreteDomain<QueryDDims>(domain).size()...);
567}
568
569template <class... QueryDDims, class... DDims>
570KOKKOS_FUNCTION constexpr DiscreteElement<QueryDDims...> front(
571 StridedDiscreteDomain<DDims...> const& domain) noexcept
572{
573 return DiscreteElement<QueryDDims...>(StridedDiscreteDomain<QueryDDims>(domain).front()...);
574}
575
576template <class... QueryDDims, class... DDims>
577KOKKOS_FUNCTION constexpr DiscreteElement<QueryDDims...> back(
578 StridedDiscreteDomain<DDims...> const& domain) noexcept
579{
580 return DiscreteElement<QueryDDims...>(StridedDiscreteDomain<QueryDDims>(domain).back()...);
581}
582
583template <class DDim>
585{
586private:
587 DiscreteElement<DDim> m_value = DiscreteElement<DDim>();
588
589 DiscreteVector<DDim> m_stride = DiscreteVector<DDim>();
590
591public:
592 using iterator_category = std::random_access_iterator_tag;
593
594 using value_type = DiscreteElement<DDim>;
595
596 using difference_type = std::ptrdiff_t;
597
599
601 DiscreteElement<DDim> value,
602 DiscreteVector<DDim> stride)
603 : m_value(value)
604 , m_stride(stride)
605 {
606 }
607
608 KOKKOS_FUNCTION constexpr DiscreteElement<DDim> operator*() const noexcept
609 {
610 return m_value;
611 }
612
614 {
615 m_value.uid() += m_stride.value();
616 return *this;
617 }
618
620 {
621 auto tmp = *this;
622 ++*this;
623 return tmp;
624 }
625
627 {
628 m_value.uid() -= m_stride.value();
629 return *this;
630 }
631
633 {
634 auto tmp = *this;
635 --*this;
636 return tmp;
637 }
638
639 KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator& operator+=(difference_type n)
640 {
641 if (n >= difference_type(0)) {
642 m_value.uid() += static_cast<DiscreteElementType>(n) * m_stride.value();
643 } else {
644 m_value.uid() -= static_cast<DiscreteElementType>(-n) * m_stride.value();
645 }
646 return *this;
647 }
648
649 KOKKOS_FUNCTION constexpr StridedDiscreteDomainIterator& operator-=(difference_type n)
650 {
651 if (n >= difference_type(0)) {
652 m_value.uid() -= static_cast<DiscreteElementType>(n) * m_stride.value();
653 } else {
654 m_value.uid() += static_cast<DiscreteElementType>(-n) * m_stride.value();
655 }
656 return *this;
657 }
658
659 KOKKOS_FUNCTION constexpr DiscreteElement<DDim> operator[](difference_type n) const
660 {
661 return m_value + n * m_stride.value();
662 }
663
664 friend KOKKOS_FUNCTION constexpr bool operator==(
667 {
668 return xx.m_value == yy.m_value;
669 }
670
671#if !defined(__cpp_impl_three_way_comparison) || __cpp_impl_three_way_comparison < 201902L
672 // In C++20, `a!=b` shall be automatically translated by the compiler to `!(a==b)`
673 friend KOKKOS_FUNCTION constexpr bool operator!=(
676 {
677 return xx.m_value != yy.m_value;
678 }
679#endif
680
681 friend KOKKOS_FUNCTION constexpr bool operator<(
684 {
685 return xx.m_value < yy.m_value;
686 }
687
688 friend KOKKOS_FUNCTION constexpr bool operator>(
691 {
692 return yy < xx;
693 }
694
695 friend KOKKOS_FUNCTION constexpr bool operator<=(
698 {
699 return !(yy < xx);
700 }
701
702 friend KOKKOS_FUNCTION constexpr bool operator>=(
705 {
706 return !(xx < yy);
707 }
708
711 difference_type n)
712 {
713 return i += n;
714 }
715
717 difference_type n,
719 {
720 return i += n;
721 }
722
725 difference_type n)
726 {
727 return i -= n;
728 }
729
730 friend KOKKOS_FUNCTION constexpr difference_type operator-(
733 {
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);
736 }
737};
738
739} // namespace ddc
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
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)