An interface to allow SuperLU to be used as an (exact) Preconditioner. More...
#include <SuperLU_preconditioner.h>
Public Member Functions | |
SuperLUPreconditioner () | |
Constructor. More... | |
~SuperLUPreconditioner () | |
Destructor. More... | |
SuperLUPreconditioner (const SuperLUPreconditioner &)=delete | |
Broken copy constructor. More... | |
void | operator= (const SuperLUPreconditioner &)=delete |
Broken assignment operator. More... | |
void | setup () |
Function to set up a preconditioner for the linear system defined by matrix_pt. This function must be called before using preconditioner_solve. Note: matrix_pt must point to an object of class CRDoubleMatrix or CCDoubleMatrix. More... | |
void | preconditioner_solve (const DoubleVector &r, DoubleVector &z) |
Function applies SuperLU to vector r for (exact) preconditioning, this requires a call to setup(...) first. More... | |
void | preconditioner_solve_transpose (const DoubleVector &r, DoubleVector &z) |
Function applies SuperLU to vector r for (exact) preconditioning (of the transposed matrix system) this requires a call to setup(...) first. More... | |
virtual void | clean_up_memory () |
Clean up memory – forward the call to the version in SuperLU in its LinearSolver incarnation. More... | |
double | get_memory_usage_for_lu_factors () |
Get the amount of memory used to store the LU factors inside SuperLU. More... | |
double | get_total_memory_needed_for_superlu () |
Get the total memory needed by SuperLU to store AND calculate the LU factors. More... | |
Vector< double > | get_memory_usage_for_superlu () |
Get the amount of memory taken up by SuperLU. The first entry of the returned result contains the memory used to store the LU factors and the second entry contains the total memory used to store AND calculate the LU factors. More... | |
void | enable_doc_stats () |
Enable documentation of solver statistics. More... | |
void | disable_doc_stats () |
Enable documentation of solver statistics. More... | |
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... | |
void | setup (DoubleMatrixBase *matrix_pt) |
Setup the preconditioner: store the matrix pointer and the communicator pointer then call preconditioner specific setup() function. More... | |
void | setup (const Problem *problem_pt, DoubleMatrixBase *matrix_pt) |
Compatability layer for old preconditioners where problem pointers were needed. The problem pointer is only used to get a communicator pointer. More... | |
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 interface function for making a preconditioner a subsidiary of a block preconditioner. By default nothing is needed, but if this preconditioner is also a block preconditioner then things need to happen. There's an assumption here that the block preconditioner will be in CR form but since that assumption is hard coded all over BlockPreconditioner we're safe. More... | |
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) |
Virtual interface function for making a preconditioner a subsidiary of a block preconditioner. By default nothing is needed, but if this preconditioner is also a block preconditioner then things need to happen. Version for coarsening dof-types. More... | |
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 |
if the communicator_pt is null then the distribution is not setup then false is returned, otherwise return true More... | |
void | build_distribution (const LinearAlgebraDistribution *const dist_pt) |
setup the distribution of this distributable linear algebra object More... | |
void | build_distribution (const LinearAlgebraDistribution &dist) |
setup the distribution of this distributable linear algebra object More... | |
Private Attributes | |
SuperLUSolver | Solver |
the SuperLU solver emplyed by this preconditioner More... | |
Additional Inherited Members | |
Protected Member Functions inherited from oomph::DistributableLinearAlgebraObject | |
void | clear_distribution () |
clear the distribution of this distributable linear algebra object More... | |
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... | |
An interface to allow SuperLU to be used as an (exact) Preconditioner.
Definition at line 39 of file SuperLU_preconditioner.h.
|
inline |
Constructor.
Definition at line 43 of file SuperLU_preconditioner.h.
References oomph::SuperLUSolver::disable_doc_stats(), oomph::LinearSolver::disable_doc_time(), and Solver.
|
inline |
Destructor.
Definition at line 50 of file SuperLU_preconditioner.h.
|
delete |
Broken copy constructor.
|
inlinevirtual |
Clean up memory – forward the call to the version in SuperLU in its LinearSolver incarnation.
Reimplemented from oomph::Preconditioner.
Definition at line 106 of file SuperLU_preconditioner.h.
References oomph::SuperLUSolver::clean_up_memory(), and Solver.
|
inline |
Enable documentation of solver statistics.
Definition at line 158 of file SuperLU_preconditioner.h.
References oomph::SuperLUSolver::disable_doc_stats(), and Solver.
|
inline |
Enable documentation of solver statistics.
Definition at line 151 of file SuperLU_preconditioner.h.
References oomph::SuperLUSolver::enable_doc_stats(), and Solver.
|
inline |
Get the amount of memory used to store the LU factors inside SuperLU.
Definition at line 113 of file SuperLU_preconditioner.h.
References oomph::SuperLUSolver::get_memory_usage_for_lu_factors(), and Solver.
|
inline |
Get the amount of memory taken up by SuperLU. The first entry of the returned result contains the memory used to store the LU factors and the second entry contains the total memory used to store AND calculate the LU factors.
Definition at line 133 of file SuperLU_preconditioner.h.
References oomph::SuperLUSolver::get_memory_usage_for_lu_factors(), oomph::SuperLUSolver::get_total_needed_memory(), and Solver.
|
inline |
Get the total memory needed by SuperLU to store AND calculate the LU factors.
Definition at line 122 of file SuperLU_preconditioner.h.
References oomph::SuperLUSolver::get_total_needed_memory(), and Solver.
|
delete |
Broken assignment operator.
|
inlinevirtual |
Function applies SuperLU to vector r for (exact) preconditioning, this requires a call to setup(...) first.
Implements oomph::Preconditioner.
Definition at line 90 of file SuperLU_preconditioner.h.
References oomph::SuperLUSolver::resolve(), and Solver.
|
inlinevirtual |
Function applies SuperLU to vector r for (exact) preconditioning (of the transposed matrix system) this requires a call to setup(...) first.
Reimplemented from oomph::Preconditioner.
Definition at line 98 of file SuperLU_preconditioner.h.
References oomph::SuperLUSolver::resolve_transpose(), and Solver.
|
inlinevirtual |
Function to set up a preconditioner for the linear system defined by matrix_pt. This function must be called before using preconditioner_solve. Note: matrix_pt must point to an object of class CRDoubleMatrix or CCDoubleMatrix.
Implements oomph::Preconditioner.
Definition at line 63 of file SuperLU_preconditioner.h.
References oomph::DistributableLinearAlgebraObject::build_distribution(), oomph::DistributableLinearAlgebraObject::distribution_pt(), oomph::SuperLUSolver::factorise(), oomph::Preconditioner::matrix_pt(), oomph::oomph_info, and Solver.
Referenced by oomph::SimpleFSIPreconditioner< MATRIX >::setup().
|
private |
the SuperLU solver emplyed by this preconditioner
Definition at line 167 of file SuperLU_preconditioner.h.
Referenced by clean_up_memory(), disable_doc_stats(), enable_doc_stats(), get_memory_usage_for_lu_factors(), get_memory_usage_for_superlu(), get_total_memory_needed_for_superlu(), preconditioner_solve(), preconditioner_solve_transpose(), setup(), and SuperLUPreconditioner().