10 #ifdef MOOSE_MFEM_ENABLED 21 params.
addClassDescription(
"Hypre solver for the iterative solution of MFEM equation systems " 22 "using the flexible generalized minimal residual method.");
23 params.
addParam<mfem::real_t>(
"l_tol", 1e-5,
"Set the relative tolerance.");
24 params.
addParam<
int>(
"l_max_its", 10000,
"Set the maximum number of iterations.");
25 params.
addParam<
int>(
"kdim", 10,
"Set the k-dimension.");
26 params.
addParam<
int>(
"print_level", 2,
"Set the solver verbosity.");
27 params.
addParam<UserObjectName>(
"preconditioner",
"Optional choice of preconditioner to use.");
42 solver->SetTol(getParam<mfem::real_t>(
"l_tol"));
43 solver->SetMaxIter(getParam<int>(
"l_max_its"));
44 solver->SetKDim(getParam<int>(
"kdim"));
45 solver->SetPrintLevel(getParam<int>(
"print_level"));
54 mooseError(
"LOR solver cannot take a preconditioner");
64 mfem::ParLORDiscretization lor_disc(a, tdofs);
65 auto lor_solver =
new mfem::LORSolver<mfem::HypreFGMRES>(
67 lor_solver->GetSolver().SetTol(getParam<mfem::real_t>(
"l_tol"));
68 lor_solver->GetSolver().SetMaxIter(getParam<int>(
"l_max_its"));
69 lor_solver->GetSolver().SetKDim(getParam<int>(
"kdim"));
70 lor_solver->GetSolver().SetPrintLevel(getParam<int>(
"print_level"));
virtual MFEMMesh & mesh() override
Overwritten mesh() method from base MooseMesh to retrieve the correct mesh type, in this case MFEMMes...
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.
MFEMHypreFGMRES(const InputParameters ¶meters)
MFEMSolverBase * _preconditioner
Preconditioner to be used for the problem.
static InputParameters validParams()
void setPreconditioner(T &solver)
Retrieves the preconditioner userobject if present, sets the member pointer to said object if still u...
registerMooseObject("MooseApp", MFEMHypreFGMRES)
static InputParameters validParams()
void constructSolver(const InputParameters ¶meters) override
Override in derived classes to construct and set the solver options.
mfem::ParMesh & getMFEMParMesh()
Accessors for the _mfem_par_mesh object.
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...
Wrapper for mfem::HypreFGMRES solver.
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...
void updateSolver(mfem::ParBilinearForm &a, mfem::Array< int > &tdofs) override
Updates the solver with the bilinear form in case LOR solve is required.
std::unique_ptr< mfem::Solver > _solver
Solver to be used for the problem.