https://mooseframework.inl.gov
EigenproblemESProblemOperator.C
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://mooseframework.inl.gov
3 //*
4 //* All rights reserved, see COPYRIGHT for full restrictions
5 //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
6 //*
7 //* Licensed under LGPL 2.1, please see LICENSE for details
8 //* https://www.gnu.org/licenses/lgpl-2.1.html
9 
10 #ifdef MOOSE_MFEM_ENABLED
11 
13 #include "MFEMEigensolverBase.h"
14 
15 namespace Moose::MFEM
16 {
17 
18 void
20 {
22 
23  auto * const es = GetEquationSystem();
24  if (es->GetTestVarNames().size() > 1)
25  mooseError("Eigenproblems are only supported in single-variable systems");
26 
27  auto eigensolver =
29  es->PrepareEigensolver(*eigensolver);
30  eigensolver->Solve();
32 }
33 
34 void
36 {
39 }
40 
41 void
43  Moose::MFEM::GridFunctions & gridfunctions, Moose::MFEM::EigensolverBase * eigensolver)
44 {
45  mfem::Array<mfem::real_t> eigenvalues;
46  eigensolver->GetEigenvalues(eigenvalues);
47 
48  const auto & trial_var_name = _trial_var_names.at(0);
49  const auto & sep = _problem_data.mode_separator;
50 
51  // Distribute the zeroth mode onto the base variable
52  gridfunctions.Get(trial_var_name)->Distribute(eigensolver->GetEigenvector(0));
53 
54  for (int i = 0; i < eigenvalues.Size(); ++i)
55  gridfunctions.Get(trial_var_name + sep + std::to_string(i))
56  ->Distribute(eigensolver->GetEigenvector(i));
57 }
58 
59 } // namespace Moose::MFEM
60 
61 #endif
void BuildEquationSystemOperator()
Add kernels/bcs and assemble the linear part of the equation system.
std::vector< std::string > _trial_var_names
Vector of names of state gridfunctions used in formulation, ordered by appearance in block vector dur...
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311
EigenproblemEquationSystem * GetEquationSystem() const override
Returns a pointer to the operator&#39;s equation system.
std::shared_ptr< Moose::MFEM::LinearSolverBase > jacobian_solver
std::unique_ptr< T_DEST, T_DELETER > dynamic_pointer_cast(std::unique_ptr< T_SRC, T_DELETER > &src)
These are reworked from https://stackoverflow.com/a/11003103.
virtual const mfem::HypreParVector & GetEigenvector(int index) const =0
Retrieves the computed eigenvector corresponding to the given index.
T * Get(const std::string &field_name) const
Returns a non-owning pointer to the field. This is guaranteed to return a non-null pointer...
virtual void Solve()
For eigensolvers, this method calls the underlying Solve method.
virtual void BuildEquationSystem()
Build all forms comprising this EquationSystem.
void RecoverEigenproblemSolution(GridFunctions &gridfunctions, EigensolverBase *eigensolver)
virtual void GetEigenvalues(mfem::Array< mfem::real_t > &eigenvalues) const =0
Retrieves the computed eigenvalues.
std::string mode_separator
Utilities for converting between vector(s) of libMesh Points and MFEM Vector(s).
Moose::MFEM::GridFunctions gridfunctions
Base class for eigensolvers.
void BuildEigenproblemJacobian(mfem::BlockVector &trueX)
Build eigenproblem system, with essential boundary conditions accounted for.