|
| std::shared_ptr< const LinOp > | get_system_matrix () const |
| |
| IndexType * | get_agg () noexcept |
| |
| const IndexType * | get_const_agg () const noexcept |
| |
|
const parameters_type & | get_parameters () const |
| |
|
const ConcreteLinOp * | apply (ptr_param< const LinOp > b, ptr_param< LinOp > x) const |
| |
|
ConcreteLinOp * | apply (ptr_param< const LinOp > b, ptr_param< LinOp > x) |
| |
|
const ConcreteLinOp * | apply (ptr_param< const LinOp > alpha, ptr_param< const LinOp > b, ptr_param< const LinOp > beta, ptr_param< LinOp > x) const |
| |
|
ConcreteLinOp * | apply (ptr_param< const LinOp > alpha, ptr_param< const LinOp > b, ptr_param< const LinOp > beta, ptr_param< LinOp > x) |
| |
|
std::unique_ptr< AbstractObject > | create_default (std::shared_ptr< const Executor > exec) const |
| |
|
std::unique_ptr< AbstractObject > | create_default () const |
| |
|
std::unique_ptr< AbstractObject > | clone (std::shared_ptr< const Executor > exec) const |
| |
|
std::unique_ptr< AbstractObject > | clone () const |
| |
|
AbstractObject * | copy_from (const PolymorphicObject *other) |
| |
|
template<typename Derived > |
| std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, AbstractObject > * | copy_from (std::unique_ptr< Derived > &&other) |
| |
|
template<typename Derived > |
| std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, AbstractObject > * | copy_from (const std::unique_ptr< Derived > &other) |
| |
|
AbstractObject * | copy_from (const std::shared_ptr< const PolymorphicObject > &other) |
| |
|
AbstractObject * | move_from (ptr_param< PolymorphicObject > other) |
| |
|
AbstractObject * | clear () |
| |
|
PolymorphicObject & | operator= (const PolymorphicObject &) |
| |
| std::unique_ptr< PolymorphicObject > | create_default (std::shared_ptr< const Executor > exec) const |
| |
| std::unique_ptr< PolymorphicObject > | create_default () const |
| |
| std::unique_ptr< PolymorphicObject > | clone (std::shared_ptr< const Executor > exec) const |
| |
| std::unique_ptr< PolymorphicObject > | clone () const |
| |
| PolymorphicObject * | copy_from (const PolymorphicObject *other) |
| |
| template<typename Derived , typename Deleter > |
| std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, PolymorphicObject > * | copy_from (std::unique_ptr< Derived, Deleter > &&other) |
| |
| template<typename Derived , typename Deleter > |
| std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, PolymorphicObject > * | copy_from (const std::unique_ptr< Derived, Deleter > &other) |
| |
| PolymorphicObject * | copy_from (const std::shared_ptr< const PolymorphicObject > &other) |
| |
| PolymorphicObject * | move_from (ptr_param< PolymorphicObject > other) |
| |
| PolymorphicObject * | clear () |
| |
| std::shared_ptr< const Executor > | get_executor () const noexcept |
| |
| void | add_logger (std::shared_ptr< const Logger > logger) override |
| |
| void | remove_logger (const Logger *logger) override |
| |
|
void | remove_logger (ptr_param< const Logger > logger) |
| |
| const std::vector< std::shared_ptr< const Logger > > & | get_loggers () const override |
| |
| void | clear_loggers () override |
| |
|
void | remove_logger (ptr_param< const Logger > logger) |
| |
| void | convert_to (result_type *result) const override |
| |
| void | move_to (result_type *result) override |
| |
| virtual void | convert_to (result_type *result) const =0 |
| |
|
void | convert_to (ptr_param< result_type > result) const |
| |
| virtual void | move_to (result_type *result)=0 |
| |
|
void | move_to (ptr_param< result_type > result) |
| |
| std::shared_ptr< const LinOp > | get_fine_op () const override |
| |
| std::shared_ptr< const LinOp > | get_restrict_op () const override |
| |
| std::shared_ptr< const LinOp > | get_coarse_op () const override |
| |
| std::shared_ptr< const LinOp > | get_prolong_op () const override |
| |
| std::shared_ptr< Composition< ValueType > > | get_composition () const |
| |
| std::shared_ptr< const LinOp > | get_operator_at (size_type index) const |
| |
|
|
void | apply_impl (const LinOp *b, LinOp *x) const override |
| |
|
void | apply_impl (const LinOp *alpha, const LinOp *b, const LinOp *beta, LinOp *x) const override |
| |
|
| Pgm (std::shared_ptr< const Executor > exec) |
| |
|
| Pgm (const Factory *factory, std::shared_ptr< const LinOp > system_matrix) |
| |
|
void | generate () |
| |
| std::tuple< std::shared_ptr< LinOp >, std::shared_ptr< LinOp >, std::shared_ptr< LinOp > > | generate_local (std::shared_ptr< const matrix::Csr< ValueType, IndexType > > local_matrix) |
| |
|
template<typename GlobalIndexType > |
| void | communicate (std::shared_ptr< const experimental::distributed::Matrix< ValueType, IndexType, GlobalIndexType > > matrix, const array< IndexType > &local_agg, array< IndexType > &non_local_agg) |
| |
|
ConcreteLinOp * | self () noexcept |
| |
|
const ConcreteLinOp * | self () const noexcept |
| |
| std::unique_ptr< PolymorphicObject > | create_default_impl (std::shared_ptr< const Executor > exec) const override |
| |
| PolymorphicObject * | copy_from_impl (const PolymorphicObject *other) override |
| |
| PolymorphicObject * | copy_from_impl (std::unique_ptr< PolymorphicObject > other) override |
| |
| PolymorphicObject * | move_from_impl (PolymorphicObject *other) override |
| |
| PolymorphicObject * | move_from_impl (std::unique_ptr< PolymorphicObject > other) override |
| |
| PolymorphicObject * | clear_impl () override |
| |
| | PolymorphicObject (std::shared_ptr< const Executor > exec) |
| |
|
| PolymorphicObject (const PolymorphicObject &other) |
| |
|
void | log (Params &&... params) const |
| |
| void | set_multigrid_level (std::shared_ptr< const LinOp > prolong_op, std::shared_ptr< const LinOp > coarse_op, std::shared_ptr< const LinOp > restrict_op) |
| |
| void | set_fine_op (std::shared_ptr< const LinOp > fine_op) |
| |
| | EnableMultigridLevel (std::shared_ptr< const LinOp > fine_op) |
| |
| void | set_composition (LinOp &&... linop) |
| |
template<typename ValueType = default_precision, typename IndexType = int32>
class gko::multigrid::Pgm< ValueType, IndexType >
Parallel graph match (Pgm) is the aggregate method introduced in the paper M. Naumov et al., "AmgX: A Library for GPU Accelerated Algebraic
Multigrid and Preconditioned Iterative Methods". Current implementation only contains size = 2 version.
Pgm creates the aggregate group according to the matrix value not the structure. Pgm gives two steps (one-phase handshaking) to group the elements. 1: get the strongest neighbor of each unaggregated element. 2: group the elements whose strongest neighbor is each other. repeating until reaching the given conditions. After that, the un-aggregated elements are assigned to an aggregated group or are left alone.
- Template Parameters
-
| ValueType | precision of matrix elements |
| IndexType | precision of matrix indexes |