![]() |
|
Base class for Trilinos preconditioners as oomph-lib preconditioner. More...
#include <trilinos_preconditioners.h>
Inheritance diagram for oomph::TrilinosPreconditionerBase:Public Member Functions | |
| TrilinosPreconditionerBase () | |
| Constructor. More... | |
| virtual | ~TrilinosPreconditionerBase () |
| Destructor. More... | |
| void | clean_up_memory () |
| deletes the preconditioner, matrices and maps More... | |
| TrilinosPreconditionerBase (const TrilinosPreconditionerBase &)=delete | |
| Broken copy constructor. More... | |
| void | setup () |
| Broken assignment operator. More... | |
| void | setup (Epetra_CrsMatrix *epetra_matrix_pt) |
| void | preconditioner_solve (const DoubleVector &r, DoubleVector &z) |
| applies the preconditioner More... | |
| Epetra_Operator *& | epetra_operator_pt () |
| Epetra_Operator * | epetra_operator_pt () const |
Public Member Functions inherited from oomph::Preconditioner | |
| Preconditioner () | |
| Constructor. More... | |
| Preconditioner (const Preconditioner &)=delete | |
| Broken copy constructor. More... | |
| void | operator= (const Preconditioner &)=delete |
| Broken assignment operator. More... | |
| virtual | ~Preconditioner () |
| Destructor (empty) More... | |
| virtual void | preconditioner_solve_transpose (const DoubleVector &r, DoubleVector &z) |
| void | setup (DoubleMatrixBase *matrix_pt) |
| void | setup (const Problem *problem_pt, DoubleMatrixBase *matrix_pt) |
| void | enable_silent_preconditioner_setup () |
| Set up the block preconditioner quietly! More... | |
| void | disable_silent_preconditioner_setup () |
| Be verbose in the block preconditioner setup. More... | |
| virtual DoubleMatrixBase * | matrix_pt () const |
| Get function for matrix pointer. More... | |
| virtual void | set_matrix_pt (DoubleMatrixBase *matrix_pt) |
| Set the matrix pointer. More... | |
| virtual const OomphCommunicator * | comm_pt () const |
| Get function for comm pointer. More... | |
| virtual void | set_comm_pt (const OomphCommunicator *const comm_pt) |
| Set the communicator pointer. More... | |
| double | setup_time () const |
| Returns the time to setup the preconditioner. More... | |
| virtual void | turn_into_subsidiary_block_preconditioner (BlockPreconditioner< CRDoubleMatrix > *master_block_prec_pt, const Vector< unsigned > &doftype_in_master_preconditioner_coarse) |
| virtual void | turn_into_subsidiary_block_preconditioner (BlockPreconditioner< CRDoubleMatrix > *master_block_prec_pt, const Vector< unsigned > &doftype_in_master_preconditioner_coarse, const Vector< Vector< unsigned >> &doftype_coarsen_map_coarse) |
Public Member Functions inherited from oomph::DistributableLinearAlgebraObject | |
| DistributableLinearAlgebraObject () | |
| Default constructor - create a distribution. More... | |
| DistributableLinearAlgebraObject (const DistributableLinearAlgebraObject &matrix)=delete | |
| Broken copy constructor. More... | |
| void | operator= (const DistributableLinearAlgebraObject &)=delete |
| Broken assignment operator. More... | |
| virtual | ~DistributableLinearAlgebraObject () |
| Destructor. More... | |
| LinearAlgebraDistribution * | distribution_pt () const |
| access to the LinearAlgebraDistribution More... | |
| unsigned | nrow () const |
| access function to the number of global rows. More... | |
| unsigned | nrow_local () const |
| access function for the num of local rows on this processor. More... | |
| unsigned | nrow_local (const unsigned &p) const |
| access function for the num of local rows on this processor. More... | |
| unsigned | first_row () const |
| access function for the first row on this processor More... | |
| unsigned | first_row (const unsigned &p) const |
| access function for the first row on this processor More... | |
| bool | distributed () const |
| distribution is serial or distributed More... | |
| bool | distribution_built () const |
| void | build_distribution (const LinearAlgebraDistribution *const dist_pt) |
| void | build_distribution (const LinearAlgebraDistribution &dist) |
Static Public Attributes | |
| static double | Cumulative_preconditioner_solve_time = 0.0 |
Protected Member Functions | |
| virtual void | setup_trilinos_preconditioner (Epetra_CrsMatrix *epetra_matrix_pt)=0 |
Protected Member Functions inherited from oomph::DistributableLinearAlgebraObject | |
| void | clear_distribution () |
Protected Attributes | |
| Epetra_Operator * | Epetra_preconditioner_pt |
| Epetra_CrsMatrix * | Epetra_matrix_pt |
Protected Attributes inherited from oomph::Preconditioner | |
| bool | Silent_preconditioner_setup |
| Boolean to indicate whether or not the build should be done silently. More... | |
| std::ostream * | Stream_pt |
| Pointer to the output stream – defaults to std::cout. More... | |
Base class for Trilinos preconditioners as oomph-lib preconditioner.
|
inline |
Constructor.
References Epetra_matrix_pt, and Epetra_preconditioner_pt.
|
inlinevirtual |
Destructor.
References clean_up_memory().
|
delete |
Broken copy constructor.
|
inlinevirtual |
deletes the preconditioner, matrices and maps
Reimplemented from oomph::Preconditioner.
References Epetra_matrix_pt, and Epetra_preconditioner_pt.
Referenced by setup(), and ~TrilinosPreconditionerBase().
|
inline |
Access function to Epetra_preconditioner_pt. For use with TrilinosAztecOOSolver
References Epetra_preconditioner_pt.
Referenced by oomph::TrilinosAztecOOSolver::solver_setup().
|
inline |
Access function to Epetra_preconditioner_pt (const version) For use with TrilinosAztecOOSolver
References Epetra_preconditioner_pt.
|
virtual |
applies the preconditioner
preconditioner_solve - applies the preconditioner to the vector r taking distributed oomph-lib vectors (DistributedVector<double>) as arguments.
Implements oomph::Preconditioner.
References oomph::DoubleVector::build(), oomph::TrilinosEpetraHelpers::copy_to_oomphlib_vector(), oomph::TrilinosEpetraHelpers::create_distributed_epetra_vector(), Cumulative_preconditioner_solve_time, oomph::DistributableLinearAlgebraObject::distribution_pt(), Epetra_preconditioner_pt, OOMPH_CURRENT_FUNCTION, OOMPH_EXCEPTION_LOCATION, UniformPSDSelfTest::r, and oomph::TimingHelpers::timer().
|
virtual |
Broken assignment operator.
Function to set up a preconditioner for the linear system defined by matrix_pt. This function must be called before using preconditioner_solve. NOTE 1. matrix_pt must point to an object of class CRDoubleMatrix or DistributedCRDoubleMatrix This method should be called by oomph-lib solvers and preconditioners
Implements oomph::Preconditioner.
References oomph::DistributableLinearAlgebraObject::build_distribution(), clean_up_memory(), oomph::TrilinosEpetraHelpers::create_distributed_epetra_matrix(), oomph::DistributableLinearAlgebraObject::distribution_pt(), Epetra_matrix_pt, oomph::Preconditioner::matrix_pt(), oomph::DoubleMatrixBase::ncol(), oomph::DistributableLinearAlgebraObject::nrow(), oomph::DoubleMatrixBase::nrow(), OOMPH_CURRENT_FUNCTION, OOMPH_EXCEPTION_LOCATION, and setup_trilinos_preconditioner().
Referenced by oomph::TrilinosAztecOOSolver::solver_setup().
| void oomph::TrilinosPreconditionerBase::setup | ( | Epetra_CrsMatrix * | epetra_matrix_pt | ) |
Function to setup a preconditioner for the linear system defined by the oomph-lib oomph_matrix_pt and Epetra epetra_matrix_pt matrices. This method is called by Trilinos solvers.
References clean_up_memory(), oomph::Preconditioner::matrix_pt(), OOMPH_CURRENT_FUNCTION, OOMPH_EXCEPTION_LOCATION, and setup_trilinos_preconditioner().
|
protectedpure virtual |
Function to set up a specific Trilinos preconditioner. This is called by setup(...).
Implemented in oomph::TrilinosIFPACKPreconditioner, and oomph::TrilinosMLPreconditioner.
Referenced by setup().
|
static |
Static double that accumulates the preconditioner solve time of all instantiations of this class. Reset it manually, e.g. after every Newton solve.
//////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////// Static double that accumulates the preconditioner solve time of all instantiations of this class. Reset it manually, e.g. after every Newton solve.
Referenced by preconditioner_solve().
|
protected |
Pointer used to store the epetra matrix - only used when this preconditioner is setup using the oomph-lib interface
Referenced by clean_up_memory(), setup(), and TrilinosPreconditionerBase().
|
protected |
The preconditioner which will be set up using function setup_trilinos_preconditioner(...)
Referenced by clean_up_memory(), epetra_operator_pt(), preconditioner_solve(), oomph::TrilinosMLPreconditioner::setup_trilinos_preconditioner(), oomph::TrilinosIFPACKPreconditioner::setup_trilinos_preconditioner(), and TrilinosPreconditionerBase().