10#include <similie/tensor/tensor_impl.hpp>
17template <tensor::TensorIndex HeadTensorIndex, tensor::TensorNatIndex... TailTensorIndex>
21 ddc::DiscreteDomain<HeadTensorIndex, TailTensorIndex...> m_domain;
22 std::vector<std::size_t> m_coalesc_idx;
23 std::array<std::vector<std::size_t>,
sizeof...(TailTensorIndex)> m_idx;
24 std::vector<double> m_values;
36 ddc::DiscreteDomain<HeadTensorIndex, TailTensorIndex...>
domain,
38 std::array<std::vector<std::size_t>,
sizeof...(TailTensorIndex)>
idx,
39 std::vector<double>
values)
47 ddc::DiscreteDomain<HeadTensorIndex, TailTensorIndex...>
domain()
57 std::array<std::vector<std::size_t>,
sizeof...(TailTensorIndex)>
idx()
71 ddc::DiscreteDomain<TailTensorIndex...>,
73 Kokkos::DefaultHostExecutionSpace::memory_space> dense)
75 m_coalesc_idx.push_back(m_coalesc_idx.back());
76 ddc::for_each(dense.domain(), [&](ddc::DiscreteElement<TailTensorIndex...> elem) {
77 if (dense(elem) != 0) {
78 m_coalesc_idx.back() += 1;
79 (m_idx[ddc::type_seq_rank_v<
81 ddc::detail::TypeSeq<TailTensorIndex...>>]
82 .push_back(elem.template uid<TailTensorIndex>()),
84 m_values.push_back(dense(elem));
91 ddc::DiscreteElement<HeadTensorIndex>
id)
const
93 const std::size_t id_begin = m_coalesc_idx[
id.uid()];
94 const std::size_t id_end = m_coalesc_idx[
id.uid() + 1];
95 std::vector<std::size_t> new_coalesc_idx {0, id_end - id_begin};
96 std::array<std::vector<std::size_t>,
sizeof...(TailTensorIndex)> new_idx;
97 ((new_idx[ddc::type_seq_rank_v<TailTensorIndex, ddc::detail::TypeSeq<TailTensorIndex...>>]
98 = std::vector<std::size_t>(
99 m_idx[ddc::type_seq_rank_v<
101 ddc::detail::TypeSeq<TailTensorIndex...>>]
104 m_idx[ddc::type_seq_rank_v<
106 ddc::detail::TypeSeq<TailTensorIndex...>>]
108 + id_begin + id_end)),
111 new_values(m_values.begin() + id_begin, m_values.begin() + id_begin + id_end);
113 return CsrDynamic<HeadTensorIndex, TailTensorIndex...>(
114 ddc::DiscreteDomain<HeadTensorIndex, TailTensorIndex...>(m_domain),
123 .write(
reinterpret_cast<const char*
>(coalesc_idx().data()),
124 coalesc_idx().size() *
sizeof(std::size_t));
126 for (std::size_t i = 0; i <
sizeof...(TailTensorIndex); ++i) {
128 .write(
reinterpret_cast<const char*
>(idx()[i].data()),
129 idx()[i].size() *
sizeof(std::size_t));
133 .write(
reinterpret_cast<const char*
>(values().data()),
134 m_values.size() *
sizeof(
double));
143 ddc::DiscreteDomain<HeadId, TailId...>,
144 Kokkos::layout_right,
145 Kokkos::DefaultHostExecutionSpace::memory_space>
149 ddc::DiscreteDomain<HeadId, TailId...>,
150 Kokkos::layout_right,
151 Kokkos::DefaultHostExecutionSpace::memory_space> dense,
154 ddc::parallel_fill(dense, 0.);
155 for (std::size_t i = 0; i < csr.
coalesc_idx().size() - 1; ++i) {
157 std::size_t
const j_end = csr.
coalesc_idx()[i + 1];
158 Kokkos::parallel_for(
160 Kokkos::RangePolicy<Kokkos::DefaultHostExecutionSpace>(j_begin, j_end),
162 dense(ddc::DiscreteElement<HeadId>(i),
163 ddc::DiscreteElement<TailId...>(csr.
idx()[ddc::type_seq_rank_v<
165 ddc::detail::TypeSeq<TailId...>>][j]...))
172template <
class... TensorIndex>
175 os <<
"----------\n";
176 for (std::size_t i = 0; i < csr.
coalesc_idx().size(); ++i) {
180 for (std::size_t i = 0; i < csr.
idx()[0].size(); ++i) {
181 for (std::size_t j = 0; j <
sizeof...(TensorIndex) - 1; ++j) {
182 os << csr.
idx()[j][i] <<
" ";
CsrDynamic(ddc::DiscreteDomain< HeadTensorIndex, TailTensorIndex... > domain)
CsrDynamic(ddc::DiscreteDomain< HeadTensorIndex, TailTensorIndex... > domain, std::vector< std::size_t > coalesc_idx, std::array< std::vector< std::size_t >, sizeof...(TailTensorIndex)> idx, std::vector< double > values)
std::array< std::vector< std::size_t >, sizeof...(TailTensorIndex)> idx() const
void write(std::ofstream &file)
std::vector< double > values() const
CsrDynamic< HeadTensorIndex, TailTensorIndex... > get(ddc::DiscreteElement< HeadTensorIndex > id) const
ddc::DiscreteDomain< HeadTensorIndex, TailTensorIndex... > domain()
void push_back(sil::tensor::Tensor< double, ddc::DiscreteDomain< TailTensorIndex... >, Kokkos::layout_right, Kokkos::DefaultHostExecutionSpace::memory_space > dense)
std::vector< std::size_t > coalesc_idx() const
sil::tensor::Tensor< double, ddc::DiscreteDomain< HeadId, TailId... >, Kokkos::layout_right, Kokkos::DefaultHostExecutionSpace::memory_space > csr2dense(sil::tensor::Tensor< double, ddc::DiscreteDomain< HeadId, TailId... >, Kokkos::layout_right, Kokkos::DefaultHostExecutionSpace::memory_space > dense, CsrDynamic< HeadId, TailId... > csr)
std::ostream & operator<<(std::ostream &os, Csr< N, TensorIndex... > const &csr)
Tensor(ddc::Chunk< ElementType, SupportType, Allocator >) -> Tensor< ElementType, SupportType, Kokkos::layout_right, typename Allocator::memory_space >
The top-level namespace of SimiLie.