 |
Ginkgo
Generated from pipelines/2171896597 branch based on develop. Ginkgo version 1.11.0
A numerical linear algebra library targeting many-core architectures
|
5 #ifndef GKO_PUBLIC_CORE_BASE_DEVICE_MATRIX_DATA_HPP_
6 #define GKO_PUBLIC_CORE_BASE_DEVICE_MATRIX_DATA_HPP_
9 #include <ginkgo/core/base/array.hpp>
10 #include <ginkgo/core/base/dim.hpp>
11 #include <ginkgo/core/base/exception_helpers.hpp>
12 #include <ginkgo/core/base/executor.hpp>
13 #include <ginkgo/core/base/matrix_data.hpp>
14 #include <ginkgo/core/base/temporary_clone.hpp>
35 template <
typename ValueType,
typename IndexType>
37 GKO_ASSERT_SUPPORTED_VALUE_AND_INDEX_TYPE;
40 using value_type = ValueType;
41 using index_type = IndexType;
84 template <
typename InputValueType,
typename RowIndexType,
85 typename ColIndexType>
87 "explicitly construct the gko::array arguments instead of passing "
90 std::initializer_list<RowIndexType> row_idxs,
91 std::initializer_list<ColIndexType> col_idxs,
92 std::initializer_list<InputValueType> values)
117 std::shared_ptr<const Executor> exec,
const host_type& data);
167 GKO_DEPRECATED(
"use get_num_stored_elements()")
273 template <
typename ValueType,
typename IndexType>
275 static std::unique_ptr<device_matrix_data<ValueType, IndexType>> create(
276 std::shared_ptr<const Executor> exec,
280 return std::make_unique<device_matrix_data<ValueType, IndexType>>(
281 std::move(exec), *ptr);
283 return std::make_unique<device_matrix_data<ValueType, IndexType>>(
290 template <
typename ValueType,
typename IndexType>
291 struct temporary_clone_helper<const device_matrix_data<ValueType, IndexType>> {
292 static std::unique_ptr<const device_matrix_data<ValueType, IndexType>>
293 create(std::shared_ptr<const Executor> exec,
294 const device_matrix_data<ValueType, IndexType>* ptr,
bool)
296 return std::make_unique<const device_matrix_data<ValueType, IndexType>>(
297 std::move(exec), *ptr);
302 template <
typename ValueType,
typename IndexType>
303 class copy_back_deleter<device_matrix_data<ValueType, IndexType>>
304 :
public copy_back_deleter_from_assignment<
305 device_matrix_data<ValueType, IndexType>> {
307 using copy_back_deleter_from_assignment<device_matrix_data<
308 ValueType, IndexType>>::copy_back_deleter_from_assignment;
316 #endif // GKO_PUBLIC_CORE_BASE_DEVICE_MATRIX_DATA_HPP_
host_type copy_to_host() const
Copies the device_matrix_data entries to the host to return a regular matrix_data object with the sam...
value_type * get_values()
Returns a pointer to the value array.
Definition: device_matrix_data.hpp:216
const index_type * get_const_row_idxs() const
Returns a pointer to the constant row index array.
Definition: device_matrix_data.hpp:189
Type used to store nonzeros.
Definition: matrix_data.hpp:60
std::shared_ptr< const Executor > get_executor() const
Returns the executor used to store the device_matrix_data entries.
Definition: device_matrix_data.hpp:150
index_type * get_row_idxs()
Returns a pointer to the row index array.
Definition: device_matrix_data.hpp:182
static device_matrix_data create_from_host(std::shared_ptr< const Executor > exec, const host_type &data)
Creates a device_matrix_data object from the given host data on the given executor.
std::size_t size_type
Integral type used for allocation quantities.
Definition: types.hpp:90
void remove_zeros()
Removes all zero entries from the storage.
arrays empty_out()
Moves out the internal arrays of the device_matrix_data object and resets it to an empty 0x0 matrix.
void sum_duplicates()
Sums up all duplicate entries pointing to the same non-zero location.
The Ginkgo namespace.
Definition: abstract_factory.hpp:20
size_type get_num_elems() const
Returns the number of stored elements of the matrix.
Definition: device_matrix_data.hpp:168
index_type * get_col_idxs()
Returns a pointer to the column index array.
Definition: device_matrix_data.hpp:199
This structure is used as an intermediate data type to store a sparse matrix.
Definition: matrix_data.hpp:126
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
dim< 2 > get_size() const
Returns the dimensions of the matrix.
Definition: device_matrix_data.hpp:160
const value_type * get_const_values() const
Returns a pointer to the constant value array.
Definition: device_matrix_data.hpp:223
std::shared_ptr< const Executor > get_executor() const noexcept
Returns the Executor associated with the array.
Definition: array.hpp:703
size_type get_num_stored_elements() const
Returns the number of stored elements of the matrix.
Definition: device_matrix_data.hpp:175
void fill_zero()
Fills the matrix entries with zeros.
The first step in using the Ginkgo library consists of creating an executor.
Definition: executor.hpp:615
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
void sort_row_major()
Sorts the matrix entries in row-major order This means that they will be sorted by row index first,...
size_type get_size() const noexcept
Returns the number of elements in the array.
Definition: array.hpp:670
device_matrix_data(std::shared_ptr< const Executor > exec, dim< 2 > size={}, size_type num_entries=0)
Initializes a new device_matrix_data object.
This type is a device-side equivalent to matrix_data.
Definition: device_matrix_data.hpp:36
void resize_and_reset(size_type new_num_entries)
Resizes the internal storage to the given number of stored matrix entries.
const index_type * get_const_col_idxs() const
Returns a pointer to the constant column index array.
Definition: device_matrix_data.hpp:206
Stores the internal arrays of a device_matrix_data object.
Definition: device_matrix_data.hpp:248