GEOS
|
General 2x2 block preconditioner. More...
#include <BlockPreconditioner.hpp>
Public Types | |
using | Base = PreconditionerBase< LAI > |
Alias for the base type. | |
using | Vector = typename Base::Vector |
Alias for the vector type. | |
using | Matrix = typename Base::Matrix |
Alias for the matrix type. | |
Public Types inherited from geos::PreconditionerBase< LAI > | |
using | Base = LinearOperator< typename LAI::ParallelVector > |
Alias for base type. | |
using | Vector = typename Base::Vector |
Alias for vector type. | |
using | Matrix = typename LAI::ParallelMatrix |
Alias for matrix type. | |
Public Types inherited from geos::LinearOperator< LAI::ParallelVector > | |
using | Vector = LAI::ParallelVector |
Alias for template parameter. | |
Public Member Functions | |
BlockPreconditioner (BlockShapeOption const shapeOption, SchurComplementOption const schurOption, BlockScalingOption const scalingOption) | |
Constructor. More... | |
virtual | ~BlockPreconditioner () override |
Destructor. | |
void | setupBlock (localIndex const blockIndex, std::vector< DofManager::SubComponent > blockDofs, std::unique_ptr< PreconditionerBase< LAI > > solver, real64 const scaling=1.0) |
Setup data for one of the two blocks. More... | |
PreconditionerBase interface methods | |
virtual void | setup (Matrix const &mat) override |
Compute the preconditioner from a matrix. More... | |
virtual void | apply (Vector const &src, Vector &dst) const override |
Apply operator to a vector. More... | |
virtual void | clear () override |
Clean up the preconditioner setup. More... | |
Public Member Functions inherited from geos::PreconditionerBase< LAI > | |
virtual void | setup (Matrix const &mat) |
Compute the preconditioner from a matrix. More... | |
virtual globalIndex | numGlobalRows () const override |
Get the number of global rows. More... | |
virtual globalIndex | numGlobalCols () const override |
Get the number of global columns. More... | |
virtual localIndex | numLocalRows () const override |
Get the number of local rows. More... | |
virtual localIndex | numLocalCols () const override |
Get the number of local columns. More... | |
virtual MPI_Comm | comm () const override |
Get the MPI communicator the matrix was created with. More... | |
bool | ready () const |
Chech if preconditioner is ready to use. More... | |
Matrix const & | matrix () const |
Access the matrix the preconditioner was computed from. More... | |
virtual bool | hasPreconditionerMatrix () const |
Check whether the preconditioner is available in matrix (explicit) form. More... | |
virtual Matrix const & | preconditionerMatrix () const |
Access the preconditioner in matrix form (whenever available). It must be overridden by the specific preconditioner. More... | |
Public Member Functions inherited from geos::LinearOperator< LAI::ParallelVector > | |
LinearOperator ()=default | |
Constructor. | |
virtual | ~LinearOperator ()=default |
Destructor. | |
virtual void | apply (Vector const &src, Vector &dst) const=0 |
Apply operator to a vector, dst = this(src) . More... | |
virtual void | residual (Vector const &x, Vector const &b, Vector &r) const |
Compute residual r = b - this(x) . More... | |
General 2x2 block preconditioner.
LAI | type of linear algebra interface providing matrix/vector types |
Definition at line 101 of file BlockPreconditioner.hpp.
|
explicit |
Constructor.
shapeOption | preconditioner block shape |
schurOption | type of Schur complement approximation to use |
scalingOption | type of scaling to apply to blocks |
|
overridevirtual |
Apply operator to a vector.
src | Input vector (x). |
dst | Output vector (b). |
src
and dst
cannot alias the same vector (some implementations may allow this).
|
overridevirtual |
Clean up the preconditioner setup.
Releases memory used and allows the matrix to be deleted cleanly. This method should be called before the matrix used to compute the preconditioner goes out of scope or is re-created. Some implementations require the matrix to outlive the preconditioner (for example, Trilinos/ML may crash the program if deleted after the matrix).
Reimplemented from geos::PreconditionerBase< LAI >.
|
overridevirtual |
Compute the preconditioner from a matrix.
mat | the matrix to precondition |
void geos::BlockPreconditioner< LAI >::setupBlock | ( | localIndex const | blockIndex, |
std::vector< DofManager::SubComponent > | blockDofs, | ||
std::unique_ptr< PreconditionerBase< LAI > > | solver, | ||
real64 const | scaling = 1.0 |
||
) |
Setup data for one of the two blocks.
blockIndex | index of the block to set up |
blockDofs | choice of DoF components (from a monolithic system) |
solver | instance of the inner preconditioner for the block |
scaling | user-provided row scaling coefficient for this block |
blockDofs
of the two blocks are non-overlapping and their union includes all DoF components in the monolithic system.