|
dune-istl 2.11
|
Accelerated flexible conjugate gradient method. More...
#include <dune/istl/solvers.hh>

Public Types | |
| typedef X | domain_type |
| Type of the domain of the operator to be inverted. | |
| typedef X | range_type |
| Type of the range of the operator to be inverted. | |
| typedef X::field_type | field_type |
| The field type of the operator. | |
| typedef FieldTraits< field_type >::real_type | real_type |
| The real type of the field type (is the same if using real numbers, but differs for std::complex). | |
| typedef Simd::Scalar< real_type > | scalar_real_type |
| scalar type underlying the field_type | |
Public Member Functions | |
| RestartedFCGSolver (const LinearOperator< X, X > &op, Preconditioner< X, X > &prec, scalar_real_type reduction, int maxit, int verbose, int mmax=10) | |
| Constructor to initialize a RestartedFCG solver. | |
| RestartedFCGSolver (const LinearOperator< X, X > &op, const ScalarProduct< X > &sp, Preconditioner< X, X > &prec, scalar_real_type reduction, int maxit, int verbose, int mmax=10) | |
| Constructor to initialize a RestartedFCG solver. | |
| RestartedFCGSolver (std::shared_ptr< const LinearOperator< X, X > > op, std::shared_ptr< const ScalarProduct< X > > sp, std::shared_ptr< Preconditioner< X, X > > prec, scalar_real_type reduction, int maxit, int verbose, int mmax=10) | |
| Constructor to initialize a RestartedFCG solver. | |
| RestartedFCGSolver (std::shared_ptr< const LinearOperator< X, X > > op, std::shared_ptr< Preconditioner< X, X > > prec, const ParameterTree &configuration) | |
| Constructor to initialize a RestartedFCG solver. | |
| RestartedFCGSolver (std::shared_ptr< const LinearOperator< X, X > > op, std::shared_ptr< const ScalarProduct< X > > sp, std::shared_ptr< Preconditioner< X, X > > prec, const ParameterTree &config) | |
| void | apply (X &x, X &b, InverseOperatorResult &res) override |
| Apply inverse operator. | |
| void | apply (X &x, X &b, double reduction, InverseOperatorResult &res) override |
| Apply inverse operator with given reduction factor. | |
| SolverCategory::Category | category () const override |
| Category of the solver (see SolverCategory::Category). | |
| std::string | name () const |
Protected Types | |
| using | Iteration = typename IterativeSolver<X,X>::template Iteration<unsigned int> |
| enum | |
Protected Member Functions | |
| void | printHeader (std::ostream &s) const |
| helper function for printing header of solver output | |
| void | printOutput (std::ostream &s, const CountType &iter, const DataType &norm, const DataType &norm_old) const |
| helper function for printing solver output | |
| void | printOutput (std::ostream &s, const CountType &iter, const DataType &norm) const |
| helper function for printing solver output | |
Protected Attributes | |
| int | _mmax |
| std::shared_ptr< const LinearOperator< X, X > > | _op |
| std::shared_ptr< Preconditioner< X, X > > | _prec |
| std::shared_ptr< const ScalarProduct< X > > | _sp |
| scalar_real_type | _reduction |
| int | _maxit |
| int | _verbose |
| SolverCategory::Category | _category |
Accelerated flexible conjugate gradient method.
Flexible conjugate gradient method as in Y. Notay 'Flexible conjugate Gradients', SIAM J. Sci. Comput Vol. 22, No.4, pp. 1444-1460
This solver discard cyclic all old directions to speed up computing. In exact arithmetic it is exactly the same as the GeneralizedPCGSolver, but it is much faster, depending on the operator and dimension. On the other hand for large mmax it uses noticeably more memory.
|
inherited |
Type of the domain of the operator to be inverted.
|
inherited |
The field type of the operator.
|
protected |
|
inherited |
Type of the range of the operator to be inverted.
|
inherited |
The real type of the field type (is the same if using real numbers, but differs for std::complex).
|
inherited |
scalar type underlying the field_type
|
protectedinherited |
|
inline |
Constructor to initialize a RestartedFCG solver.
| op | The operator we solve. |
| prec | The preconditioner to apply in each iteration of the loop. Has to inherit from Preconditioner. |
| reduction | The relative defect reduction to achieve when applying the operator. |
| maxit | The maximum number of iteration steps allowed when applying the operator. |
| verbose | The verbosity level. |
Verbose levels are:
| mmax | is the maximal number of previous vectors which are orthogonalized against the new search direction. |
|
inline |
Constructor to initialize a RestartedFCG solver.
| op | The operator we solve. |
| sp | The scalar product to use, e. g. SeqScalarproduct. |
| prec | The preconditioner to apply in each iteration of the loop. Has to inherit from Preconditioner. |
| reduction | The relative defect reduction to achieve when applying the operator. |
| maxit | The maximum number of iteration steps allowed when applying the operator. |
| verbose | The verbosity level. |
Verbose levels are:
| mmax | is the maximal number of previous vectors which are orthogonalized against the new search direction. |
|
inline |
Constructor to initialize a RestartedFCG solver.
| op | The operator we solve. |
| sp | The scalar product to use, e. g. SeqScalarproduct. |
| prec | The preconditioner to apply in each iteration of the loop. Has to inherit from Preconditioner. |
| reduction | The relative defect reduction to achieve when applying the operator. |
| maxit | The maximum number of iteration steps allowed when applying the operator. |
| verbose | The verbosity level. |
Verbose levels are:
| mmax | is the maximal number of previous vectors which are orthogonalized against the new search direction. |
|
inline |
Constructor to initialize a RestartedFCG solver.
Constructor.
| op | The operator we solve |
| prec | The preconditioner to apply in each iteration of the loop. |
| configuration | ParameterTree containing iterative solver parameters. |
| ParameterTree Key | Meaning |
|---|---|
| reduction | The relative defect reduction to achieve when applying the operator |
| maxit | The maximum number of iteration steps allowed when applying the operator |
| verbose | The verbosity level |
See ISTL_Factory for the ParameterTree layout and examples.
Additional parameter:
| ParameterTree Key | Meaning |
|---|---|
| mmax | number of FCG cycles before restart. default=10 |
See ISTL_Factory for the ParameterTree layout and examples.
|
inline |
|
inlineoverridevirtualinherited |
Apply inverse operator with given reduction factor.
apply inverse operator, with given convergence criteria.
| x | The left hand side to store the result in. |
| b | The right hand side |
| reduction | The minimum defect reduction to achieve. |
| res | Object to store the statistics about applying the operator. |
| SolverAbort | When the solver detects a problem and cannot continue |
Implements Dune::InverseOperator< X, X >.
|
inlineoverridevirtual |
Apply inverse operator.
Apply inverse operator,.
| x | The left hand side to store the result in. |
| b | The right hand side |
| res | Object to store the statistics about applying the operator. |
| SolverAbort | When the solver detects a problem and cannot continue |
Implements Dune::InverseOperator< X, X >.
|
inlineoverridevirtualinherited |
Category of the solver (see SolverCategory::Category).
Implements Dune::InverseOperator< X, X >.
|
inlineinherited |
|
inlineprotectedinherited |
helper function for printing header of solver output
|
inlineprotectedinherited |
helper function for printing solver output
|
inlineprotectedinherited |
helper function for printing solver output
|
protectedinherited |
|
protectedinherited |
|
protected |
|
protectedinherited |
|
protectedinherited |
|
protectedinherited |
|
protectedinherited |
|
protectedinherited |