IBAMR
An adaptive and distributed-memory parallel implementation of the immersed boundary (IB) method
|
Class GeneralSolver provides an abstract interface for the implementation of linear or nonlinear solvers for systems of equations defined on an AMR patch hierarchy. More...
#include </home/runner/work/IBAMR/IBAMR/ibtk/include/ibtk/GeneralSolver.h>
Public Member Functions | |
GeneralSolver ()=default | |
Constructor. | |
virtual | ~GeneralSolver ()=default |
Empty virtual destructor. | |
General-purpose solver functionality. | |
const std::string & | getName () const |
Return the object name. | |
virtual bool | getIsInitialized () const |
Return whether the operator is initialized. | |
virtual void | setHomogeneousBc (bool homogeneous_bc) |
Set whether the solver should use homogeneous boundary conditions. | |
virtual bool | getHomogeneousBc () const |
Return whether the solver is using homogeneous boundary conditions. | |
virtual void | setSolutionTime (double solution_time) |
Set the time at which the solution is to be evaluated. | |
virtual double | getSolutionTime () const |
Get the time at which the solution is being evaluated. | |
virtual void | setTimeInterval (double current_time, double new_time) |
Set the current time interval. | |
virtual std::pair< double, double > | getTimeInterval () const |
Get the current time interval. | |
virtual double | getDt () const |
Get the current time step size. | |
virtual void | setHierarchyMathOps (SAMRAI::tbox::Pointer< HierarchyMathOps > hier_math_ops) |
Set the HierarchyMathOps object used by the solver. | |
virtual SAMRAI::tbox::Pointer< HierarchyMathOps > | getHierarchyMathOps () const |
Get the HierarchyMathOps object used by the solver. | |
virtual bool | solveSystem (SAMRAI::solv::SAMRAIVectorReal< NDIM, double > &x, SAMRAI::solv::SAMRAIVectorReal< NDIM, double > &b)=0 |
Solve the system of equations. More... | |
virtual void | initializeSolverState (const SAMRAI::solv::SAMRAIVectorReal< NDIM, double > &x, const SAMRAI::solv::SAMRAIVectorReal< NDIM, double > &b) |
Compute hierarchy dependent data required for solving . More... | |
virtual void | deallocateSolverState () |
Remove all hierarchy dependent data allocated by initializeSolverState(). More... | |
Functions to access solver parameters. | |
virtual void | setMaxIterations (int max_iterations) |
Set the maximum number of nonlinear iterations to use per solve. | |
virtual int | getMaxIterations () const |
Get the maximum number of nonlinear iterations to use per solve. | |
virtual void | setAbsoluteTolerance (double abs_residual_tol) |
Set the absolute residual tolerance for convergence. | |
virtual double | getAbsoluteTolerance () const |
Get the absolute residual tolerance for convergence. | |
virtual void | setRelativeTolerance (double rel_residual_tol) |
Set the relative residual tolerance for convergence. | |
virtual double | getRelativeTolerance () const |
Get the relative residual tolerance for convergence. | |
Functions to access data on the most recent solve. | |
virtual int | getNumIterations () const |
Return the iteration count from the most recent solve. | |
virtual double | getResidualNorm () const |
Return the residual norm from the most recent iteration. | |
Logging functions. | |
std::string | d_object_name = "unitialized" |
bool | d_is_initialized = false |
bool | d_homogeneous_bc = false |
double | d_solution_time = std::numeric_limits<double>::quiet_NaN() |
double | d_current_time = std::numeric_limits<double>::quiet_NaN() |
double | d_new_time = std::numeric_limits<double>::quiet_NaN() |
double | d_rel_residual_tol = 0.0 |
double | d_abs_residual_tol = 0.0 |
int | d_max_iterations = 100 |
int | d_current_iterations = 0 |
double | d_current_residual_norm = std::numeric_limits<double>::quiet_NaN() |
SAMRAI::tbox::Pointer< HierarchyMathOps > | d_hier_math_ops |
bool | d_hier_math_ops_external = false |
bool | d_enable_logging = false |
virtual void | setLoggingEnabled (bool enable_logging=true) |
Enable or disable logging. | |
virtual bool | getLoggingEnabled () const |
Determine whether logging is enabled or disabled. | |
virtual void | printClassData (std::ostream &stream) |
Print class data to stream. | |
void | init (const std::string &object_name, bool homogeneous_bc) |
virtual void | initSpecialized (const std::string &object_name, bool homogeneous_bc) |
Class GeneralSolver provides an abstract interface for the implementation of linear or nonlinear solvers for systems of equations defined on an AMR patch hierarchy.
|
virtual |
Remove all hierarchy dependent data allocated by initializeSolverState().
Reimplemented in IBAMR::VCStaggeredStokesProjectionPreconditioner, IBAMR::StaggeredStokesProjectionPreconditioner, IBAMR::StaggeredStokesBlockPreconditioner, IBAMR::StaggeredStokesBlockFactorizationPreconditioner, IBAMR::CIBStaggeredStokesSolver, IBTK::SCPoissonHypreLevelSolver, IBTK::PETScPCLSWrapper, IBTK::PETScNewtonKrylovSolver, IBTK::PETScLevelSolver, IBTK::PETScKrylovLinearSolver, IBTK::FACPreconditioner, IBTK::CCPoissonHypreLevelSolver, IBTK::BJacobiPreconditioner, and IBTK::BGaussSeidelPreconditioner.
|
virtual |
Compute hierarchy dependent data required for solving .
In a typical implementation, the solveSystem() method will compute some required hierarchy dependent data before the solve, and then remove that data after the solve. For multiple solves that use the same hierarchy configuration, it is more efficient to:
Note that it is generally necessary to reinitialize the solver state when the hierarchy configuration changes.
x | solution vector |
b | right-hand-side vector |
Conditions on Parameters:
Reimplemented in IBAMR::VCStaggeredStokesProjectionPreconditioner, IBAMR::StaggeredStokesProjectionPreconditioner, IBAMR::StaggeredStokesBlockPreconditioner, IBAMR::StaggeredStokesBlockFactorizationPreconditioner, IBAMR::CIBStaggeredStokesSolver, IBTK::SCPoissonHypreLevelSolver, IBTK::PETScPCLSWrapper, IBTK::PETScNewtonKrylovSolver, IBTK::PETScLevelSolver, IBTK::PETScKrylovLinearSolver, IBTK::FACPreconditioner, IBTK::CCPoissonHypreLevelSolver, IBTK::BJacobiPreconditioner, and IBTK::BGaussSeidelPreconditioner.
|
pure virtual |
Solve the system of equations.
Before calling solveSystem(), the form of the solution x and right-hand-side b vectors must be set properly by the user on all patch interiors on the specified range of levels in the patch hierarchy. The user is responsible for all data management for the quantities associated with the solution and right-hand-side vectors. In particular, patch data in these vectors must be allocated prior to calling this method.
x | solution vector |
b | right-hand-side vector |
Conditions on Parameters:
true
if the solver converged to the specified tolerances, false
otherwise Implemented in IBAMR::VCStaggeredStokesProjectionPreconditioner, IBAMR::StaggeredStokesProjectionPreconditioner, IBAMR::StaggeredStokesBlockFactorizationPreconditioner, IBAMR::CIBStaggeredStokesSolver, IBTK::SCPoissonHypreLevelSolver, IBTK::PETScPCLSWrapper, IBTK::PETScNewtonKrylovSolver, IBTK::PETScLevelSolver, IBTK::PETScKrylovLinearSolver, IBTK::FACPreconditioner, IBTK::CCPoissonHypreLevelSolver, IBTK::BJacobiPreconditioner, and IBTK::BGaussSeidelPreconditioner.