Dune Core Modules (2.5.0)
Preconditioned loop solver. More...
#include <dune/istl/solvers.hh>
Public Types | |
typedef X | domain_type |
The domain type of the operator that we do the inverse for. | |
typedef X | range_type |
The range type of the operator that we do the inverse for. | |
typedef X::field_type | field_type |
The field type of the operator that we do the inverse for. | |
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) | |
Public Member Functions | |
template<class L , class P > | |
LoopSolver (L &op, P &prec, real_type reduction, int maxit, int verbose) | |
Set up Loop solver. More... | |
template<class L , class S , class P > | |
LoopSolver (L &op, S &sp, P &prec, real_type reduction, int maxit, int verbose) | |
Set up loop solver. More... | |
virtual void | apply (X &x, X &b, InverseOperatorResult &res) |
Apply inverse operator,. More... | |
virtual void | apply (X &x, X &b, double reduction, InverseOperatorResult &res) |
apply inverse operator, with given convergence criteria. More... | |
Detailed Description
class Dune::LoopSolver< X >
Preconditioned loop solver.
Implements a preconditioned loop. Using this class every Preconditioner can be turned into a solver. The solver will apply one preconditioner step in each iteration loop.
Constructor & Destructor Documentation
◆ LoopSolver() [1/2]
|
inline |
Set up Loop solver.
- Parameters
-
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:
- 0 : print nothing
- 1 : print initial and final defect and statistics
- 2 : print line for each iteration
References Dune::SolverCategory::sequential.
◆ LoopSolver() [2/2]
|
inline |
Set up loop solver.
- Parameters
-
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:
- 0 : print nothing
- 1 : print initial and final defect and statistics
- 2 : print line for each iteration
Member Function Documentation
◆ apply() [1/2]
|
inlinevirtual |
apply inverse operator, with given convergence criteria.
- Warning
- Right hand side b may be overwritten!
- Parameters
-
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.
- Exceptions
-
SolverAbort When the solver detects a problem and cannot continue
Implements Dune::InverseOperator< X, X >.
◆ apply() [2/2]
|
inlinevirtual |
Apply inverse operator,.
- Warning
- Note: right hand side b may be overwritten!
- Parameters
-
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.
- Exceptions
-
SolverAbort When the solver detects a problem and cannot continue
Implements Dune::InverseOperator< X, X >.
References Dune::Preconditioner< X, Y >::apply(), Dune::LinearOperator< X, Y >::applyscaleadd(), Dune::InverseOperatorResult::clear(), Dune::InverseOperatorResult::conv_rate, Dune::InverseOperatorResult::converged, Dune::Timer::elapsed(), Dune::InverseOperatorResult::elapsed, Dune::InverseOperatorResult::iterations, Dune::Preconditioner< X, Y >::post(), Dune::Preconditioner< X, Y >::pre(), Dune::InverseOperator< X, X >::printHeader(), Dune::InverseOperator< X, X >::printOutput(), and Dune::InverseOperatorResult::reduction.
The documentation for this class was generated from the following file:
- dune/istl/solvers.hh