![]() |
Ginkgo Generated from branch based on main. Ginkgo version 1.11.0
A numerical linear algebra library targeting many-core architectures
|
The Incomplete Cholesky (IC) preconditioner solves the equation 
#include <ginkgo/core/preconditioner/ic.hpp>
Classes | |
| struct | parameters_type |
| class | Factory |
Public Types | |
| using | l_solver_type |
| using | value_type = gko::detail::get_value_type<LSolverTypeOrValueType> |
| using | lh_solver_type = gko::detail::transposed_type<l_solver_type> |
| using | index_type = IndexType |
| using | transposed_type = Ic<LSolverTypeOrValueType, IndexType> |
| Public Types inherited from gko::EnablePolymorphicAssignment< Ic< solver::LowerTrs<>, int32 > > | |
| using | result_type |
Public Member Functions | |
| const parameters_type & | get_parameters () const |
| std::shared_ptr< const l_solver_type > | get_l_solver () const |
| Returns the solver which is used for the provided L matrix. | |
| std::shared_ptr< const lh_solver_type > | get_lh_solver () const |
| Returns the solver which is used for the L^H matrix. | |
| std::unique_ptr< LinOp > | transpose () const override |
| Returns a LinOp representing the transpose of the Transposable object. | |
| std::unique_ptr< LinOp > | conj_transpose () const override |
| Returns a LinOp representing the conjugate transpose of the Transposable object. | |
| Ic & | operator= (const Ic &other) |
| Copy-assigns an IC preconditioner. | |
| Ic & | operator= (Ic &&other) |
| Move-assigns an IC preconditioner. | |
| Ic (const Ic &other) | |
| Copy-constructs an IC preconditioner. | |
| Ic (Ic &&other) | |
| Move-constructs an IC preconditioner. | |
| Public Member Functions inherited from gko::EnableLinOp< Ic< solver::LowerTrs<>, int32 > > | |
| const Ic< solver::LowerTrs<>, int32 > * | apply (ptr_param< const LinOp > b, ptr_param< LinOp > x) const |
| Public Member Functions inherited from gko::EnablePolymorphicAssignment< Ic< solver::LowerTrs<>, 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()) |
| static parameters_type | parse (const config::pnode &config, const config::registry &context, const config::type_descriptor &td_for_child=config::make_type_descriptor< value_type, index_type >()) |
| Create the parameters from the property_tree. | |
Friends | |
| class | EnableLinOp< Ic > |
| class | EnablePolymorphicObject< Ic, LinOp > |
The Incomplete Cholesky (IC) preconditioner solves the equation 
It allows to set both the solver for L defaulting to solver::LowerTrs, which is a direct triangular solvers. The solver for L^H is the conjugate-transposed solver for L, ensuring that the preconditioner is symmetric and positive-definite. For this L solver, a factory can be provided (using with_l_solver) to have more control over their behavior. In particular, it is possible to use an iterative method for solving the triangular systems. The default parameters for an iterative triangluar solver are:
An object of this class can be created with a matrix or a gko::Composition containing two matrices. If created with a matrix, it is factorized before creating the solver. If a gko::Composition (containing two matrices) is used, the first operand will be taken as the L matrix, the second will be considered the L^H matrix, which helps to avoid the otherwise necessary transposition of L inside the solver. ParIc can be directly used, since it orders the factors in the correct way.


| LSolverTypeOrValueType | type of the solver or the value type used for the L matrix. Defaults to solver::LowerTrs |
| IndexType | type of the indices when ParIc is used to generate the L and L^H factors. Irrelevant otherwise. |
| using gko::preconditioner::Ic< LSolverTypeOrValueType, IndexType >::l_solver_type |
|
inline |
Copy-constructs an IC preconditioner.
Inherits the executor, shallow-copies the solvers and parameters.
|
inline |
Move-constructs an IC preconditioner.
Inherits the executor, moves the solvers and parameters. The moved-from object is empty (0x0 with nullptr solvers and default parameters)
|
inlineoverridevirtual |
Returns a LinOp representing the conjugate transpose of the Transposable object.
Implements gko::Transposable.
Referenced by conj_transpose().
|
inline |
Returns the solver which is used for the provided L matrix.
Referenced by conj_transpose(), and transpose().
|
inline |
Returns the solver which is used for the L^H matrix.
Referenced by conj_transpose(), and transpose().
|
inline |
Copy-assigns an IC preconditioner.
Preserves the executor, shallow-copies the solvers and parameters. Creates a clone of the solvers if they are on the wrong executor.
|
inline |
Move-assigns an IC preconditioner.
Preserves the executor, moves the solvers and parameters. Creates a clone of the solvers if they are on the wrong executor. The moved-from object is empty (0x0 with nullptr solvers and default parameters)
|
inlinestatic |
Create the parameters from the property_tree.
Because this is directly tied to the specific type, the value/index type settings within config are ignored and type_descriptor is only used for children configs.
| config | the property tree for setting |
| context | the registry |
| td_for_child | the type descriptor for children configs. The default uses the value/index type of this class. When l_solver_type uses LinOp not concrete type, it will use the default_precision in ginkgo. |
|
inlineoverridevirtual |
Returns a LinOp representing the transpose of the Transposable object.
Implements gko::Transposable.
Referenced by transpose().