|  | Ginkgo Generated from  branch based on master. Ginkgo version 1.7.0
    A numerical linear algebra library targeting many-core architectures | 
Parallel graph match (Pgm) is the aggregate method introduced in the paper M. More...
#include <ginkgo/core/multigrid/pgm.hpp>
| Classes | |
| class | Factory | 
| struct | parameters_type | 
| Public Types | |
| using | value_type = ValueType | 
| using | index_type = IndexType | 
|  Public Types inherited from gko::EnablePolymorphicAssignment< ConcreteLinOp > | |
| using | result_type | 
|  Public Types inherited from gko::ConvertibleTo< ResultType > | |
| using | result_type = ResultType | 
|  Public Types inherited from gko::multigrid::EnableMultigridLevel< ValueType > | |
| using | value_type = ValueType | 
|  Public Types inherited from gko::UseComposition< ValueType > | |
| using | value_type | 
| Public Member Functions | |
| std::shared_ptr< const LinOp > | get_system_matrix () const | 
| Returns the system operator (matrix) of the linear system. | |
| IndexType * | get_agg () noexcept | 
| Returns the aggregate group. | |
| const IndexType * | get_const_agg () const noexcept | 
| Returns the aggregate group. | |
| const parameters_type & | get_parameters () const | 
|  Public Member Functions inherited from gko::EnableLinOp< ConcreteLinOp, PolymorphicBase > | |
| 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) | 
|  Public Member Functions inherited from gko::EnableAbstractPolymorphicObject< AbstractObject, PolymorphicBase > | |
| 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 () | 
|  Public Member Functions inherited from gko::PolymorphicObject | |
| PolymorphicObject & | operator= (const PolymorphicObject &) | 
| std::unique_ptr< PolymorphicObject > | create_default (std::shared_ptr< const Executor > exec) const | 
| Creates a new "default" object of the same dynamic type as this object. | |
| std::unique_ptr< PolymorphicObject > | create_default () const | 
| Creates a new "default" object of the same dynamic type as this object. | |
| std::unique_ptr< PolymorphicObject > | clone (std::shared_ptr< const Executor > exec) const | 
| Creates a clone of the object. | |
| std::unique_ptr< PolymorphicObject > | clone () const | 
| Creates a clone of the object. | |
| PolymorphicObject * | copy_from (const PolymorphicObject *other) | 
| Copies another object into this object. | |
| 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) | 
| Moves another object into this object. | |
| 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) | 
| Copies another object into this object. | |
| PolymorphicObject * | copy_from (const std::shared_ptr< const PolymorphicObject > &other) | 
| Copies another object into this object. | |
| PolymorphicObject * | move_from (ptr_param< PolymorphicObject > other) | 
| Moves another object into this object. | |
| PolymorphicObject * | clear () | 
| Transforms the object into its default state. | |
| std::shared_ptr< const Executor > | get_executor () const noexcept | 
| Returns the Executor of the object. | |
|  Public Member Functions inherited from gko::log::EnableLogging< PolymorphicObject > | |
| void | add_logger (std::shared_ptr< const Logger > logger) override | 
| Adds a new logger to the list of subscribed loggers. | |
| void | remove_logger (const Logger *logger) override | 
| Removes a logger from the list of subscribed loggers. | |
| void | remove_logger (ptr_param< const Logger > logger) | 
| const std::vector< std::shared_ptr< const Logger > > & | get_loggers () const override | 
| Returns the vector containing all loggers registered at this object. | |
| void | clear_loggers () override | 
| Remove all loggers registered at this object. | |
|  Public Member Functions inherited from gko::log::Loggable | |
| void | remove_logger (ptr_param< const Logger > logger) | 
|  Public Member Functions inherited from gko::EnablePolymorphicAssignment< ConcreteLinOp > | |
| void | convert_to (result_type *result) const override | 
| Converts the implementer to an object of type result_type. | |
| void | move_to (result_type *result) override | 
| Converts the implementer to an object of type result_type by moving data from this object. | |
|  Public Member Functions inherited from gko::ConvertibleTo< ResultType > | |
| virtual void | convert_to (result_type *result) const =0 | 
| Converts the implementer to an object of type result_type. | |
| void | convert_to (ptr_param< result_type > result) const | 
| virtual void | move_to (result_type *result)=0 | 
| Converts the implementer to an object of type result_type by moving data from this object. | |
| void | move_to (ptr_param< result_type > result) | 
|  Public Member Functions inherited from gko::multigrid::EnableMultigridLevel< ValueType > | |
| std::shared_ptr< const LinOp > | get_fine_op () const override | 
| Returns the operator on fine level. | |
| std::shared_ptr< const LinOp > | get_restrict_op () const override | 
| Returns the restrict operator. | |
| std::shared_ptr< const LinOp > | get_coarse_op () const override | 
| Returns the operator on coarse level. | |
| std::shared_ptr< const LinOp > | get_prolong_op () const override | 
| Returns the prolong operator. | |
|  Public Member Functions inherited from gko::UseComposition< ValueType > | |
| std::shared_ptr< Composition< ValueType > > | get_composition () const | 
| Returns the composition operators. | |
| std::shared_ptr< const LinOp > | get_operator_at (size_type index) const | 
| Returns the operator at index-th position of composition. | |
| Static Public Member Functions | |
| static auto | build () -> decltype(Factory ::create()) | 
| Friends | |
| class | EnableLinOp< Pgm > | 
| class | EnablePolymorphicObject< Pgm, LinOp > | 
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.
| ValueType | precision of matrix elements | 
| IndexType | precision of matrix indexes | 
| 
 | inlinenoexcept | 
Returns the aggregate group.
Aggregate group whose size is same as the number of rows. Stores the mapping information from row index to coarse row index. i.e., agg[row_idx] = coarse_row_idx.
References gko::array< ValueType >::get_data().
| 
 | inlinenoexcept | 
Returns the aggregate group.
Aggregate group whose size is same as the number of rows. Stores the mapping information from row index to coarse row index. i.e., agg[row_idx] = coarse_row_idx.
References gko::array< ValueType >::get_const_data().
| 
 | inline | 
Returns the system operator (matrix) of the linear system.