Ginkgo  Generated from pipelines/2406079695 branch based on develop. Ginkgo version 1.12.0
A numerical linear algebra library targeting many-core architectures
ell.hpp
1 // SPDX-FileCopyrightText: 2017 - 2026 The Ginkgo authors
2 //
3 // SPDX-License-Identifier: BSD-3-Clause
4 
5 #ifndef GKO_PUBLIC_CORE_MATRIX_ELL_HPP_
6 #define GKO_PUBLIC_CORE_MATRIX_ELL_HPP_
7 
8 
9 #include <ginkgo/core/base/array.hpp>
10 #include <ginkgo/core/base/lin_op.hpp>
11 #include <ginkgo/core/matrix/device_views.hpp>
12 
13 
14 namespace gko {
15 namespace matrix {
16 
17 
18 template <typename ValueType>
19 class Dense;
20 
21 template <typename ValueType, typename IndexType>
22 class Coo;
23 
24 template <typename ValueType, typename IndexType>
25 class Csr;
26 
27 template <typename ValueType, typename IndexType>
28 class Hybrid;
29 
30 
52 template <typename ValueType = default_precision, typename IndexType = int32>
53 class Ell : public EnableLinOp<Ell<ValueType, IndexType>>,
54  public ConvertibleTo<Ell<next_precision<ValueType>, IndexType>>,
55 #if GINKGO_ENABLE_HALF || GINKGO_ENABLE_BFLOAT16
56  public ConvertibleTo<Ell<next_precision<ValueType, 2>, IndexType>>,
57 #endif
58 #if GINKGO_ENABLE_HALF && GINKGO_ENABLE_BFLOAT16
59  public ConvertibleTo<Ell<next_precision<ValueType, 3>, IndexType>>,
60 #endif
61  public ConvertibleTo<Dense<ValueType>>,
62  public ConvertibleTo<Csr<ValueType, IndexType>>,
63  public DiagonalExtractable<ValueType>,
64  public ReadableFromMatrixData<ValueType, IndexType>,
65  public WritableToMatrixData<ValueType, IndexType>,
66  public EnableAbsoluteComputation<
67  remove_complex<Ell<ValueType, IndexType>>> {
68  friend class EnablePolymorphicObject<Ell, LinOp>;
69  friend class Dense<ValueType>;
70  friend class Coo<ValueType, IndexType>;
71  friend class Csr<ValueType, IndexType>;
72  friend class Ell<to_complex<ValueType>, IndexType>;
73  friend class Ell<previous_precision<ValueType>, IndexType>;
74  friend class Hybrid<ValueType, IndexType>;
75  GKO_ASSERT_SUPPORTED_VALUE_AND_INDEX_TYPE;
76 
77 public:
80  using ConvertibleTo<Ell<next_precision<ValueType>, IndexType>>::convert_to;
81  using ConvertibleTo<Ell<next_precision<ValueType>, IndexType>>::move_to;
82  using ConvertibleTo<Dense<ValueType>>::convert_to;
83  using ConvertibleTo<Dense<ValueType>>::move_to;
84  using ConvertibleTo<Csr<ValueType, IndexType>>::convert_to;
85  using ConvertibleTo<Csr<ValueType, IndexType>>::move_to;
87 
88  using value_type = ValueType;
89  using index_type = IndexType;
90  using mat_data = matrix_data<ValueType, IndexType>;
91  using device_mat_data = device_matrix_data<ValueType, IndexType>;
92  using absolute_type = remove_complex<Ell>;
93  using device_view = matrix::view::ell<value_type, index_type>;
94  using const_device_view =
95  matrix::view::ell<const value_type, const index_type>;
96 
97  void convert_to(
98  Ell<next_precision<ValueType>, IndexType>* result) const override;
99 
100  void move_to(Ell<next_precision<ValueType>, IndexType>* result) override;
101 
102 #if GINKGO_ENABLE_HALF || GINKGO_ENABLE_BFLOAT16
103  friend class Ell<previous_precision<ValueType, 2>, IndexType>;
104  using ConvertibleTo<
105  Ell<next_precision<ValueType, 2>, IndexType>>::convert_to;
106  using ConvertibleTo<Ell<next_precision<ValueType, 2>, IndexType>>::move_to;
107 
108  void convert_to(
109  Ell<next_precision<ValueType, 2>, IndexType>* result) const override;
110 
111  void move_to(Ell<next_precision<ValueType, 2>, IndexType>* result) override;
112 #endif
113 
114 #if GINKGO_ENABLE_HALF && GINKGO_ENABLE_BFLOAT16
115  friend class Ell<previous_precision<ValueType, 3>, IndexType>;
116  using ConvertibleTo<
117  Ell<next_precision<ValueType, 3>, IndexType>>::convert_to;
118  using ConvertibleTo<Ell<next_precision<ValueType, 3>, IndexType>>::move_to;
119 
120  void convert_to(
121  Ell<next_precision<ValueType, 3>, IndexType>* result) const override;
122 
123  void move_to(Ell<next_precision<ValueType, 3>, IndexType>* result) override;
124 #endif
125 
126  void convert_to(Dense<ValueType>* other) const override;
127 
128  void move_to(Dense<ValueType>* other) override;
129 
130  void convert_to(Csr<ValueType, IndexType>* other) const override;
131 
132  void move_to(Csr<ValueType, IndexType>* other) override;
133 
134  void read(const mat_data& data) override;
135 
136  void read(const device_mat_data& data) override;
137 
138  void read(device_mat_data&& data) override;
139 
140  void write(mat_data& data) const override;
141 
142  std::unique_ptr<Diagonal<ValueType>> extract_diagonal() const override;
143 
144  std::unique_ptr<absolute_type> compute_absolute() const override;
145 
146  void compute_absolute_inplace() override;
147 
153  value_type* get_values() noexcept { return values_.get_data(); }
154 
162  const value_type* get_const_values() const noexcept
163  {
164  return values_.get_const_data();
165  }
166 
172  index_type* get_col_idxs() noexcept { return col_idxs_.get_data(); }
173 
181  const index_type* get_const_col_idxs() const noexcept
182  {
183  return col_idxs_.get_const_data();
184  }
185 
192  {
193  return num_stored_elements_per_row_;
194  }
195 
201  size_type get_stride() const noexcept { return stride_; }
202 
209  {
210  return values_.get_size();
211  }
212 
223  value_type& val_at(size_type row, size_type idx) noexcept
224  {
225  return values_.get_data()[this->linearize_index(row, idx)];
226  }
227 
231  value_type val_at(size_type row, size_type idx) const noexcept
232  {
233  return values_.get_const_data()[this->linearize_index(row, idx)];
234  }
235 
246  index_type& col_at(size_type row, size_type idx) noexcept
247  {
248  return this->get_col_idxs()[this->linearize_index(row, idx)];
249  }
250 
254  index_type col_at(size_type row, size_type idx) const noexcept
255  {
256  return this->get_const_col_idxs()[this->linearize_index(row, idx)];
257  }
258 
260  device_view get_device_view();
261 
263  const_device_view get_const_device_view() const;
264 
276  static std::unique_ptr<Ell> create(
277  std::shared_ptr<const Executor> exec, const dim<2>& size = {},
278  size_type num_stored_elements_per_row = 0, size_type stride = 0);
279 
299  static std::unique_ptr<Ell> create(std::shared_ptr<const Executor> exec,
300  const dim<2>& size,
301  array<value_type> values,
302  array<index_type> col_idxs,
303  size_type num_stored_elements_per_row,
304  size_type stride);
305 
311  template <typename InputValueType, typename InputColumnIndexType>
312  GKO_DEPRECATED(
313  "explicitly construct the gko::array argument instead of passing "
314  "initializer lists")
315  static std::unique_ptr<Ell> create(
316  std::shared_ptr<const Executor> exec, const dim<2>& size,
317  std::initializer_list<InputValueType> values,
318  std::initializer_list<InputColumnIndexType> col_idxs,
319  size_type num_stored_elements_per_row, size_type stride)
320  {
321  return create(exec, size, array<value_type>{exec, std::move(values)},
322  array<index_type>{exec, std::move(col_idxs)},
323  num_stored_elements_per_row, stride);
324  }
325 
339  static std::unique_ptr<const Ell> create_const(
340  std::shared_ptr<const Executor> exec, const dim<2>& size,
341  gko::detail::const_array_view<ValueType>&& values,
342  gko::detail::const_array_view<IndexType>&& col_idxs,
343  size_type num_stored_elements_per_row, size_type stride);
344 
350  Ell& operator=(const Ell&);
351 
357  Ell& operator=(Ell&&);
358 
363  Ell(const Ell&);
364 
369  Ell(Ell&&);
370 
371 protected:
372  Ell(std::shared_ptr<const Executor> exec, const dim<2>& size = {},
373  size_type num_stored_elements_per_row = 0, size_type stride = 0);
374 
375  Ell(std::shared_ptr<const Executor> exec, const dim<2>& size,
376  array<value_type> values, array<index_type> col_idxs,
377  size_type num_stored_elements_per_row, size_type stride);
378 
388  void resize(dim<2> new_size, size_type max_row_nnz);
389 
390  void apply_impl(const LinOp* b, LinOp* x) const override;
391 
392  void apply_impl(const LinOp* alpha, const LinOp* b, const LinOp* beta,
393  LinOp* x) const override;
394 
395  size_type linearize_index(size_type row, size_type col) const noexcept
396  {
397  return row + stride_ * col;
398  }
399 
400 private:
401  size_type num_stored_elements_per_row_;
402  size_type stride_;
403  array<value_type> values_;
404  array<index_type> col_idxs_;
405 };
406 
407 
408 } // namespace matrix
409 } // namespace gko
410 
411 
412 #endif // GKO_PUBLIC_CORE_MATRIX_ELL_HPP_
gko::matrix::Ell::Ell
Ell(const Ell &)
Copy-constructs an Ell matrix.
gko::EnablePolymorphicAssignment< ConcreteLinOp >::move_to
void move_to(result_type *result) override
Definition: polymorphic_object.hpp:751
gko::matrix::Ell::get_stride
size_type get_stride() const noexcept
Returns the stride of the matrix.
Definition: ell.hpp:201
gko::EnablePolymorphicAssignment< ConcreteLinOp >::convert_to
void convert_to(result_type *result) const override
Definition: polymorphic_object.hpp:749
gko::LinOp
Definition: lin_op.hpp:117
gko::ReadableFromMatrixData::read
virtual void read(const matrix_data< ValueType, IndexType > &data)=0
Reads a matrix from a matrix_data structure.
gko::matrix::Ell::compute_absolute
std::unique_ptr< absolute_type > compute_absolute() const override
Gets the AbsoluteLinOp.
gko::matrix::Ell::get_values
value_type * get_values() noexcept
Returns the values of the matrix.
Definition: ell.hpp:153
gko::matrix::Ell::val_at
value_type & val_at(size_type row, size_type idx) noexcept
Returns the idx-th non-zero element of the row-th row .
Definition: ell.hpp:223
gko::matrix::Ell::extract_diagonal
std::unique_ptr< Diagonal< ValueType > > extract_diagonal() const override
Extracts the diagonal entries of the matrix into a vector.
gko::matrix::Ell::operator=
Ell & operator=(const Ell &)
Copy-assigns an Ell matrix.
gko::size_type
std::size_t size_type
Integral type used for allocation quantities.
Definition: types.hpp:90
gko::matrix::Ell::get_const_values
const value_type * get_const_values() const noexcept
Returns the values of the matrix.
Definition: ell.hpp:162
gko::matrix::Ell::create_const
static std::unique_ptr< const Ell > create_const(std::shared_ptr< const Executor > exec, const dim< 2 > &size, gko::detail::const_array_view< ValueType > &&values, gko::detail::const_array_view< IndexType > &&col_idxs, size_type num_stored_elements_per_row, size_type stride)
Creates a constant (immutable) Ell matrix from a set of constant arrays.
gko::matrix::Ell::get_col_idxs
index_type * get_col_idxs() noexcept
Returns the column indexes of the matrix.
Definition: ell.hpp:172
gko::matrix::Ell::get_const_col_idxs
const index_type * get_const_col_idxs() const noexcept
Returns the column indexes of the matrix.
Definition: ell.hpp:181
gko::matrix::Ell::create
static std::unique_ptr< Ell > create(std::shared_ptr< const Executor > exec, const dim< 2 > &size={}, size_type num_stored_elements_per_row=0, size_type stride=0)
Creates an uninitialized Ell matrix of the specified size.
gko
The Ginkgo namespace.
Definition: abstract_factory.hpp:20
gko::matrix::Ell::val_at
value_type val_at(size_type row, size_type idx) const noexcept
Returns the idx-th non-zero element of the row-th row .
Definition: ell.hpp:231
gko::array< value_type >
gko::matrix::Ell::get_num_stored_elements
size_type get_num_stored_elements() const noexcept
Returns the number of elements explicitly stored in the matrix.
Definition: ell.hpp:208
gko::dim< 2 >
gko::matrix::Ell::read
void read(const mat_data &data) override
Reads a matrix from a matrix_data structure.
gko::matrix::Ell::get_device_view
device_view get_device_view()
get the non-owning device view
gko::array::get_data
value_type * get_data() noexcept
Returns a pointer to the block of memory used to store the elements of the array.
Definition: array.hpp:687
gko::matrix::Ell::get_num_stored_elements_per_row
size_type get_num_stored_elements_per_row() const noexcept
Returns the number of stored elements per row.
Definition: ell.hpp:191
gko::matrix::Ell::get_const_device_view
const_device_view get_const_device_view() const
get the const non-owning device view
gko::previous_precision
typename detail::find_precision_impl< T, -step >::type previous_precision
Obtains the previous move type of T in the singly-linked precision corresponding bfloat16/half.
Definition: math.hpp:473
gko::matrix::Ell
ELL is a matrix format where stride with explicit zeros is used such that all rows have the same numb...
Definition: csr.hpp:31
gko::matrix::Ell::write
void write(mat_data &data) const override
Writes a matrix to a matrix_data structure.
gko::matrix::Ell::compute_absolute_inplace
void compute_absolute_inplace() override
Compute absolute inplace on each element.
gko::Executor
The first step in using the Ginkgo library consists of creating an executor.
Definition: executor.hpp:616
gko::array::get_const_data
const value_type * get_const_data() const noexcept
Returns a constant pointer to the block of memory used to store the elements of the array.
Definition: array.hpp:696
gko::array::get_size
size_type get_size() const noexcept
Returns the number of elements in the array.
Definition: array.hpp:670
gko::matrix::Ell::col_at
index_type col_at(size_type row, size_type idx) const noexcept
Returns the idx-th column index of the row-th row .
Definition: ell.hpp:254
gko::matrix::Ell::col_at
index_type & col_at(size_type row, size_type idx) noexcept
Returns the idx-th column index of the row-th row .
Definition: ell.hpp:246
gko::LinOp::LinOp
LinOp(const LinOp &)=default
Copy-constructs a LinOp.
gko::to_complex
typename detail::to_complex_s< T >::type to_complex
Obtain the type which adds the complex of complex/scalar type or the template parameter of class by a...
Definition: math.hpp:283