|  | Ginkgo Generated from  branch based on main. Ginkgo version 1.10.0
    A numerical linear algebra library targeting many-core architectures | 
Defines the parameters of the interleaved block storage scheme used by block-Jacobi blocks. More...
#include <ginkgo/core/preconditioner/jacobi.hpp>
| Public Member Functions | |
| block_interleaved_storage_scheme (IndexType block_offset, IndexType group_offset, uint32 group_power) | |
| IndexType | get_group_size () const noexcept | 
| Returns the number of elements in the group. | |
| size_type | compute_storage_space (size_type num_blocks) const noexcept | 
| Computes the storage space required for the requested number of blocks. | |
| IndexType | get_group_offset (IndexType block_id) const noexcept | 
| Returns the offset of the group belonging to the block with the given ID. | |
| IndexType | get_block_offset (IndexType block_id) const noexcept | 
| Returns the offset of the block with the given ID within its group. | |
| IndexType | get_global_block_offset (IndexType block_id) const noexcept | 
| Returns the offset of the block with the given ID. | |
| IndexType | get_stride () const noexcept | 
| Returns the stride between columns of the block. | |
| Public Attributes | |
| IndexType | block_offset | 
| The offset between consecutive blocks within the group. | |
| IndexType | group_offset | 
| The offset between two block groups. | |
| uint32 | group_power | 
| Then base 2 power of the group. | |
Defines the parameters of the interleaved block storage scheme used by block-Jacobi blocks.
| IndexType | type used for storing indices of the matrix | 
| 
 | inlinenoexcept | 
Computes the storage space required for the requested number of blocks.
| num_blocks | the total number of blocks that needs to be stored | 
References gko::ceildiv(), and get_group_size().
| 
 | inlinenoexcept | 
Returns the offset of the block with the given ID within its group.
| block_id | the ID of the block | 
References block_offset, and get_group_size().
Referenced by get_global_block_offset().
| 
 | inlinenoexcept | 
Returns the offset of the block with the given ID.
| block_id | the ID of the block | 
References get_block_offset(), and get_group_offset().
| 
 | inlinenoexcept | 
Returns the offset of the group belonging to the block with the given ID.
| block_id | the ID of the block | 
References group_offset, and group_power.
Referenced by get_global_block_offset().
| 
 | inlinenoexcept | 
Returns the number of elements in the group.
References group_power, and gko::one().
Referenced by compute_storage_space(), and get_block_offset().
| 
 | inlinenoexcept | 
Returns the stride between columns of the block.
References block_offset, and group_power.
| uint32 gko::preconditioner::block_interleaved_storage_scheme< IndexType >::group_power | 
Then base 2 power of the group.
I.e. the group contains 1 << group_power elements.
Referenced by get_group_offset(), get_group_size(), and get_stride().