10 #ifdef MOOSE_MFEM_ENABLED 21 params.
addClassDescription(
"Hypre auxiliary-space Maxwell solver and preconditioner for the " 22 "iterative solution of MFEM equation systems.");
23 params.
addParam<MFEMFESpaceName>(
"fespace",
"H(curl) FESpace to use in HypreAMS setup.");
26 "Declare that the system is singular; use when solving curl-curl problem " 27 "if mass term is zero");
28 params.
addParam<
int>(
"print_level", 2,
"Set the solver verbosity.");
34 :
Moose::MFEM::LinearSolverBase(parameters),
35 _mfem_fespace(getMFEMProblem().getMFEMObject<
MFEMFESpace>(
"MFEMFESpace",
36 getParam<MFEMFESpaceName>(
"fespace")))
45 if (getParam<bool>(
"singular"))
46 solver->SetSingularProblem();
48 solver->iterative_mode = getParam<bool>(
"use_initial_guess");
49 solver->SetPrintLevel(getParam<int>(
"print_level"));
61 mfem::Geometry::Type::CUBE)
62 mooseError(
"LOR HypreAMS Solver only supports hex meshes.");
64 auto lor_solver =
new mfem::LORSolver<mfem::HypreAMS>(a, tdofs);
65 lor_solver->GetSolver().SetPrintLevel(getParam<int>(
"print_level"));
66 if (getParam<bool>(
"singular"))
67 lor_solver->GetSolver().SetSingularProblem();
Wrapper for mfem::HypreAMS solver.
registerMooseObject("MooseApp", MFEMHypreAMS)
const MFEMFESpace & _mfem_fespace
std::unique_ptr< mfem::Solver > _solver
Solver to be used for the problem.
void ConstructSolver() override
Override in derived classes to construct and set the solver options.
static InputParameters validParams()
bool _lor
Variable defining whether to use LOR solver.
static InputParameters validParams()
Constructs and stores an mfem::ParFiniteElementSpace object.
MFEMHypreAMS(const InputParameters &)
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...
void SetupLOR(mfem::ParBilinearForm &a, mfem::Array< int > &tdofs) override
Updates the solver with the bilinear form in case LOR solve is required.
std::shared_ptr< mfem::ParFiniteElementSpace > getFESpace() const
Returns a shared pointer to the constructed fespace.
MOOSE now contains C++17 code, so give a reasonable error message stating what the user can do to add...
virtual void CheckSpectralEquivalence(mfem::ParBilinearForm &blf) const
Checks for the correct configuration of quadrature bases for LOR spectral equivalence.