|  | Ginkgo Generated from  branch based on main. Ginkgo version 1.10.0
    A numerical linear algebra library targeting many-core architectures | 
Rcm (Reverse Cuthill-McKee) is a reordering algorithm minimizing the bandwidth of a matrix. More...
#include <ginkgo/core/reorder/rcm.hpp>
| Classes | |
| class | Factory | 
| struct | parameters_type | 
| Public Types | |
| using | SparsityMatrix = matrix::SparsityCsr<ValueType, IndexType> | 
| using | PermutationMatrix = matrix::Permutation<IndexType> | 
| using | value_type = ValueType | 
| using | index_type = IndexType | 
| Public Types inherited from gko::EnablePolymorphicAssignment< Rcm< default_precision, int32 > > | |
| using | result_type | 
| Public Types inherited from gko::ConvertibleTo< Rcm< default_precision, int32 > > | |
| using | result_type | 
| Public Member Functions | |
| std::shared_ptr< const PermutationMatrix > | get_permutation () const | 
| Gets the permutation (permutation matrix, output of the algorithm) of the linear operator. | |
| std::shared_ptr< const PermutationMatrix > | get_inverse_permutation () const | 
| Gets the inverse permutation (permutation matrix, output of the algorithm) of the linear operator. | |
| const parameters_type & | get_parameters () const | 
| Public Member Functions inherited from gko::EnableAbstractPolymorphicObject< Rcm< default_precision, int32 >, ReorderingBase< int32 > > | |
| std::unique_ptr< Rcm< default_precision, int32 > > | create_default (std::shared_ptr< const Executor > exec) const | 
| std::unique_ptr< Rcm< default_precision, int32 > > | clone (std::shared_ptr< const Executor > exec) const | 
| Rcm< default_precision, int32 > * | copy_from (const PolymorphicObject *other) | 
| Rcm< default_precision, int32 > * | move_from (ptr_param< PolymorphicObject > other) | 
| Rcm< default_precision, int32 > * | clear () | 
| Public Member Functions inherited from gko::EnablePolymorphicAssignment< Rcm< default_precision, int32 > > | |
| void | convert_to (result_type *result) const override | 
| void | move_to (result_type *result) override | 
| Static Public Member Functions | |
| static auto | build () -> decltype(Factory::create()) | 
| Friends | |
| class | EnablePolymorphicObject< Rcm, ReorderingBase< IndexType > > | 
Rcm (Reverse Cuthill-McKee) is a reordering algorithm minimizing the bandwidth of a matrix.
Such a reordering typically also significantly reduces fill-in, though usually not as effective as more complex algorithms, specifically AMD and nested dissection schemes. The advantage of this algorithm is its low runtime. It requires the input matrix to be structurally symmetric.
There are two "starting strategies" currently available: minimum degree and pseudo-peripheral. These strategies control how a starting vertex for a connected component is chosen, which is then renumbered as first vertex in the component, starting the algorithm from there. In general, the bandwidths obtained by choosing a pseudo-peripheral vertex are slightly smaller than those obtained from choosing a vertex of minimum degree. On the other hand, this strategy is much more expensive, relatively. The algorithm for finding a pseudo-peripheral vertex as described in "Computer Solution of Sparse Linear Systems" (George, Liu, Ng, Oak Ridge National Laboratory, 1994) is implemented here.
| ValueType | Type of the values of all matrices used in this class | 
| IndexType | Type of the indices of all matrices used in this class | 
| 
 | inline | 
Gets the inverse permutation (permutation matrix, output of the algorithm) of the linear operator.
| 
 | inline | 
Gets the permutation (permutation matrix, output of the algorithm) of the linear operator.