|
opm-simulators
|
Provides the common code which is required by most linear solvers. More...
#include <parallelbasebackend.hh>
Public Member Functions | |
| ParallelBaseBackend (const Simulator &simulator) | |
| void | eraseMatrix () |
| Causes the solve() method to discared the structure of the linear system of equations the next time it is called. | |
| void | prepare (const SparseMatrixAdapter &M, const Vector &) |
| Set up the internal data structures required for the linear solver. More... | |
| void | setResidual (const Vector &b) |
| Assign values to the internal data structure for the residual vector. More... | |
| void | getResidual (Vector &b) const |
| Retrieve the synchronized internal residual vector. More... | |
| void | setMatrix (const SparseMatrixAdapter &M) |
| Sets the values of the residual's Jacobian matrix. More... | |
| bool | solve (Vector &x) |
| Actually solve the linear system of equations. More... | |
| size_t | iterations () const |
| Return number of iterations used during last solve. | |
Static Public Member Functions | |
| static void | registerParameters () |
| Register all run-time parameters for the linear solver. | |
Protected Types | |
| enum | { dimWorld = GridView::dimensionworld } |
| using | Implementation = GetPropType< TypeTag, Properties::LinearSolverBackend > |
| using | Simulator = GetPropType< TypeTag, Properties::Simulator > |
| using | Scalar = GetPropType< TypeTag, Properties::Scalar > |
| using | LinearSolverScalar = GetPropType< TypeTag, Properties::LinearSolverScalar > |
| using | SparseMatrixAdapter = GetPropType< TypeTag, Properties::SparseMatrixAdapter > |
| using | Vector = GetPropType< TypeTag, Properties::GlobalEqVector > |
| using | BorderListCreator = GetPropType< TypeTag, Properties::BorderListCreator > |
| using | GridView = GetPropType< TypeTag, Properties::GridView > |
| using | Overlap = GetPropType< TypeTag, Properties::Overlap > |
| using | OverlappingVector = GetPropType< TypeTag, Properties::OverlappingVector > |
| using | OverlappingMatrix = GetPropType< TypeTag, Properties::OverlappingMatrix > |
| using | PreconditionerWrapper = GetPropType< TypeTag, Properties::PreconditionerWrapper > |
| using | SequentialPreconditioner = typename PreconditionerWrapper::SequentialPreconditioner |
| using | ParallelPreconditioner = Opm::Linear::OverlappingPreconditioner< SequentialPreconditioner, Overlap > |
| using | ParallelScalarProduct = Opm::Linear::OverlappingScalarProduct< OverlappingVector, Overlap > |
| using | ParallelOperator = Opm::Linear::OverlappingOperator< OverlappingMatrix, OverlappingVector, OverlappingVector > |
Protected Member Functions | |
| Implementation & | asImp_ () |
| const Implementation & | asImp_ () const |
| void | cleanup_ () |
| std::shared_ptr< ParallelPreconditioner > | preparePreconditioner_ () |
| void | cleanupPreconditioner_ () |
| void | writeOverlapToVTK_ () |
Provides the common code which is required by most linear solvers.
This class provides access to all preconditioners offered by dune-istl using the PreconditionerWrapper property:
Where the choices possible for '$PRECONDITIONER' are:
Jacobi: A Jacobi preconditionerGaussSeidel: A Gauss-Seidel preconditionerSSOR: A symmetric successive overrelaxation (SSOR) preconditionerSOR: A successive overrelaxation (SOR) preconditionerILUn: An ILU(n) preconditionerILU0: An ILU(0) preconditioner. The results of this preconditioner are the same as setting the PreconditionerOrder property to 0 and using the ILU(n) preconditioner. The reason for the existence of ILU0 is that it is computationally cheaper because it does not need to consider things which are only required for higher orders
|
inline |
Retrieve the synchronized internal residual vector.
This only deals with entries which are local to the current process.
|
inline |
Set up the internal data structures required for the linear solver.
This only specified the topology of the linear system of equations; it does does not assign the values of the residual vector and its Jacobian matrix.
|
inline |
Sets the values of the residual's Jacobian matrix.
This method also synchronizes the data structure across the processes which are involved in the simulation run.
|
inline |
Assign values to the internal data structure for the residual vector.
This method also cares about synchronizing that vector with the peer processes.
|
inline |
Actually solve the linear system of equations.