|
Ginkgo
Generated from pipelines/1554403166 branch based on develop. Ginkgo version 1.9.0
A numerical linear algebra library targeting many-core architectures
|
5 #ifndef GKO_PUBLIC_CORE_PRECONDITIONER_JACOBI_HPP_
6 #define GKO_PUBLIC_CORE_PRECONDITIONER_JACOBI_HPP_
9 #include <ginkgo/core/base/array.hpp>
10 #include <ginkgo/core/base/lin_op.hpp>
11 #include <ginkgo/core/config/config.hpp>
12 #include <ginkgo/core/config/registry.hpp>
13 #include <ginkgo/core/matrix/csr.hpp>
14 #include <ginkgo/core/matrix/dense.hpp>
15 #include <ginkgo/core/matrix/diagonal.hpp>
24 namespace preconditioner {
36 template <
typename IndexType>
125 GKO_ATTRIBUTES IndexType
186 template <
typename ValueType = default_precision,
typename IndexType =
int32>
199 using value_type = ValueType;
200 using index_type = IndexType;
225 return storage_scheme_;
272 void write(mat_data& data)
const override;
274 std::unique_ptr<LinOp>
transpose()
const override;
377 struct storage_optimization_type {
379 : is_block_wise{
false}, of_all_blocks{p}
382 storage_optimization_type(
384 : is_block_wise{block_wise_opt.
get_size() > 0},
385 block_wise{block_wise_opt}
388 storage_optimization_type(
389 array<precision_reduction>&& block_wise_opt)
390 : is_block_wise{block_wise_opt.
get_size() > 0},
391 block_wise{std::move(block_wise_opt)}
394 operator precision_reduction() {
return of_all_blocks; }
397 precision_reduction of_all_blocks;
520 static parameters_type
parse(
523 config::make_type_descriptor<ValueType, IndexType>());
531 explicit Jacobi(std::shared_ptr<const Executor> exec)
548 explicit Jacobi(
const Factory* factory,
549 std::shared_ptr<const LinOp> system_matrix)
552 parameters_{factory->get_parameters()},
553 storage_scheme_{this->compute_storage_scheme(
556 blocks_(
factory->get_executor(),
557 storage_scheme_.compute_storage_space(
558 parameters_.block_pointers.get_size() - 1)),
559 conditioning_(
factory->get_executor())
564 this->generate(system_matrix.get(), parameters_.
skip_sorting);
575 block_interleaved_storage_scheme<index_type> compute_storage_scheme(
578 uint32 default_block_stride = 32;
580 if (
auto hip_exec = std::dynamic_pointer_cast<const gko::HipExecutor>(
582 default_block_stride = hip_exec->get_warp_size();
584 uint32 max_block_stride = default_block_stride;
585 if (param_max_block_stride != 0) {
588 max_block_stride = param_max_block_stride;
590 max_block_stride != default_block_stride) {
592 GKO_NOT_SUPPORTED(
this);
597 GKO_NOT_SUPPORTED(
this);
599 const auto group_size = static_cast<uint32>(
601 const auto block_offset = max_block_size;
602 const auto block_stride = group_size * block_offset;
603 const auto group_offset = max_block_size * block_stride;
604 return {static_cast<index_type>(block_offset),
605 static_cast<index_type>(group_offset),
618 void generate(
const LinOp* system_matrix,
bool skip_sorting);
627 void detect_blocks(
const matrix::Csr<ValueType, IndexType>* system_matrix);
629 void apply_impl(
const LinOp* b,
LinOp* x)
const override;
632 LinOp* x)
const override;
635 block_interleaved_storage_scheme<index_type> storage_scheme_{};
637 array<value_type> blocks_;
638 array<remove_complex<value_type>> conditioning_;
646 #endif // GKO_PUBLIC_CORE_PRECONDITIONER_JACOBI_HPP_
Definition: jacobi.hpp:501
static parameters_type parse(const config::pnode &config, const config::registry &context, const config::type_descriptor &td_for_child=config::make_type_descriptor< ValueType, IndexType >())
Create the parameters from the property_tree.
void set_executor(std::shared_ptr< const Executor > exec)
Changes the Executor of the array, moving the allocated data to the new Executor.
Definition: array.hpp:700
This class is used to encode storage precisions of low precision algorithms.
Definition: types.hpp:238
IndexType block_offset
The offset between consecutive blocks within the group.
Definition: jacobi.hpp:50
bool skip_sorting
true means it is known that the matrix given to this factory will be sorted first by row,...
Definition: jacobi.hpp:344
pnode describes a tree of properties.
Definition: property_tree.hpp:28
Definition: lin_op.hpp:117
IndexType get_group_offset(IndexType block_id) const noexcept
Returns the offset of the group belonging to the block with the given ID.
Definition: jacobi.hpp:101
IndexType get_group_size() const noexcept
Returns the number of elements in the group.
Definition: jacobi.hpp:69
size_type get_num_blocks() const noexcept
Returns the number of blocks of the operator.
Definition: jacobi.hpp:212
Linear operators which support transposition should implement the Transposable interface.
Definition: lin_op.hpp:433
constexpr uint32 get_significant_bit(const T &n, uint32 hint=0u) noexcept
Returns the position of the most significant bit of the number.
Definition: math.hpp:1002
std::size_t size_type
Integral type used for allocation quantities.
Definition: types.hpp:86
IndexType get_stride() const noexcept
Returns the stride between columns of the block.
Definition: jacobi.hpp:137
#define GKO_FACTORY_PARAMETER_SCALAR(_name, _default)
Creates a scalar factory parameter in the factory parameters structure.
Definition: abstract_factory.hpp:445
void move_to(matrix::Dense< value_type > *result) override
Converts the implementer to an object of type result_type by moving data from this object.
This class describes the value and index types to be used when building a Ginkgo type from a configur...
Definition: type_descriptor.hpp:39
uint32 max_block_stride
Stride between two columns of a block (as number of elements).
Definition: jacobi.hpp:325
The Ginkgo namespace.
Definition: abstract_factory.hpp:20
IndexType group_offset
The offset between two block groups.
Definition: jacobi.hpp:55
constexpr T get_superior_power(const T &base, const T &limit, const T &hint=T{1}) noexcept
Returns the smallest power of base not smaller than limit.
Definition: math.hpp:1020
void convert_to(matrix::Dense< value_type > *result) const override
Converts the implementer to an object of type result_type.
A block-Jacobi preconditioner is a block-diagonal linear operator, obtained by inverting the diagonal...
Definition: jacobi.hpp:187
uint32 group_power
Then base 2 power of the group.
Definition: jacobi.hpp:62
std::uint32_t uint32
32-bit unsigned integral type.
Definition: types.hpp:126
This structure is used as an intermediate data type to store a sparse matrix.
Definition: matrix_data.hpp:126
Jacobi & operator=(const Jacobi &other)
Copy-assigns a Jacobi preconditioner.
#define GKO_ENABLE_LIN_OP_FACTORY(_lin_op, _parameters_name, _factory_name)
This macro will generate a default implementation of a LinOpFactory for the LinOp subclass it is defi...
Definition: lin_op.hpp:1017
gko::array< index_type > block_pointers
Starting (row / column) indexes of individual blocks.
Definition: jacobi.hpp:372
const remove_complex< value_type > * get_conditioning() const noexcept
Returns an array of 1-norm condition numbers of the blocks.
Definition: jacobi.hpp:253
void write(mat_data &data) const override
Writes a matrix to a matrix_data structure.
const value_type * get_blocks() const noexcept
Returns the pointer to the memory used for storing the block data.
Definition: jacobi.hpp:239
IndexType get_global_block_offset(IndexType block_id) const noexcept
Returns the offset of the block with the given ID.
Definition: jacobi.hpp:126
A LinOp implementing this interface can write its data to a matrix_data structure.
Definition: lin_op.hpp:660
size_type get_num_stored_elements() const noexcept
Returns the number of elements explicitly stored in the matrix.
Definition: jacobi.hpp:263
storage_optimization_type storage_optimization
The precisions to use for the blocks of the matrix.
Definition: jacobi.hpp:470
Defines the parameters of the interleaved block storage scheme used by block-Jacobi blocks.
Definition: jacobi.hpp:37
uint32 max_block_size
Maximal size of diagonal blocks.
Definition: jacobi.hpp:314
ConvertibleTo interface is used to mark that the implementer can be converted to the object of Result...
Definition: polymorphic_object.hpp:470
Jacobi(const Jacobi &other)
Copy-constructs a Jacobi preconditioner.
std::unique_ptr< LinOp > transpose() const override
Returns a LinOp representing the transpose of the Transposable object.
This class stores additional context for creating Ginkgo objects from configuration files.
Definition: registry.hpp:167
std::unique_ptr< LinOp > conj_transpose() const override
Returns a LinOp representing the conjugate transpose of the Transposable object.
#define GKO_ENABLE_BUILD_METHOD(_factory_name)
Defines a build method for the factory, simplifying its construction by removing the repetitive typin...
Definition: abstract_factory.hpp:394
const block_interleaved_storage_scheme< index_type > & get_storage_scheme() const noexcept
Returns the storage scheme used for storing Jacobi blocks.
Definition: jacobi.hpp:222
#define GKO_CREATE_FACTORY_PARAMETERS(_parameters_name, _factory_name)
This Macro will generate a new type containing the parameters for the factory _factory_name.
Definition: abstract_factory.hpp:280
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
#define GKO_FACTORY_PARAMETER_VECTOR(_name,...)
Creates a vector factory parameter in the factory parameters structure.
Definition: abstract_factory.hpp:461
constexpr int64 ceildiv(int64 num, int64 den)
Performs integer division with rounding up.
Definition: math.hpp:612
size_type compute_storage_space(size_type num_blocks) const noexcept
Computes the storage space required for the requested number of blocks.
Definition: jacobi.hpp:87
std::shared_ptr< const Executor > get_executor() const noexcept
Returns the Executor of the object.
Definition: polymorphic_object.hpp:234
size_type get_size() const noexcept
Returns the number of elements in the array.
Definition: array.hpp:656
const dim< 2 > & get_size() const noexcept
Returns the size of the operator.
Definition: lin_op.hpp:210
typename detail::remove_complex_s< T >::type remove_complex
Obtain the type which removed the complex of complex/scalar type or the template parameter of class b...
Definition: math.hpp:325
The EnableLinOp mixin can be used to provide sensible default implementations of the majority of the ...
Definition: lin_op.hpp:877
LinOp(const LinOp &)=default
Copy-constructs a LinOp.
IndexType get_block_offset(IndexType block_id) const noexcept
Returns the offset of the block with the given ID within its group.
Definition: jacobi.hpp:113
This mixin inherits from (a subclass of) PolymorphicObject and provides a base implementation of a ne...
Definition: polymorphic_object.hpp:661