10 #ifdef MOOSE_MFEM_ENABLED 21 params.
addClassDescription(
"Hypre solver for the iterative solution of MFEM equation systems " 22 "using the preconditioned conjugate gradient method.");
24 params.
addParam<mfem::real_t>(
"l_tol", 1e-5,
"Set the relative tolerance.");
25 params.
addParam<mfem::real_t>(
"l_abs_tol", 1e-50,
"Set the absolute tolerance.");
26 params.
addParam<
int>(
"l_max_its", 10000,
"Set the maximum number of iterations.");
27 params.
addParam<
int>(
"print_level", 2,
"Set the solver verbosity.");
28 params.
addParam<UserObjectName>(
"preconditioner",
"Optional choice of preconditioner to use.");
42 solver->SetTol(getParam<mfem::real_t>(
"l_tol"));
43 solver->SetAbsTol(getParam<mfem::real_t>(
"l_abs_tol"));
44 solver->SetMaxIter(getParam<int>(
"l_max_its"));
45 solver->SetPrintLevel(getParam<int>(
"print_level"));
54 mooseError(
"LOR solver cannot take a preconditioner");
64 mfem::ParLORDiscretization lor_disc(a, tdofs);
66 lor_solver->GetSolver().SetTol(getParam<mfem::real_t>(
"l_tol"));
67 lor_solver->GetSolver().SetAbsTol(getParam<mfem::real_t>(
"l_abs_tol"));
68 lor_solver->GetSolver().SetMaxIter(getParam<int>(
"l_max_its"));
69 lor_solver->GetSolver().SetPrintLevel(getParam<int>(
"print_level"));
MFEMHyprePCG(const InputParameters ¶meters)
const InputParameters & parameters() const
Get the parameters of the object.
virtual void checkSpectralEquivalence(mfem::ParBilinearForm &blf) const
Checks for the correct configuration of quadrature bases for LOR spectral equivalence.
MFEMSolverBase * _preconditioner
Preconditioner to be used for the problem.
static InputParameters validParams()
void updateSolver(mfem::ParBilinearForm &a, mfem::Array< int > &tdofs) override
Updates the solver with the bilinear form in case LOR solve is required.
void setPreconditioner(T &solver)
Retrieves the preconditioner userobject if present, sets the member pointer to said object if still u...
Wrapper for mfem::HyprePCG solver.
MPI_Comm getComm()
Return the MPI communicator associated with this FE problem's mesh.
void constructSolver(const InputParameters ¶meters) override
Override in derived classes to construct and set the solver options.
static InputParameters validParams()
bool _lor
Variable defining whether to use LOR solver.
MFEMProblem & getMFEMProblem()
Returns a reference to the MFEMProblem instance.
Base class for wrapping mfem::Solver-derived classes.
void mooseError(Args &&... args) const
Emits an error prefixed with object name and type and optionally a file path to the top-level block p...
virtual void updateSolver(mfem::ParBilinearForm &a, mfem::Array< int > &tdofs)=0
Updates the solver with the given bilinear form and essential dof list, in case an LOR or algebraic s...
registerMooseObject("MooseApp", MFEMHyprePCG)
std::unique_ptr< mfem::Solver > _solver
Solver to be used for the problem.