DDC 0.12.0
Loading...
Searching...
No Matches
chunk_span.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 <cstddef>
8#include <type_traits>
9#include <utility>
10
11#include <Kokkos_Core.hpp>
12
13#include "detail/kokkos.hpp"
14#include "detail/macros.hpp"
15#include "detail/type_seq.hpp"
16
17#include "chunk_common.hpp"
21
22namespace ddc {
23
24template <class, class, class>
25class Chunk;
26
27template <
28 class ElementType,
29 class SupportType,
30 class LayoutStridedPolicy = Kokkos::layout_right,
31 class MemorySpace = Kokkos::DefaultHostExecutionSpace::memory_space>
32class ChunkSpan;
33
34template <class ElementType, class SupportType, class LayoutStridedPolicy, class MemorySpace>
35inline constexpr bool
37 = true;
38
39template <class ElementType, class SupportType, class LayoutStridedPolicy, class MemorySpace>
40inline constexpr bool
42 = true;
43
44template <class ElementType, class SupportType, class LayoutStridedPolicy, class MemorySpace>
45class ChunkSpan : public ChunkCommon<ElementType, SupportType, LayoutStridedPolicy>
46{
47 static_assert(
48 std::is_same_v<LayoutStridedPolicy, Kokkos::layout_left>
49 || std::is_same_v<LayoutStridedPolicy, Kokkos::layout_right>
50 || std::is_same_v<LayoutStridedPolicy, Kokkos::layout_stride>,
51 "ChunkSpan only supports layout_left, layout_right or layout_stride");
52
53protected:
54 using base_type = ChunkCommon<ElementType, SupportType, LayoutStridedPolicy>;
55
56public:
57 /// type of a span of this full chunk
58 using span_type = ChunkSpan<ElementType, SupportType, LayoutStridedPolicy, MemorySpace>;
59
60 /// type of a view of this full chunk
61 using view_type = ChunkSpan<ElementType const, SupportType, LayoutStridedPolicy, MemorySpace>;
62
63 using discrete_domain_type = typename base_type::discrete_domain_type;
64
65 using memory_space = MemorySpace;
66
67 /// The dereferenceable part of the co-domain but with a different domain, starting at 0
68 using allocation_mdspan_type = typename base_type::allocation_mdspan_type;
69
70 using const_allocation_mdspan_type = typename base_type::const_allocation_mdspan_type;
71
72 using discrete_element_type = typename discrete_domain_type::discrete_element_type;
73
74 using discrete_vector_type = typename discrete_domain_type::discrete_vector_type;
75
76 using extents_type = typename base_type::extents_type;
77
78 using layout_type = typename base_type::layout_type;
79
80 using accessor_type = typename base_type::accessor_type;
81
82 using mapping_type = typename base_type::mapping_type;
83
84 using element_type = typename base_type::element_type;
85
86 using value_type = typename base_type::value_type;
87
88 using size_type = typename base_type::size_type;
89
90 using data_handle_type = typename base_type::data_handle_type;
91
92 using reference = typename base_type::reference;
93
94 template <class, class, class, class>
95 friend class ChunkSpan;
96
97protected:
98 template <class QueryDDim, class... ODDims>
99 KOKKOS_FUNCTION static constexpr auto get_slicer_for(DiscreteVector<ODDims...> const& c)
100 {
101 DDC_IF_NVCC_THEN_PUSH_AND_SUPPRESS(implicit_return_from_non_void_function)
102 if constexpr (in_tags_v<QueryDDim, detail::TypeSeq<ODDims...>>) {
103 return c.template get<QueryDDim>();
104 } else {
105 return Kokkos::full_extent;
106 }
107 DDC_IF_NVCC_THEN_POP
108 }
109
110 template <class QueryDDim, class... ODDims, class... OODDims>
111 KOKKOS_FUNCTION static constexpr auto get_slicer_for(
112 DiscreteDomain<ODDims...> const& c,
113 DiscreteDomain<OODDims...> const& origin)
114 {
115 DDC_IF_NVCC_THEN_PUSH_AND_SUPPRESS(implicit_return_from_non_void_function)
116 if constexpr (in_tags_v<QueryDDim, detail::TypeSeq<ODDims...>>) {
117 DiscreteDomain<QueryDDim> const c_slice(c);
118 DiscreteDomain<QueryDDim> const origin_slice(origin);
119 return std::pair<std::size_t, std::size_t>(
120 c_slice.front() - origin_slice.front(),
121 c_slice.back() + 1 - origin_slice.front());
122 } else {
123 return Kokkos::full_extent;
124 }
125 DDC_IF_NVCC_THEN_POP
126 }
127
128 template <class TypeSeq>
129 struct slicer;
130
131 template <class... DDims>
132 struct slicer<detail::TypeSeq<DDims...>>
133 {
134 template <class... ODDims>
135 KOKKOS_FUNCTION constexpr auto operator()(
136 allocation_mdspan_type const& span,
137 DiscreteVector<ODDims...> const& c) const
138 {
139 return Kokkos::submdspan(span, get_slicer_for<DDims>(c)...);
140 }
141
142 template <class... ODDims, class... OODDims>
143 KOKKOS_FUNCTION constexpr auto operator()(
144 allocation_mdspan_type const& span,
145 DiscreteDomain<ODDims...> const& c,
146 DiscreteDomain<OODDims...> const& origin) const
147 {
148 return Kokkos::submdspan(span, get_slicer_for<DDims>(c, origin)...);
149 }
150 };
151
152public:
153 /// Empty ChunkSpan
154 KOKKOS_DEFAULTED_FUNCTION constexpr ChunkSpan() = default;
155
156 /** Constructs a new ChunkSpan by copy, yields a new view to the same data
157 * @param other the ChunkSpan to copy
158 */
159 KOKKOS_DEFAULTED_FUNCTION constexpr ChunkSpan(ChunkSpan const& other) = default;
160
161 /** Constructs a new ChunkSpan by move
162 * @param other the ChunkSpan to move
163 */
164 KOKKOS_DEFAULTED_FUNCTION constexpr ChunkSpan(ChunkSpan&& other) noexcept = default;
165
166 /** Forbids to construct a ChunkSpan from a rvalue of type Chunk.
167 */
168 template <class OElementType, class Allocator>
169 ChunkSpan(Chunk<OElementType, SupportType, Allocator>&& other) noexcept
170 requires(std::is_same_v<typename Allocator::memory_space, MemorySpace>)
171 = delete;
172
173 /** Constructs a new ChunkSpan from a Chunk, yields a new view to the same data
174 * @param other the Chunk to view
175 */
176 template <class OElementType, class Allocator>
177 KOKKOS_FUNCTION constexpr explicit ChunkSpan(
178 Chunk<OElementType, SupportType, Allocator>& other) noexcept
179 requires(std::is_same_v<typename Allocator::memory_space, MemorySpace>)
180 : base_type(other.m_allocation_mdspan, other.m_domain)
181 {
182 }
183
184 /** Constructs a new ChunkSpan from a Chunk, yields a new view to the same data
185 * @param other the Chunk to view
186 */
187 // Disabled in the case of `ElementType` is not `const` to avoid write access
188 template <class OElementType, class Allocator>
189 KOKKOS_FUNCTION constexpr explicit ChunkSpan(
190 Chunk<OElementType, SupportType, Allocator> const& other) noexcept
191 requires(
192 std::is_const_v<ElementType>
193 && std::is_same_v<typename Allocator::memory_space, MemorySpace>)
194 : base_type(other.m_allocation_mdspan, other.m_domain)
195 {
196 }
197
198 /** Constructs a new ChunkSpan by copy of a chunk, yields a new view to the same data
199 * @param other the ChunkSpan to move
200 */
201 template <class OElementType>
202 KOKKOS_FUNCTION constexpr explicit ChunkSpan(
203 ChunkSpan<OElementType, SupportType, layout_type, MemorySpace> const& other) noexcept
204 : base_type(other.m_allocation_mdspan, other.m_domain)
205 {
206 }
207
208 /** Constructs a new ChunkSpan from scratch
209 * @param ptr the allocation pointer to the data
210 * @param domain the domain that sustains the view
211 */
212 KOKKOS_FUNCTION constexpr ChunkSpan(ElementType* const ptr, SupportType const& domain)
213 requires(std::is_constructible_v<mapping_type, extents_type>)
214 : base_type(ptr, domain)
215 {
216 }
217
218 /** Constructs a new ChunkSpan from scratch
219 * @param allocation_mdspan the allocation mdspan to the data
220 * @param domain the domain that sustains the view
221 */
222 KOKKOS_FUNCTION constexpr ChunkSpan(
223 allocation_mdspan_type allocation_mdspan,
224 SupportType const& domain)
225 : base_type(allocation_mdspan, domain)
226 {
227 for (std::size_t i = 0; i < SupportType::rank(); ++i) {
228 KOKKOS_ASSERT(
229 allocation_mdspan.extent(i)
230 == static_cast<std::size_t>(detail::array(domain.extents())[i]))
231 }
232 }
233
234 /** Constructs a new ChunkSpan from scratch
235 * @param view the Kokkos view
236 * @param domain the domain that sustains the view
237 */
238 template <class KokkosView>
239 KOKKOS_FUNCTION constexpr ChunkSpan(KokkosView const& view, SupportType const& domain) noexcept
240 requires(Kokkos::is_view_v<KokkosView>)
241 : ChunkSpan(
242 detail::build_mdspan(view, std::make_index_sequence<SupportType::rank()> {}),
243 domain)
244 {
245 }
246
247 KOKKOS_DEFAULTED_FUNCTION ~ChunkSpan() noexcept = default;
248
249 /** Copy-assigns a new value to this ChunkSpan, yields a new view to the same data
250 * @param other the ChunkSpan to copy
251 * @return *this
252 */
253 KOKKOS_DEFAULTED_FUNCTION constexpr ChunkSpan& operator=(ChunkSpan const& other) = default;
254
255 /** Move-assigns a new value to this ChunkSpan
256 * @param other the ChunkSpan to move
257 * @return *this
258 */
259 KOKKOS_DEFAULTED_FUNCTION constexpr ChunkSpan& operator=(ChunkSpan&& other) noexcept = default;
260
261 /** Slice out some dimensions
262 */
263 template <class... QueryDDims>
264 KOKKOS_FUNCTION constexpr auto operator[](
265 DiscreteElement<QueryDDims...> const& slice_spec) const
266 {
267 using detail::TypeSeq;
268 using QueryDDom = typename detail::RebindDomain<SupportType, TypeSeq<QueryDDims...>>::type;
269 KOKKOS_ASSERT(QueryDDom(this->m_domain).contains(slice_spec))
270 slicer<to_type_seq_t<SupportType>> const slicer;
271 auto subview = slicer(
272 this->allocation_mdspan(),
273 QueryDDom(this->m_domain).distance_from_front(slice_spec));
274 using layout_type = typename decltype(subview)::layout_type;
275 using extents_type = typename decltype(subview)::extents_type;
276 using OutTypeSeqDDims
277 = type_seq_remove_t<to_type_seq_t<SupportType>, TypeSeq<QueryDDims...>>;
278 using OutDDom = typename detail::RebindDomain<SupportType, OutTypeSeqDDims>::type;
279 if constexpr (
280 std::is_same_v<layout_type, Kokkos::Experimental::layout_left_padded<>>
281 || std::is_same_v<layout_type, Kokkos::Experimental::layout_right_padded<>>) {
282 Kokkos::layout_stride::mapping<extents_type> const mapping_stride(subview.mapping());
283 Kokkos::mdspan<ElementType, extents_type, Kokkos::layout_stride> const
284 a(subview.data_handle(), mapping_stride);
285 return ChunkSpan<
286 ElementType,
287 OutDDom,
288 Kokkos::layout_stride,
289 memory_space>(a, OutDDom(this->m_domain));
290 } else {
291 return ChunkSpan<
292 ElementType,
293 OutDDom,
294 layout_type,
295 memory_space>(subview, OutDDom(this->m_domain));
296 }
297 }
298
299 /** Restrict to a subdomain, only valid when SupportType is a DiscreteDomain
300 */
301 template <class... QueryDDims>
302 KOKKOS_FUNCTION constexpr auto operator[](DiscreteDomain<QueryDDims...> const& odomain) const
303 requires(is_discrete_domain_v<SupportType>)
304 {
305 KOKKOS_ASSERT(
306 odomain.empty()
307 || (DiscreteDomain<QueryDDims...>(this->m_domain).contains(odomain.front())
308 && DiscreteDomain<QueryDDims...>(this->m_domain).contains(odomain.back())))
309 slicer<to_type_seq_t<SupportType>> const slicer;
310 auto subview = slicer(this->allocation_mdspan(), odomain, this->m_domain);
311 using layout_type = typename decltype(subview)::layout_type;
312 using extents_type = typename decltype(subview)::extents_type;
313 if constexpr (
314 std::is_same_v<layout_type, Kokkos::Experimental::layout_left_padded<>>
315 || std::is_same_v<layout_type, Kokkos::Experimental::layout_right_padded<>>) {
316 Kokkos::layout_stride::mapping<extents_type> const mapping_stride(subview.mapping());
317 Kokkos::mdspan<ElementType, extents_type, Kokkos::layout_stride> const
318 a(subview.data_handle(), mapping_stride);
319 return ChunkSpan<
320 ElementType,
321 decltype(this->m_domain.restrict_with(odomain)),
322 Kokkos::layout_stride,
323 memory_space>(a, this->m_domain.restrict_with(odomain));
324 } else {
325 return ChunkSpan<
326 ElementType,
327 decltype(this->m_domain.restrict_with(odomain)),
328 layout_type,
329 memory_space>(subview, this->m_domain.restrict_with(odomain));
330 }
331 }
332
333 /** Element access using a list of DiscreteElement
334 * @param delems discrete elements
335 * @return reference to this element
336 */
337 template <concepts::discrete_element... DElems>
338 KOKKOS_FUNCTION constexpr reference operator()(DElems const&... delems) const noexcept
339 {
340 static_assert(
341 SupportType::rank() == (0 + ... + DElems::size()),
342 "Invalid number of dimensions");
343 KOKKOS_ASSERT(this->m_domain.contains(delems...))
344 return DDC_MDSPAN_ACCESS_OP(
345 this->m_allocation_mdspan,
346 detail::array(this->m_domain.distance_from_front(delems...)));
347 }
348
349 /** Element access using a list of DiscreteVector
350 * @param dvects discrete vectors
351 * @return reference to this element
352 */
353 template <concepts::discrete_vector... DVects>
354 KOKKOS_FUNCTION constexpr reference operator()(DVects const&... dvects) const noexcept
355 requires(sizeof...(DVects) != 0)
356 {
357 static_assert(
358 SupportType::rank() == (0 + ... + DVects::size()),
359 "Invalid number of dimensions");
360 return DDC_MDSPAN_ACCESS_OP(
361 this->m_allocation_mdspan,
362 detail::array(discrete_vector_type(dvects...)));
363 }
364
365 /** Access to the underlying allocation pointer
366 * @return allocation pointer
367 */
368 KOKKOS_FUNCTION constexpr ElementType* data_handle() const
369 {
370 return base_type::data_handle();
371 }
372
373 /** Provide a mdspan on the memory allocation
374 * @return allocation mdspan
375 */
376 KOKKOS_FUNCTION constexpr allocation_mdspan_type allocation_mdspan() const
377 {
378 return base_type::allocation_mdspan();
379 }
380
381 /** Provide a mdspan on the memory allocation
382 * @return allocation mdspan
383 */
384 KOKKOS_FUNCTION constexpr auto allocation_kokkos_view() const
385 {
386 auto s = this->allocation_mdspan();
387 auto kokkos_layout = detail::build_kokkos_layout(
388 s.extents(),
389 s.mapping(),
390 std::make_index_sequence<SupportType::rank()> {});
391 return Kokkos::View<
392 detail::mdspan_to_kokkos_element_t<ElementType, SupportType::rank()>,
393 decltype(kokkos_layout),
394 MemorySpace>(s.data_handle(), kokkos_layout);
395 }
396
397 KOKKOS_FUNCTION constexpr view_type span_cview() const
398 {
399 return view_type(*this);
400 }
401
402 KOKKOS_FUNCTION constexpr span_type span_view() const
403 {
404 return *this;
405 }
406};
407
408template <class DataType, class... Properties, class SupportType>
409KOKKOS_DEDUCTION_GUIDE ChunkSpan(
410 Kokkos::View<DataType, Properties...> const& view,
411 SupportType domain)
412 -> ChunkSpan<
413 detail::kokkos_to_mdspan_element_t<
414 typename Kokkos::View<DataType, Properties...>::data_type>,
415 SupportType,
416 detail::kokkos_to_mdspan_layout_t<
417 typename Kokkos::View<DataType, Properties...>::array_layout>,
418 typename Kokkos::View<DataType, Properties...>::memory_space>;
419
420template <class ElementType, class SupportType, class Allocator>
421ChunkSpan(Chunk<ElementType, SupportType, Allocator>& other) -> ChunkSpan<
422 ElementType,
423 SupportType,
424 Kokkos::layout_right,
425 typename Allocator::memory_space>;
426
427template <class ElementType, class SupportType, class Allocator>
428ChunkSpan(Chunk<ElementType, SupportType, Allocator> const& other) -> ChunkSpan<
429 ElementType const,
430 SupportType,
431 Kokkos::layout_right,
432 typename Allocator::memory_space>;
433
434template <
435 class ElementType,
436 class SupportType,
437 class LayoutStridedPolicy = Kokkos::layout_right,
438 class MemorySpace = Kokkos::HostSpace>
439using ChunkView = ChunkSpan<ElementType const, SupportType, LayoutStridedPolicy, MemorySpace>;
440
441} // namespace ddc
friend class ChunkSpan
KOKKOS_FUNCTION constexpr ChunkCommon(ElementType *ptr, SupportType const &domain)
Constructs a new ChunkCommon from scratch.
KOKKOS_FUNCTION constexpr bool is_strided() const noexcept
KOKKOS_DEFAULTED_FUNCTION ~ChunkCommon() noexcept=default
KOKKOS_FUNCTION constexpr ElementType * data_handle() const
Access to the underlying allocation pointer.
KOKKOS_DEFAULTED_FUNCTION constexpr ChunkCommon()=default
Empty ChunkCommon.
allocation_mdspan_type m_allocation_mdspan
The raw view of the data.
KOKKOS_FUNCTION constexpr SupportType domain() const noexcept
Provide access to the domain on which this chunk is defined.
static KOKKOS_FUNCTION constexpr bool is_always_strided() noexcept
KOKKOS_FUNCTION constexpr allocation_mdspan_type allocation_mdspan() const
Provide a modifiable view of the data.
KOKKOS_FUNCTION constexpr ChunkCommon(allocation_mdspan_type allocation_mdspan, SupportType const &domain) noexcept
Constructs a new ChunkCommon from scratch.
KOKKOS_DEFAULTED_FUNCTION constexpr ChunkCommon(ChunkCommon const &other)=default
Constructs a new ChunkCommon by copy, yields a new view to the same data.
static KOKKOS_FUNCTION constexpr bool is_always_unique() noexcept
KOKKOS_FUNCTION constexpr DiscreteDomain< QueryDDims... > domain() const noexcept
Provide access to the domain on which this chunk is defined.
KOKKOS_DEFAULTED_FUNCTION constexpr ChunkCommon & operator=(ChunkCommon const &other)=default
Copy-assigns a new value to this ChunkCommon, yields a new view to the same data.
KOKKOS_DEFAULTED_FUNCTION constexpr ChunkCommon(ChunkCommon &&other) noexcept=default
Constructs a new ChunkCommon by move.
KOKKOS_DEFAULTED_FUNCTION constexpr ChunkCommon & operator=(ChunkCommon &&other) noexcept=default
Move-assigns a new value to this ChunkCommon.
KOKKOS_FUNCTION constexpr size_type extent() const noexcept
KOKKOS_FUNCTION constexpr size_type stride() const
KOKKOS_FUNCTION constexpr bool is_exhaustive() const noexcept
KOKKOS_FUNCTION constexpr mapping_type mapping() const noexcept
static KOKKOS_FUNCTION constexpr int rank() noexcept
KOKKOS_FUNCTION constexpr bool is_unique() const noexcept
KOKKOS_FUNCTION constexpr accessor_type accessor() const
KOKKOS_FUNCTION constexpr SupportType::discrete_vector_type extents() const noexcept
KOKKOS_FUNCTION constexpr size_type size() const noexcept
SupportType m_domain
The mesh on which this chunk is defined.
static KOKKOS_FUNCTION constexpr int rank_dynamic() noexcept
static KOKKOS_FUNCTION constexpr size_type static_extent(std::size_t r) noexcept
static KOKKOS_FUNCTION constexpr bool is_always_exhaustive() noexcept
KOKKOS_DEFAULTED_FUNCTION constexpr ChunkSpan(ChunkSpan &&other) noexcept=default
Constructs a new ChunkSpan by move.
KOKKOS_FUNCTION constexpr view_type span_cview() const
KOKKOS_FUNCTION constexpr ChunkSpan(allocation_mdspan_type allocation_mdspan, SupportType const &domain)
Constructs a new ChunkSpan from scratch.
KOKKOS_FUNCTION constexpr auto operator[](DiscreteElement< QueryDDims... > const &slice_spec) const
Slice out some dimensions.
ChunkSpan(Chunk< OElementType, SupportType, Allocator > &&other) noexcept=delete
Forbids to construct a ChunkSpan from a rvalue of type Chunk.
KOKKOS_DEFAULTED_FUNCTION constexpr ChunkSpan(ChunkSpan const &other)=default
Constructs a new ChunkSpan by copy, yields a new view to the same data.
static KOKKOS_FUNCTION constexpr auto get_slicer_for(DiscreteDomain< ODDims... > const &c, DiscreteDomain< OODDims... > const &origin)
static KOKKOS_FUNCTION constexpr auto get_slicer_for(DiscreteVector< ODDims... > const &c)
KOKKOS_FUNCTION constexpr ChunkSpan(Chunk< OElementType, SupportType, Allocator > const &other) noexcept
Constructs a new ChunkSpan from a Chunk, yields a new view to the same data.
KOKKOS_FUNCTION constexpr reference operator()(DElems const &... delems) const noexcept
Element access using a list of DiscreteElement.
KOKKOS_DEFAULTED_FUNCTION constexpr ChunkSpan()=default
Empty ChunkSpan.
KOKKOS_FUNCTION constexpr allocation_mdspan_type allocation_mdspan() const
Provide a mdspan on the memory allocation.
KOKKOS_FUNCTION constexpr ElementType * data_handle() const
Access to the underlying allocation pointer.
KOKKOS_FUNCTION constexpr auto allocation_kokkos_view() const
Provide a mdspan on the memory allocation.
KOKKOS_FUNCTION constexpr ChunkSpan(Chunk< OElementType, SupportType, Allocator > &other) noexcept
Constructs a new ChunkSpan from a Chunk, yields a new view to the same data.
KOKKOS_DEFAULTED_FUNCTION constexpr ChunkSpan & operator=(ChunkSpan const &other)=default
Copy-assigns a new value to this ChunkSpan, yields a new view to the same data.
KOKKOS_FUNCTION constexpr ChunkSpan(ChunkSpan< OElementType, SupportType, layout_type, MemorySpace > const &other) noexcept
Constructs a new ChunkSpan by copy of a chunk, yields a new view to the same data.
KOKKOS_FUNCTION constexpr ChunkSpan(KokkosView const &view, SupportType const &domain) noexcept
Constructs a new ChunkSpan from scratch.
KOKKOS_DEFAULTED_FUNCTION ~ChunkSpan() noexcept=default
KOKKOS_FUNCTION constexpr auto operator[](DiscreteDomain< QueryDDims... > const &odomain) const
Restrict to a subdomain, only valid when SupportType is a DiscreteDomain.
KOKKOS_FUNCTION constexpr span_type span_view() const
KOKKOS_FUNCTION constexpr ChunkSpan(ElementType *const ptr, SupportType const &domain)
Constructs a new ChunkSpan from scratch.
KOKKOS_DEFAULTED_FUNCTION constexpr ChunkSpan & operator=(ChunkSpan &&other) noexcept=default
Move-assigns a new value to this ChunkSpan.
auto operator[](DiscreteElement< QueryDDims... > const &slice_spec) const
Slice out some dimensions.
Definition chunk.hpp:154
char const * label() const
Returns the label of the Chunk.
Definition chunk.hpp:249
const_allocation_mdspan_type allocation_mdspan() const
Provide a mdspan on the memory allocation.
Definition chunk.hpp:273
ElementType const * data_handle() const
Access to the underlying allocation pointer.
Definition chunk.hpp:257
auto allocation_kokkos_view()
Provide an unmanaged Kokkos::View on the memory allocation.
Definition chunk.hpp:289
auto operator[](DiscreteDomain< QueryDDims... > const &odomain)
Slice out some dimensions.
Definition chunk.hpp:176
auto allocation_kokkos_view() const
Provide an unmanaged Kokkos::View on the memory allocation.
Definition chunk.hpp:305
Chunk(SupportType const &domain, Allocator allocator=Allocator())
Construct a Chunk on a domain with uninitialized values.
Definition chunk.hpp:104
Chunk & operator=(Chunk const &other)=delete
Deleted: use deepcopy instead.
allocation_mdspan_type allocation_mdspan()
Provide a mdspan on the memory allocation.
Definition chunk.hpp:281
ElementType * data_handle()
Access to the underlying allocation pointer.
Definition chunk.hpp:265
view_type span_cview() const
Definition chunk.hpp:318
Chunk(Chunk const &other)=delete
Deleted: use deepcopy instead.
~Chunk() noexcept
Definition chunk.hpp:124
Chunk(std::string const &label, SupportType const &domain, Allocator allocator=Allocator())
Construct a labeled Chunk on a domain with uninitialized values.
Definition chunk.hpp:93
element_type & operator()(DElems const &... delems) noexcept
Element access using a list of DiscreteElement.
Definition chunk.hpp:219
Chunk()=default
Empty Chunk.
Chunk & operator=(Chunk &&other) noexcept
Move-assigns a new value to this field.
Definition chunk.hpp:138
Chunk(Chunk &&other) noexcept
Constructs a new Chunk by move.
Definition chunk.hpp:115
friend class Chunk
Definition chunk.hpp:81
span_type span_view()
Definition chunk.hpp:328
view_type span_view() const
Definition chunk.hpp:323
auto operator[](DiscreteDomain< QueryDDims... > const &odomain) const
Slice out some dimensions.
Definition chunk.hpp:168
element_type const & operator()(DElems const &... delems) const noexcept
Element access using a list of DiscreteElement.
Definition chunk.hpp:187
auto operator[](DiscreteElement< QueryDDims... > const &slice_spec)
Slice out some dimensions.
Definition chunk.hpp:161
static KOKKOS_FUNCTION constexpr discrete_vector_type extents() noexcept
KOKKOS_DEFAULTED_FUNCTION ~DiscreteDomain()=default
KOKKOS_FUNCTION constexpr DiscreteDomain(discrete_element_type const &element_begin, discrete_vector_type const &size)
Construct a DiscreteDomain starting from element_begin with size points.
KOKKOS_FUNCTION constexpr DiscreteDomain(DDoms const &...)
Construct a DiscreteDomain by copies and merge of domains.
KOKKOS_FUNCTION constexpr DiscreteDomain take_last(discrete_vector_type) const
KOKKOS_FUNCTION constexpr bool operator==(DiscreteDomain const &) const
KOKKOS_FUNCTION constexpr DiscreteDomain remove(discrete_vector_type, discrete_vector_type) const
static KOKKOS_FUNCTION constexpr std::size_t rank()
KOKKOS_FUNCTION constexpr DiscreteDomain remove_last(discrete_vector_type) const
KOKKOS_DEFAULTED_FUNCTION DiscreteDomain(DiscreteDomain const &x)=default
static KOKKOS_FUNCTION bool contains() noexcept
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteDomain()=default
KOKKOS_DEFAULTED_FUNCTION DiscreteDomain & operator=(DiscreteDomain &&x)=default
KOKKOS_FUNCTION constexpr operator bool()
static KOKKOS_FUNCTION constexpr std::size_t size()
static KOKKOS_FUNCTION constexpr bool empty() noexcept
static KOKKOS_FUNCTION bool contains(DiscreteElement<>) noexcept
static KOKKOS_FUNCTION constexpr discrete_element_type back() noexcept
static KOKKOS_FUNCTION DiscreteVector distance_from_front(DiscreteElement<>) noexcept
KOKKOS_FUNCTION constexpr DiscreteDomain remove_first(discrete_vector_type) const
static KOKKOS_FUNCTION constexpr discrete_element_type front() noexcept
KOKKOS_DEFAULTED_FUNCTION DiscreteDomain & operator=(DiscreteDomain const &x)=default
KOKKOS_FUNCTION constexpr DiscreteDomain take_first(discrete_vector_type) const
KOKKOS_FUNCTION constexpr DiscreteDomain restrict_with(DiscreteDomain< ODims... > const &) const
KOKKOS_FUNCTION constexpr DiscreteElement operator()(DiscreteVector<> const &) const noexcept
KOKKOS_DEFAULTED_FUNCTION DiscreteDomain(DiscreteDomain &&x)=default
static KOKKOS_FUNCTION DiscreteVector distance_from_front() noexcept
KOKKOS_DEFAULTED_FUNCTION DiscreteDomain(DiscreteDomain const &x)=default
KOKKOS_DEFAULTED_FUNCTION DiscreteDomain(DiscreteDomain &&x)=default
KOKKOS_FUNCTION constexpr DiscreteDomain remove_last(discrete_vector_type n) const
KOKKOS_FUNCTION bool contains(DElems const &... delems) const noexcept
KOKKOS_FUNCTION constexpr DiscreteDomain take_last(discrete_vector_type n) const
KOKKOS_FUNCTION constexpr DiscreteDomain(DDoms const &... domains)
Construct a DiscreteDomain by copies and merge of domains.
KOKKOS_FUNCTION constexpr decltype(auto) operator[](std::size_t n)
KOKKOS_FUNCTION constexpr DiscreteDomain remove(discrete_vector_type n1, discrete_vector_type n2) const
KOKKOS_FUNCTION constexpr decltype(auto) operator[](std::size_t n) const
KOKKOS_FUNCTION constexpr auto restrict_with(DiscreteDomain< ODDims... > const &odomain) const
static KOKKOS_FUNCTION constexpr std::size_t rank()
KOKKOS_FUNCTION constexpr bool empty() const noexcept
KOKKOS_FUNCTION constexpr std::size_t size() const
friend class DiscreteDomain
KOKKOS_FUNCTION constexpr discrete_vector_type extents() const noexcept
KOKKOS_FUNCTION constexpr DiscreteVector< QueryDDim > extent() const noexcept
KOKKOS_FUNCTION constexpr discrete_element_type front() const noexcept
KOKKOS_DEFAULTED_FUNCTION DiscreteDomain & operator=(DiscreteDomain &&x)=default
KOKKOS_FUNCTION constexpr DiscreteDomain remove_first(discrete_vector_type n) const
KOKKOS_FUNCTION constexpr bool operator==(DiscreteDomain< ODims... > const &other) const
KOKKOS_FUNCTION constexpr DiscreteDomain take_first(discrete_vector_type n) const
KOKKOS_DEFAULTED_FUNCTION ~DiscreteDomain()=default
KOKKOS_FUNCTION DiscreteVector< DDims... > distance_from_front(DElems const &... delems) const noexcept
KOKKOS_FUNCTION constexpr discrete_element_type back() const noexcept
KOKKOS_DEFAULTED_FUNCTION DiscreteDomain & operator=(DiscreteDomain const &x)=default
KOKKOS_FUNCTION constexpr DiscreteElement< DDims... > operator()(DiscreteVector< DDims... > const &dvect) const noexcept
KOKKOS_DEFAULTED_FUNCTION DiscreteDomain()=default
KOKKOS_FUNCTION constexpr operator bool()
KOKKOS_FUNCTION constexpr DiscreteDomain(discrete_element_type const &element_begin, discrete_vector_type const &size)
Construct a DiscreteDomain starting from element_begin with size points.
KOKKOS_FUNCTION constexpr DiscreteElement & operator+=(DiscreteVector< OTags... > const &rhs)
KOKKOS_FUNCTION constexpr value_type const & uid() const noexcept
KOKKOS_FUNCTION constexpr value_type & uid() noexcept
KOKKOS_DEFAULTED_FUNCTION ~DiscreteElement()=default
KOKKOS_FUNCTION constexpr DiscreteElement(DElems const &... delems) noexcept
KOKKOS_FUNCTION constexpr DiscreteElement & operator+=(IntegralType const &rhs)
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteElement(DiscreteElement const &)=default
KOKKOS_FUNCTION constexpr DiscreteElement operator--(int)
KOKKOS_FUNCTION constexpr DiscreteElement & operator-=(IntegralType const &rhs)
KOKKOS_FUNCTION constexpr DiscreteElement & operator-=(DiscreteVector< OTags... > const &rhs)
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteElement()=default
KOKKOS_FUNCTION constexpr DiscreteElement operator++(int)
KOKKOS_DEFAULTED_FUNCTION DiscreteElement & operator=(DiscreteElement const &other)=default
static KOKKOS_FUNCTION constexpr std::size_t size() noexcept
KOKKOS_FUNCTION constexpr DiscreteElement(std::array< IntegerType, sizeof...(Tags)> const &values) noexcept
KOKKOS_DEFAULTED_FUNCTION DiscreteElement & operator=(DiscreteElement &&other)=default
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteElement(DiscreteElement &&)=default
KOKKOS_FUNCTION constexpr DiscreteVectorElement const & get_or(DiscreteVectorElement const &default_value) const &
KOKKOS_FUNCTION constexpr DiscreteVector operator--(int)
KOKKOS_DEFAULTED_FUNCTION ~DiscreteVector()=default
KOKKOS_FUNCTION constexpr DiscreteVectorElement const & get() const noexcept
KOKKOS_FUNCTION constexpr DiscreteVector & operator+=(IntegralType const &rhs)
KOKKOS_FUNCTION constexpr DiscreteVector & operator-=(DiscreteVector< OTags... > const &rhs)
KOKKOS_FUNCTION constexpr DiscreteVector & operator-=(IntegralType const &rhs)
KOKKOS_FUNCTION constexpr DiscreteVector(DVects const &... delems) noexcept
KOKKOS_FUNCTION constexpr bool operator!=(DiscreteVector< OTags... > const &rhs) const noexcept
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteVector & operator=(DiscreteVector &&other)=default
static KOKKOS_FUNCTION constexpr std::size_t size() noexcept
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteVector()=default
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteVector(DiscreteVector const &)=default
KOKKOS_FUNCTION constexpr DiscreteVectorElement & get() noexcept
KOKKOS_FUNCTION constexpr bool operator==(DiscreteVector< OTags... > const &rhs) const noexcept
KOKKOS_FUNCTION constexpr DiscreteVector(std::array< IntegerType, sizeof...(Tags)> const &values) noexcept
KOKKOS_FUNCTION constexpr DiscreteVector & operator*=(DiscreteVector< OTags... > const &rhs)
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteVector(DiscreteVector &&)=default
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteVector & operator=(DiscreteVector const &other)=default
KOKKOS_FUNCTION constexpr DiscreteVector operator++(int)
KOKKOS_FUNCTION constexpr DiscreteVector & operator+=(DiscreteVector< OTags... > const &rhs)
The top-level namespace of DDC.
constexpr bool is_borrowed_chunk_v
KOKKOS_FUNCTION constexpr bool operator<(DiscreteElement< Tag > const &lhs, DiscreteElement< Tag > const &rhs)
KOKKOS_FUNCTION auto get_domain(ChunkType const &chunk) noexcept
Access the domain (or subdomain) of a view.
constexpr bool enable_chunk< Chunk< ElementType, SupportType, Allocator > >
Definition chunk.hpp:28
KOKKOS_FUNCTION constexpr DiscreteElement< Tag > operator+(DiscreteElement< Tag > const &lhs, IntegralType const &rhs)
KOKKOS_FUNCTION constexpr DiscreteElement< QueryDDims... > back(DiscreteDomain< DDims... > const &domain) noexcept
constexpr bool enable_borrowed_chunk
constexpr bool enable_chunk
KOKKOS_FUNCTION constexpr bool operator==(DiscreteElement< Tags... > const &lhs, DiscreteElement< OTags... > const &rhs) noexcept
constexpr bool enable_borrowed_chunk< ChunkSpan< ElementType, SupportType, LayoutStridedPolicy, MemorySpace > >
KOKKOS_FUNCTION constexpr DiscreteVector< Tags... > operator+(DiscreteVector< Tags... > const &x)
Unary operators: +, -.
KOKKOS_FUNCTION constexpr DiscreteElement< QueryTags... > select(DiscreteElement< Tags... > &&arr) noexcept
constexpr DiscreteElement< DDim > create_reference_discrete_element() noexcept
constexpr bool is_chunk_v
KOKKOS_FUNCTION constexpr DiscreteElement< QueryTags... > select(DiscreteElement< Tags... > const &arr) noexcept
KOKKOS_FUNCTION constexpr auto const & take(HeadDElem const &head, TailDElems const &... tail)
Returns a reference towards the DiscreteElement that contains the QueryTag.
KOKKOS_FUNCTION constexpr DiscreteVector< Tag > operator-(IntegralType const &lhs, DiscreteVector< Tag > const &rhs)
KOKKOS_FUNCTION constexpr auto remove_dims_of(DiscreteDomain< DDimsA... > const &DDom_a, DiscreteDomain< DDimsB... > const &) noexcept
KOKKOS_FUNCTION constexpr bool operator<(DiscreteVector< Tag > const &lhs, IntegralType const &rhs)
KOKKOS_FUNCTION constexpr DiscreteVectorElement const & get_or(DiscreteVector< Tags... > const &tuple, DiscreteVectorElement const &default_value) noexcept
KOKKOS_FUNCTION constexpr auto operator-(DiscreteVector< Tags... > const &lhs, DiscreteVector< OTags... > const &rhs)
KOKKOS_FUNCTION constexpr auto remove_dims_of(DiscreteDomain< DDimsA... > const &DDom_a) noexcept
Remove the dimensions DDimsB from DDom_a.
KOKKOS_FUNCTION constexpr DiscreteVector< Tags... > operator-(DiscreteElement< Tags... > const &lhs, DiscreteElement< OTags... > const &rhs)
binary operator: -
KOKKOS_FUNCTION constexpr DiscreteElement< QueryDDims... > front(DiscreteDomain< DDims... > const &domain) noexcept
KOKKOS_FUNCTION constexpr DiscreteVectorElement & get(DiscreteVector< Tags... > &tuple) noexcept
KOKKOS_FUNCTION constexpr DiscreteElement< QueryTag > select_or(DiscreteElement< Tags... > const &arr, DiscreteElement< QueryTag > const &default_value) noexcept
constexpr bool is_writable_chunk_v
KOKKOS_FUNCTION constexpr DiscreteVector< Tag > operator+(IntegralType const &lhs, DiscreteVector< Tag > const &rhs)
constexpr bool is_discrete_vector_v
KOKKOS_FUNCTION constexpr DiscreteElementType const & uid(DiscreteElement< Tag > const &tuple) noexcept
KOKKOS_FUNCTION constexpr DiscreteElement< Tags... > operator+(DiscreteElement< Tags... > const &lhs, DiscreteVector< OTags... > const &rhs)
right external binary operators: +, -
ChunkSpan(Chunk< ElementType, SupportType, Allocator > const &other) -> ChunkSpan< ElementType const, SupportType, Kokkos::layout_right, typename Allocator::memory_space >
KOKKOS_FUNCTION constexpr DiscreteVectorElement const & get(DiscreteVector< Tags... > const &tuple) noexcept
KOKKOS_FUNCTION constexpr DiscreteVector< Tags... > operator-(DiscreteVector< Tags... > const &x)
constexpr bool is_discrete_element_v
KOKKOS_FUNCTION constexpr DiscreteVector< QueryTags... > select(DiscreteVector< Tags... > const &arr) noexcept
KOKKOS_FUNCTION constexpr DiscreteVector< QueryDDims... > extents(DiscreteDomain< DDims... > const &domain) noexcept
Chunk(SupportType const &, Allocator) -> Chunk< typename Allocator::value_type, SupportType, Allocator >
KOKKOS_FUNCTION constexpr bool operator>=(DiscreteElement< Tag > const &lhs, DiscreteElement< Tag > const &rhs)
KOKKOS_FUNCTION constexpr auto operator+(DiscreteVector< Tags... > const &lhs, DiscreteVector< OTags... > const &rhs)
Internal binary operators: +, -.
KOKKOS_FUNCTION constexpr auto replace_dim_of(DiscreteDomain< DDimsA... > const &DDom_a, DiscreteDomain< DDimsB... > const &DDom_b) noexcept
ChunkSpan(Chunk< ElementType, SupportType, Allocator > &other) -> ChunkSpan< ElementType, SupportType, Kokkos::layout_right, typename Allocator::memory_space >
constexpr bool enable_chunk< ChunkSpan< ElementType, SupportType, LayoutStridedPolicy, MemorySpace > >
KOKKOS_FUNCTION constexpr bool operator<=(DiscreteElement< Tag > const &lhs, DiscreteElement< Tag > const &rhs)
KOKKOS_FUNCTION constexpr bool operator<(DiscreteVector< Tag > const &lhs, DiscreteVector< Tag > const &rhs)
KOKKOS_FUNCTION constexpr DiscreteElementType & uid(DiscreteElement< Tags... > &tuple) noexcept
Chunk(std::string const &, SupportType const &, Allocator) -> Chunk< typename Allocator::value_type, SupportType, Allocator >
KOKKOS_FUNCTION constexpr DiscreteVector< QueryTag > select_or(DiscreteVector< Tags... > const &arr, DiscreteVector< QueryTag > const &default_value) noexcept
KOKKOS_FUNCTION constexpr bool operator>(DiscreteElement< Tag > const &lhs, DiscreteElement< Tag > const &rhs)
KOKKOS_FUNCTION constexpr DiscreteElementType & uid(DiscreteElement< Tag > &tuple) noexcept
constexpr bool is_discrete_domain_v
KOKKOS_FUNCTION constexpr DiscreteVector< QueryTags... > select(DiscreteVector< Tags... > &&arr) noexcept
KOKKOS_FUNCTION constexpr DiscreteElement< Tag > operator-(DiscreteElement< Tag > const &lhs, IntegralType const &rhs)
KOKKOS_FUNCTION constexpr DiscreteElement< Tags... > operator-(DiscreteElement< Tags... > const &lhs, DiscreteVector< OTags... > const &rhs)
KOKKOS_FUNCTION constexpr DiscreteElementType const & uid(DiscreteElement< Tags... > const &tuple) noexcept
KOKKOS_FUNCTION constexpr auto operator*(IntegralType const &lhs, DiscreteVector< Tags... > const &rhs)
external left binary operator: *
KOKKOS_FUNCTION constexpr DiscreteDomain< QueryDDims... > select(DiscreteDomain< DDims... > const &domain)
KOKKOS_FUNCTION constexpr DiscreteVector< Tag > operator-(DiscreteVector< Tag > const &lhs, IntegralType const &rhs)
KOKKOS_DEDUCTION_GUIDE ChunkSpan(Kokkos::View< DataType, Properties... > const &view, SupportType domain) -> ChunkSpan< detail::kokkos_to_mdspan_element_t< typename Kokkos::View< DataType, Properties... >::data_type >, SupportType, detail::kokkos_to_mdspan_layout_t< typename Kokkos::View< DataType, Properties... >::array_layout >, typename Kokkos::View< DataType, Properties... >::memory_space >
KOKKOS_FUNCTION constexpr DiscreteVector< Tag > operator+(DiscreteVector< Tag > const &lhs, IntegralType const &rhs)
KOKKOS_FUNCTION constexpr DiscreteDomainIterator operator--(int)
friend KOKKOS_FUNCTION constexpr bool operator<=(DiscreteDomainIterator const &xx, DiscreteDomainIterator const &yy)
KOKKOS_FUNCTION constexpr DiscreteElement< DDim > operator*() const noexcept
friend KOKKOS_FUNCTION constexpr bool operator>=(DiscreteDomainIterator const &xx, DiscreteDomainIterator const &yy)
KOKKOS_DEFAULTED_FUNCTION DiscreteDomainIterator()=default
KOKKOS_FUNCTION constexpr DiscreteElement< DDim > operator[](difference_type n) const
KOKKOS_FUNCTION constexpr DiscreteDomainIterator & operator--()
KOKKOS_FUNCTION constexpr DiscreteDomainIterator operator++(int)
friend KOKKOS_FUNCTION constexpr DiscreteDomainIterator operator-(DiscreteDomainIterator i, difference_type n)
friend KOKKOS_FUNCTION constexpr DiscreteDomainIterator operator+(DiscreteDomainIterator i, difference_type n)
friend KOKKOS_FUNCTION constexpr bool operator>(DiscreteDomainIterator const &xx, DiscreteDomainIterator const &yy)
friend KOKKOS_FUNCTION constexpr bool operator!=(DiscreteDomainIterator const &xx, DiscreteDomainIterator const &yy)
friend KOKKOS_FUNCTION constexpr bool operator<(DiscreteDomainIterator const &xx, DiscreteDomainIterator const &yy)
KOKKOS_FUNCTION constexpr DiscreteDomainIterator & operator+=(difference_type n)
KOKKOS_FUNCTION constexpr DiscreteDomainIterator & operator++()
friend KOKKOS_FUNCTION constexpr DiscreteDomainIterator operator+(difference_type n, DiscreteDomainIterator i)
friend KOKKOS_FUNCTION constexpr bool operator==(DiscreteDomainIterator const &xx, DiscreteDomainIterator const &yy)
KOKKOS_FUNCTION constexpr DiscreteDomainIterator(DiscreteElement< DDim > value)
KOKKOS_FUNCTION constexpr DiscreteDomainIterator & operator-=(difference_type n)
friend KOKKOS_FUNCTION constexpr difference_type operator-(DiscreteDomainIterator const &xx, DiscreteDomainIterator const &yy)