16#include <Kokkos_Core.hpp>
18#include "chunk_span.hpp"
19#include "discrete_vector.hpp"
21#if defined(KOKKOS_COMPILER_GNU) || defined(KOKKOS_COMPILER_CLANG)
29 static constexpr int const s_threshold = 10;
32 static constexpr int const s_edgeitems = 3;
34 std::stringstream m_ss;
36 static std::ostream& alignment(std::ostream& os,
int level)
38 for (
int i = 0; i <= level; ++i) {
45 std::size_t get_element_width(T
const& elem)
53 void display_aligned_element(std::ostream& os, T
const& elem, std::size_t largest_element)
55 std::size_t
const elem_width = get_element_width(elem);
57 for (std::size_t i = 0; i < largest_element - elem_width; ++i) {
63 template <
class ElementType,
class Extents,
class Layout,
class Accessor>
64 std::ostream& base_case_display(
66 Kokkos::mdspan<ElementType, Extents, Layout, Accessor>
const& s,
67 std::size_t largest_element,
68 std::size_t beginning,
72 for (std::size_t i0 = beginning; i0 < end; ++i0) {
73 display_aligned_element(os, s[i0], largest_element);
74 if (i0 < extent - 1) {
81 template <
class ElementType,
class Extents,
class Layout,
class Accessor, std::size_t... Is>
82 std::ostream& recursive_display(
84 Kokkos::mdspan<ElementType, Extents, Layout, Accessor>
const& s,
86 std::size_t largest_element,
87 std::size_t beginning,
89 std::index_sequence<Is...>)
91 for (std::size_t i0 = beginning; i0 < end; ++i0) {
94 Kokkos::submdspan(s, i0, ((
void)Is, Kokkos::full_extent)...),
97 std::make_index_sequence<
sizeof...(Is)>());
99 for (
int ndims = 0; ndims <
sizeof...(Is); ++ndims) {
102 alignment(os, level);
111 template <
class ElementType,
class Extents,
class Layout,
class Accessor>
112 std::ostream& print_impl(
114 Kokkos::mdspan<ElementType, Extents, Layout, Accessor>
const& s,
117 std::index_sequence<>)
119 return os << *s.data_handle();
130 std::ostream& print_impl(
132 Kokkos::mdspan<ElementType, Extents, Layout, Accessor>
const& s,
134 std::size_t largest_element,
135 std::index_sequence<I0, Is...>)
137 auto extent = s.extent(I0);
138 if constexpr (
sizeof...(Is) > 0) {
140 if (extent < s_threshold) {
148 std::make_index_sequence<
sizeof...(Is)>());
157 std::make_index_sequence<
sizeof...(Is)>());
158 for (
int ndims = 0; ndims <
sizeof...(Is); ++ndims) {
161 alignment(os, level);
163 for (
int ndims = 0; ndims <
sizeof...(Is); ++ndims) {
166 alignment(os, level);
172 extent - s_edgeitems,
174 std::make_index_sequence<
sizeof...(Is)>());
179 if (extent < s_threshold) {
180 base_case_display(os, s, largest_element, 0, extent, extent);
182 base_case_display(os, s, largest_element, 0, s_edgeitems, extent);
184 base_case_display(os, s, largest_element, extent - s_edgeitems, extent, extent);
193 template <
class ElementType,
class Extents,
class Layout,
class Accessor>
194 std::size_t find_largest_displayed_element(
195 Kokkos::mdspan<ElementType, Extents, Layout, Accessor>
const&,
196 std::index_sequence<>)
210 std::size_t find_largest_displayed_element(
211 Kokkos::mdspan<ElementType, Extents, Layout, Accessor>
const& s,
212 std::index_sequence<I0, Is...>)
215 auto extent = s.extent(I0);
216 if constexpr (
sizeof...(Is) > 0) {
217 if (extent < s_threshold) {
218 for (std::size_t i0 = 0; i0 < extent; ++i0) {
221 find_largest_displayed_element(
222 Kokkos::submdspan(s, i0, ((
void)Is, Kokkos::full_extent)...),
223 std::make_index_sequence<
sizeof...(Is)>()));
226 for (std::size_t i0 = 0; i0 < s_edgeitems; ++i0) {
229 find_largest_displayed_element(
230 Kokkos::submdspan(s, i0, ((
void)Is, Kokkos::full_extent)...),
231 std::make_index_sequence<
sizeof...(Is)>()));
233 for (std::size_t i0 = extent - s_edgeitems; i0 < extent; ++i0) {
236 find_largest_displayed_element(
237 Kokkos::submdspan(s, i0, ((
void)Is, Kokkos::full_extent)...),
238 std::make_index_sequence<
sizeof...(Is)>()));
242 if (extent < s_threshold) {
243 for (std::size_t i0 = 0; i0 < extent; ++i0) {
244 ret = std::max(ret, get_element_width(s[i0]));
247 for (std::size_t i0 = 0; i0 < s_edgeitems; ++i0) {
248 ret = std::max(ret, get_element_width(s[i0]));
250 for (std::size_t i0 = extent - s_edgeitems; i0 < extent; ++i0) {
251 ret = std::max(ret, get_element_width(s[i0]));
259 explicit ChunkPrinter(std::ostream
const& os)
265inline void print_demangled_type_name(std::ostream& os,
char const*
const mangled_name)
267#if defined(KOKKOS_COMPILER_GNU) || defined(KOKKOS_COMPILER_CLANG)
270 std::unique_ptr<
char,
decltype(std::free)*>
const
271 demangled_name(abi::__cxa_demangle(mangled_name,
nullptr,
nullptr, &status), std::free);
273 os <<
"Error demangling dimension name: " << status;
277 os << demangled_name.get();
283inline void print_single_dim_name(
285 std::type_info
const& dim,
286 DiscreteVectorElement
const size)
288 print_demangled_type_name(os, dim.name());
289 os <<
'(' << size <<
')';
292inline void print_dim_name(std::ostream& os,
DiscreteVector<>
const&)
297template <
class Dim0,
class... Dims>
298void print_dim_name(std::ostream& os,
DiscreteVector<Dim0, Dims...>
const& dd)
300 print_single_dim_name(os,
typeid(Dim0), get<Dim0>(dd));
301 ((os <<
"×", print_single_dim_name(os,
typeid(Dims), get<Dims>(dd))), ...);
306template <
class ElementType,
class SupportType,
class LayoutStridedPolicy,
class MemorySpace>
309 ChunkSpan<ElementType, SupportType, LayoutStridedPolicy, MemorySpace>
const& chunk_span)
311 auto h_chunk_span = create_mirror_view_and_copy(Kokkos::HostSpace(), chunk_span);
313 using chunkspan_type = std::remove_cv_t<std::remove_reference_t<
decltype(h_chunk_span)>>;
314 using mdspan_type =
typename chunkspan_type::allocation_mdspan_type;
315 using extents =
typename mdspan_type::extents_type;
317 mdspan_type
const allocated_mdspan = h_chunk_span.allocation_mdspan();
319 ddc::detail::ChunkPrinter printer(os);
320 std::size_t
const largest_element = printer.find_largest_displayed_element(
322 std::make_index_sequence<extents::rank()>());
329 std::make_index_sequence<extents::rank()>());
334template <
class ElementType,
class SupportType,
class LayoutStridedPolicy,
class MemorySpace>
337 ChunkSpan<ElementType, SupportType, LayoutStridedPolicy, MemorySpace>
const& chunk_span)
339 ddc::detail::print_dim_name(os, chunk_span.extents());
341 ddc::detail::print_demangled_type_name(os,
typeid(chunk_span).name());
347template <
class ElementType,
class SupportType,
class LayoutStridedPolicy,
class MemorySpace>
350 ChunkSpan<ElementType, SupportType, LayoutStridedPolicy, MemorySpace>
const& chunk_span)
352 print_type_info(os, chunk_span);
353 print_content(os, chunk_span);
359template <
class ElementType,
class SupportType,
class LayoutStridedPolicy,
class MemorySpace>
360std::ostream& operator<<(
362 ChunkSpan<ElementType, SupportType, LayoutStridedPolicy, MemorySpace>
const& chunk_span)
364 return print(os, chunk_span);
KOKKOS_FUNCTION constexpr bool operator!=(DiscreteVector< OTags... > const &rhs) const noexcept
The top-level namespace of DDC.
std::ostream & print_content(std::ostream &os, ChunkSpan< ElementType, SupportType, LayoutStridedPolicy, MemorySpace > const &chunk_span)
std::ostream & print(std::ostream &os, ChunkSpan< ElementType, SupportType, LayoutStridedPolicy, MemorySpace > const &chunk_span)
std::ostream & print_type_info(std::ostream &os, ChunkSpan< ElementType, SupportType, LayoutStridedPolicy, MemorySpace > const &chunk_span)