|  | Ginkgo Generated from  branch based on master. Ginkgo version 1.8.0
    A numerical linear algebra library targeting many-core architectures | 
Cg or the Conjugate Gradient is a Krylov subspace solver. More...
#include <ginkgo/core/solver/batch_cg.hpp>
| Classes | |
| class | Factory | 
| struct | parameters_type | 
| Public Types | |
| using | value_type = ValueType | 
| using | real_type = gko::remove_complex<ValueType> | 
|  Public Types inherited from gko::batch::solver::EnableBatchSolver< Cg< default_precision >, default_precision > | |
| using | real_type | 
|  Public Types inherited from gko::EnablePolymorphicAssignment< Cg< default_precision > > | |
| using | result_type | 
|  Public Types inherited from gko::ConvertibleTo< Cg< default_precision > > | |
| using | result_type | 
| Public Member Functions | |
| const parameters_type & | get_parameters () const | 
|  Public Member Functions inherited from gko::batch::solver::EnableBatchSolver< Cg< default_precision >, default_precision > | |
| const Cg< default_precision > * | apply (ptr_param< const MultiVector< default_precision > > b, ptr_param< MultiVector< default_precision > > x) const | 
| const Cg< default_precision > * | apply (ptr_param< const MultiVector< default_precision > > alpha, ptr_param< const MultiVector< default_precision > > b, ptr_param< const MultiVector< default_precision > > beta, ptr_param< MultiVector< default_precision > > x) const | 
| Cg< default_precision > * | apply (ptr_param< const MultiVector< default_precision > > b, ptr_param< MultiVector< default_precision > > x) | 
| Cg< default_precision > * | apply (ptr_param< const MultiVector< default_precision > > alpha, ptr_param< const MultiVector< default_precision > > b, ptr_param< const MultiVector< default_precision > > beta, ptr_param< MultiVector< default_precision > > x) | 
|  Public Member Functions inherited from gko::batch::solver::BatchSolver | |
| std::shared_ptr< const BatchLinOp > | get_system_matrix () const | 
| Returns the system operator (matrix) of the linear system. | |
| std::shared_ptr< const BatchLinOp > | get_preconditioner () const | 
| Returns the generated preconditioner. | |
| double | get_tolerance () const | 
| Get the residual tolerance used by the solver. | |
| void | reset_tolerance (double res_tol) | 
| Update the residual tolerance to be used by the solver. | |
| int | get_max_iterations () const | 
| Get the maximum number of iterations set on the solver. | |
| void | reset_max_iterations (int max_iterations) | 
| Set the maximum number of iterations for the solver to use, independent of the factory that created it. | |
| ::gko::batch::stop::tolerance_type | get_tolerance_type () const | 
| Get the tolerance type. | |
| void | reset_tolerance_type (::gko::batch::stop::tolerance_type tol_type) | 
| Set the type of tolerance check to use inside the solver. | |
|  Public Member Functions inherited from gko::EnableAbstractPolymorphicObject< Cg< default_precision >, BatchLinOp > | |
| std::unique_ptr< Cg< default_precision > > | create_default (std::shared_ptr< const Executor > exec) const | 
| std::unique_ptr< Cg< default_precision > > | create_default () const | 
| std::unique_ptr< Cg< default_precision > > | clone (std::shared_ptr< const Executor > exec) const | 
| std::unique_ptr< Cg< default_precision > > | clone () const | 
| Cg< default_precision > * | copy_from (const PolymorphicObject *other) | 
| std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, Cg< default_precision > > * | copy_from (std::unique_ptr< Derived > &&other) | 
| std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, Cg< default_precision > > * | copy_from (const std::unique_ptr< Derived > &other) | 
| Cg< default_precision > * | copy_from (const std::shared_ptr< const PolymorphicObject > &other) | 
| Cg< default_precision > * | move_from (ptr_param< PolymorphicObject > other) | 
| Cg< default_precision > * | clear () | 
|  Public Member Functions inherited from gko::EnablePolymorphicAssignment< Cg< default_precision > > | |
| void | convert_to (result_type *result) const override | 
| void | move_to (result_type *result) override | 
|  Public Member Functions inherited from gko::ConvertibleTo< Cg< default_precision > > | |
| void | convert_to (ptr_param< result_type > result) const | 
| void | move_to (ptr_param< result_type > result) | 
| Static Public Member Functions | |
| static auto | build () -> decltype(Factory::create()) | 
| Friends | |
| class | EnableBatchLinOp< Cg > | 
| class | EnablePolymorphicObject< Cg, BatchLinOp > | 
Cg or the Conjugate Gradient is a Krylov subspace solver.
It is a short recurrence solver that is generally used to solve linear systems with SPD matrices.
This solver solves a batch of linear systems using the Cg algorithm. Each linear system in the batch can converge independently.
Unless otherwise specified via the preconditioner factory parameter, this implementation does not use any preconditioner by default. The type of tolerance (absolute or relative) and the maximum number of iterations to be used in the stopping criterion can be set via the factory parameters.
| ValueType | precision of matrix elements |