|
Ginkgo
Generated from pipelines/1589998975 branch based on develop. Ginkgo version 1.10.0
A numerical linear algebra library targeting many-core architectures
|
5 #ifndef GKO_PUBLIC_CORE_MATRIX_SELLP_HPP_
6 #define GKO_PUBLIC_CORE_MATRIX_SELLP_HPP_
9 #include <ginkgo/core/base/array.hpp>
10 #include <ginkgo/core/base/lin_op.hpp>
17 constexpr
int default_slice_size = 64;
18 constexpr
int default_stride_factor = 1;
21 template <
typename ValueType>
24 template <
typename ValueType,
typename IndexType>
42 template <
typename ValueType = default_precision,
typename IndexType =
int32>
43 class Sellp :
public EnableLinOp<Sellp<ValueType, IndexType>>,
44 public ConvertibleTo<Sellp<next_precision<ValueType>, IndexType>>,
45 #if GINKGO_ENABLE_HALF
47 Sellp<next_precision<next_precision<ValueType>>, IndexType>>,
49 public ConvertibleTo<Dense<ValueType>>,
50 public ConvertibleTo<Csr<ValueType, IndexType>>,
51 public DiagonalExtractable<ValueType>,
52 public ReadableFromMatrixData<ValueType, IndexType>,
53 public WritableToMatrixData<ValueType, IndexType>,
54 public EnableAbsoluteComputation<
55 remove_complex<Sellp<ValueType, IndexType>>> {
56 friend class EnablePolymorphicObject<
Sellp,
LinOp>;
57 friend class Dense<ValueType>;
58 friend class Csr<ValueType, IndexType>;
65 Sellp<next_precision<ValueType>, IndexType>>::convert_to;
66 using ConvertibleTo<Sellp<next_precision<ValueType>, IndexType>>::move_to;
67 using ConvertibleTo<Dense<ValueType>>::convert_to;
68 using ConvertibleTo<Dense<ValueType>>::move_to;
69 using ConvertibleTo<Csr<ValueType, IndexType>>::convert_to;
70 using ConvertibleTo<Csr<ValueType, IndexType>>::move_to;
73 using value_type = ValueType;
74 using index_type = IndexType;
75 using mat_data = matrix_data<ValueType, IndexType>;
76 using device_mat_data = device_matrix_data<ValueType, IndexType>;
77 using absolute_type = remove_complex<Sellp>;
79 friend class Sellp<previous_precision<ValueType>, IndexType>;
82 Sellp<next_precision<ValueType>, IndexType>* result)
const override;
84 void move_to(
Sellp<next_precision<ValueType>, IndexType>* result)
override;
86 #if GINKGO_ENABLE_HALF
87 friend class Sellp<previous_precision<previous_precision<ValueType>>,
89 using ConvertibleTo<Sellp<next_precision<next_precision<ValueType>>,
90 IndexType>>::convert_to;
92 Sellp<next_precision<next_precision<ValueType>>, IndexType>>::move_to;
95 result)
const override;
101 void convert_to(Dense<ValueType>* other)
const override;
103 void move_to(Dense<ValueType>* other)
override;
105 void convert_to(Csr<ValueType, IndexType>* other)
const override;
107 void move_to(Csr<ValueType, IndexType>* other)
override;
109 void read(
const mat_data& data)
override;
111 void read(
const device_mat_data& data)
override;
113 void read(device_mat_data&& data)
override;
115 void write(mat_data& data)
const override;
223 return values_.
get_size() / slice_size_;
251 return values_.
get_data()[this->linearize_index(row, slice_set, idx)];
279 return this->
get_col_idxs()[this->linearize_index(row, slice_set, idx)];
289 ->get_const_col_idxs()[this->linearize_index(row, slice_set, idx)];
302 static std::unique_ptr<Sellp>
create(std::shared_ptr<const Executor> exec,
318 static std::unique_ptr<Sellp>
create(std::shared_ptr<const Executor> exec,
351 Sellp(std::shared_ptr<const Executor> exec,
const dim<2>& size = {},
354 Sellp(std::shared_ptr<const Executor> exec,
const dim<2>& size,
357 void apply_impl(
const LinOp* b,
LinOp* x)
const override;
360 LinOp* x)
const override;
365 return (slice_set + col) * slice_size_ + row;
369 array<value_type> values_;
370 array<index_type> col_idxs_;
371 array<size_type> slice_lengths_;
372 array<size_type> slice_sets_;
382 #endif // GKO_PUBLIC_CORE_MATRIX_SELLP_HPP_
const size_type * get_const_slice_sets() const noexcept
Returns the offsets of slices.
Definition: sellp.hpp:197
size_type get_stride_factor() const noexcept
Returns the stride factor(t) of SELL-P.
Definition: sellp.hpp:214
void move_to(result_type *result) override
Definition: polymorphic_object.hpp:751
void convert_to(result_type *result) const override
Definition: polymorphic_object.hpp:749
Sellp(const Sellp &)
Copy-assigns a Sellp matrix.
virtual void read(const matrix_data< ValueType, IndexType > &data)=0
Reads a matrix from a matrix_data structure.
index_type & col_at(size_type row, size_type slice_set, size_type idx) noexcept
Returns the idx-th column index of the row-th row with slice_set slice set.
Definition: sellp.hpp:276
value_type * get_values() noexcept
Returns the values of the matrix.
Definition: sellp.hpp:128
Sellp & operator=(const Sellp &)
Copy-assigns a Sellp matrix.
size_type get_num_stored_elements() const noexcept
Returns the number of elements explicitly stored in the matrix.
Definition: sellp.hpp:231
std::size_t size_type
Integral type used for allocation quantities.
Definition: types.hpp:89
static std::unique_ptr< Sellp > create(std::shared_ptr< const Executor > exec, const dim< 2 > &size={}, size_type total_cols=0)
Creates an uninitialized Sellp matrix of the specified size.
value_type & val_at(size_type row, size_type slice_set, size_type idx) noexcept
Returns the idx-th non-zero element of the row-th row with slice_set slice set.
Definition: sellp.hpp:248
void write(mat_data &data) const override
Writes a matrix to a matrix_data structure.
const index_type * get_const_col_idxs() const noexcept
Returns the column indexes of the matrix.
Definition: sellp.hpp:156
void read(const mat_data &data) override
Reads a matrix from a matrix_data structure.
index_type * get_col_idxs() noexcept
Returns the column indexes of the matrix.
Definition: sellp.hpp:147
size_type * get_slice_lengths() noexcept
Returns the lengths(columns) of slices.
Definition: sellp.hpp:166
size_type * get_slice_sets() noexcept
Returns the offsets of slices.
Definition: sellp.hpp:188
The Ginkgo namespace.
Definition: abstract_factory.hpp:20
std::unique_ptr< absolute_type > compute_absolute() const override
Gets the AbsoluteLinOp.
const size_type * get_const_slice_lengths() const noexcept
Returns the lengths(columns) of slices.
Definition: sellp.hpp:178
value_type * get_data() noexcept
Returns a pointer to the block of memory used to store the elements of the array.
Definition: array.hpp:673
value_type val_at(size_type row, size_type slice_set, size_type idx) const noexcept
Returns the idx-th non-zero element of the row-th row with slice_set slice set.
Definition: sellp.hpp:257
size_type get_total_cols() const noexcept
Returns the total column number.
Definition: sellp.hpp:221
size_type get_slice_size() const noexcept
Returns the size of a slice.
Definition: sellp.hpp:207
next_precision_base< T > next_precision
Obtains the next type in the singly-linked precision list with half.
Definition: math.hpp:445
void compute_absolute_inplace() override
Compute absolute inplace on each element.
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:682
std::unique_ptr< Diagonal< ValueType > > extract_diagonal() const override
Extracts the diagonal entries of the matrix into a vector.
index_type col_at(size_type row, size_type slice_set, size_type idx) const noexcept
Returns the idx-th column index of the row-th row with slice_set slice set.
Definition: sellp.hpp:285
size_type get_size() const noexcept
Returns the number of elements in the array.
Definition: array.hpp:656
const value_type * get_const_values() const noexcept
Returns the values of the matrix.
Definition: sellp.hpp:137
LinOp(const LinOp &)=default
Copy-constructs a LinOp.
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:279