From 14569f31e4b711246922252d9ffcec4b18a32472 Mon Sep 17 00:00:00 2001 From: Edward Palmer Date: Thu, 27 Jun 2024 10:11:53 +0000 Subject: [PATCH 1/8] Moves hephaestus files into include/src directories. Fails to compile successfully. --- framework/include/mfem/fespaces/MFEMFESpace.h | 3 --- framework/include/mfem/variables/MFEMVariable.h | 3 +-- 2 files changed, 1 insertion(+), 5 deletions(-) diff --git a/framework/include/mfem/fespaces/MFEMFESpace.h b/framework/include/mfem/fespaces/MFEMFESpace.h index 0e01ae91..67a5e9b0 100644 --- a/framework/include/mfem/fespaces/MFEMFESpace.h +++ b/framework/include/mfem/fespaces/MFEMFESpace.h @@ -1,8 +1,5 @@ #pragma once - #include "GeneralUserObject.h" -#include "inputs.hpp" -#include "gridfunctions.hpp" class MFEMFESpace : public GeneralUserObject { diff --git a/framework/include/mfem/variables/MFEMVariable.h b/framework/include/mfem/variables/MFEMVariable.h index c997717d..4ae58a1f 100644 --- a/framework/include/mfem/variables/MFEMVariable.h +++ b/framework/include/mfem/variables/MFEMVariable.h @@ -1,8 +1,7 @@ #pragma once #include "MFEMFESpace.h" -#include "inputs.hpp" -#include "gridfunctions.hpp" +#include "GeneralUserObject.h" class MFEMVariable : public GeneralUserObject { From 943ac621ce1f80fc6fb146cc7b0365aa53418dd1 Mon Sep 17 00:00:00 2001 From: Edward Palmer Date: Thu, 27 Jun 2024 10:11:53 +0000 Subject: [PATCH 2/8] Changes ".hpp" extensions to ".h"/ --- .../include/mfem/bcs/MFEMBoundaryCondition.h | 6 +- .../include/mfem/bcs/MFEMScalarDirichletBC.h | 2 +- .../include/mfem/bcs/MFEMVectorDirichletBC.h | 2 +- .../mfem/bcs/MFEMVectorNormalIntegratedBC.h | 2 +- .../include/mfem/bcs/boundary_conditions.h | 36 +++++ .../mfem/equation_systems/equation_system.h | 142 ++++++++++++++++++ .../mfem/kernels/MFEMDiffusionKernel.h | 2 +- .../include/mfem/materials/MFEMMaterial.h | 4 +- framework/include/mfem/problem/MFEMProblem.h | 4 +- .../equation_system_problem_operator.h | 39 +++++ .../mfem/problem_operators/problem_operator.h | 22 +++ .../problem_operator_interface.h | 30 ++++ ..._domain_equation_system_problem_operator.h | 46 ++++++ .../time_domain_problem_operator.h | 28 ++++ framework/src/mfem/problem/MFEMProblem.C | 2 +- 15 files changed, 355 insertions(+), 12 deletions(-) create mode 100644 framework/include/mfem/bcs/boundary_conditions.h create mode 100644 framework/include/mfem/equation_systems/equation_system.h create mode 100644 framework/include/mfem/problem_operators/equation_system_problem_operator.h create mode 100644 framework/include/mfem/problem_operators/problem_operator.h create mode 100644 framework/include/mfem/problem_operators/problem_operator_interface.h create mode 100644 framework/include/mfem/problem_operators/time_domain_equation_system_problem_operator.h create mode 100644 framework/include/mfem/problem_operators/time_domain_problem_operator.h diff --git a/framework/include/mfem/bcs/MFEMBoundaryCondition.h b/framework/include/mfem/bcs/MFEMBoundaryCondition.h index 75af5a8c..411a6185 100644 --- a/framework/include/mfem/bcs/MFEMBoundaryCondition.h +++ b/framework/include/mfem/bcs/MFEMBoundaryCondition.h @@ -1,9 +1,9 @@ #pragma once #include "GeneralUserObject.h" -#include "boundary_conditions.hpp" -#include "gridfunctions.hpp" -#include "coefficients.hpp" +#include "boundary_conditions.h" +#include "gridfunctions.h" +#include "coefficients.h" #include "Function.h" class MFEMBoundaryCondition : public GeneralUserObject diff --git a/framework/include/mfem/bcs/MFEMScalarDirichletBC.h b/framework/include/mfem/bcs/MFEMScalarDirichletBC.h index 3455249b..9ff404cc 100644 --- a/framework/include/mfem/bcs/MFEMScalarDirichletBC.h +++ b/framework/include/mfem/bcs/MFEMScalarDirichletBC.h @@ -2,7 +2,7 @@ #include "MFEMBoundaryCondition.h" #include "MFEMFunctionCoefficient.h" -#include "boundary_conditions.hpp" +#include "boundary_conditions.h" class MFEMScalarDirichletBC : public MFEMBoundaryCondition { diff --git a/framework/include/mfem/bcs/MFEMVectorDirichletBC.h b/framework/include/mfem/bcs/MFEMVectorDirichletBC.h index cfab0b1d..32232e78 100644 --- a/framework/include/mfem/bcs/MFEMVectorDirichletBC.h +++ b/framework/include/mfem/bcs/MFEMVectorDirichletBC.h @@ -2,7 +2,7 @@ #include "MFEMBoundaryCondition.h" #include "MFEMVectorFunctionCoefficient.h" -#include "boundary_conditions.hpp" +#include "boundary_conditions.h" class MFEMVectorDirichletBC : public MFEMBoundaryCondition { diff --git a/framework/include/mfem/bcs/MFEMVectorNormalIntegratedBC.h b/framework/include/mfem/bcs/MFEMVectorNormalIntegratedBC.h index 4140d56e..08970b56 100644 --- a/framework/include/mfem/bcs/MFEMVectorNormalIntegratedBC.h +++ b/framework/include/mfem/bcs/MFEMVectorNormalIntegratedBC.h @@ -2,7 +2,7 @@ #include "MFEMBoundaryCondition.h" #include "MFEMVectorFunctionCoefficient.h" -#include "boundary_conditions.hpp" +#include "boundary_conditions.h" class MFEMVectorNormalIntegratedBC : public MFEMBoundaryCondition { diff --git a/framework/include/mfem/bcs/boundary_conditions.h b/framework/include/mfem/bcs/boundary_conditions.h new file mode 100644 index 00000000..2da2a6f6 --- /dev/null +++ b/framework/include/mfem/bcs/boundary_conditions.h @@ -0,0 +1,36 @@ +#pragma once +#include "essential_bcs.h" +#include "integrated_bcs.h" +#include "named_fields_map.h" +#include "robin_bcs.h" + +namespace hephaestus +{ + +class BCMap : public hephaestus::NamedFieldsMap +{ +public: + mfem::Array GetEssentialBdrMarkers(const std::string & name_, mfem::Mesh * mesh_); + + void ApplyEssentialBCs(const std::string & name_, + mfem::Array & ess_tdof_list, + mfem::GridFunction & gridfunc, + mfem::Mesh * mesh_); + + void ApplyEssentialBCs(const std::string & name_, + mfem::Array & ess_tdof_list, + mfem::ParComplexGridFunction & gridfunc, + mfem::Mesh * mesh_); + + void ApplyIntegratedBCs(const std::string & name_, mfem::LinearForm & lf, mfem::Mesh * mesh_); + + void ApplyIntegratedBCs(const std::string & name_, + mfem::ParComplexLinearForm & clf, + mfem::Mesh * mesh_); + + void ApplyIntegratedBCs(const std::string & name_, + mfem::ParSesquilinearForm & clf, + mfem::Mesh * mesh_); +}; + +} // namespace hephaestus diff --git a/framework/include/mfem/equation_systems/equation_system.h b/framework/include/mfem/equation_systems/equation_system.h new file mode 100644 index 00000000..fd99db92 --- /dev/null +++ b/framework/include/mfem/equation_systems/equation_system.h @@ -0,0 +1,142 @@ +#pragma once +#include "../common/pfem_extras.hpp" +#include "inputs.h" +#include "kernel_base.h" +#include "named_fields_map.h" +#include "sources.h" + +namespace hephaestus +{ + +/* +Class to store weak form components (bilinear and linear forms, and optionally +mixed and nonlinear forms) and build methods +*/ +class EquationSystem : public mfem::Operator +{ +public: + using ParBilinearFormKernel = hephaestus::Kernel; + using ParLinearFormKernel = hephaestus::Kernel; + using ParNonlinearFormKernel = hephaestus::Kernel; + using ParMixedBilinearFormKernel = hephaestus::Kernel; + + EquationSystem() = default; + ~EquationSystem() override; + + // Test variables are associated with LinearForms, + // whereas trial variables are associated with gridfunctions. + + // Names of all variables corresponding to gridfunctions. This may differ + // from test_var_names when time derivatives are present. + std::vector _trial_var_names; + // Names of all test variables corresponding to linear forms in this equation + // system + std::vector _test_var_names; + std::vector _test_pfespaces; + + // Components of weak form. // Named according to test variable + hephaestus::NamedFieldsMap _blfs; + hephaestus::NamedFieldsMap _lfs; + hephaestus::NamedFieldsMap _nlfs; + hephaestus::NamedFieldsMap> + _mblfs; // named according to trial variable + + // add test variable to EquationSystem; + virtual void AddTestVariableNameIfMissing(const std::string & test_var_name); + virtual void AddTrialVariableNameIfMissing(const std::string & trial_var_name); + + // Add kernels. + void AddKernel(const std::string & test_var_name, + std::shared_ptr blf_kernel); + + void AddKernel(const std::string & test_var_name, std::shared_ptr lf_kernel); + + void AddKernel(const std::string & test_var_name, + std::shared_ptr nlf_kernel); + + void AddKernel(const std::string & trial_var_name, + const std::string & test_var_name, + std::shared_ptr mblf_kernel); + + virtual void ApplyBoundaryConditions(hephaestus::BCMap & bc_map); + + // override to add kernels + virtual void AddKernels() {} + + // Build forms + virtual void Init(hephaestus::GridFunctions & gridfunctions, + const hephaestus::FESpaces & fespaces, + hephaestus::BCMap & bc_map, + Coefficients & coefficients); + virtual void BuildLinearForms(hephaestus::BCMap & bc_map, hephaestus::Sources & sources); + virtual void BuildBilinearForms(); + virtual void BuildMixedBilinearForms(); + virtual void BuildEquationSystem(hephaestus::BCMap & bc_map, hephaestus::Sources & sources); + + // Form linear system, with essential boundary conditions accounted for + virtual void FormLinearSystem(mfem::OperatorHandle & op, + mfem::BlockVector & trueX, + mfem::BlockVector & trueRHS); + + // Build linear system, with essential boundary conditions accounted for + virtual void BuildJacobian(mfem::BlockVector & trueX, mfem::BlockVector & trueRHS); + + /// Compute residual y = Mu + void Mult(const mfem::Vector & u, mfem::Vector & residual) const override; + + /// Compute J = M + grad_H(u) + mfem::Operator & GetGradient(const mfem::Vector & u) const override; + + // Update variable from solution vector after solve + virtual void RecoverFEMSolution(mfem::BlockVector & trueX, + hephaestus::GridFunctions & gridfunctions); + + std::vector> _ess_tdof_lists; + +protected: + bool VectorContainsName(const std::vector & the_vector, + const std::string & name) const; + + // gridfunctions for setting Dirichlet BCs + std::vector> _xs; + + mfem::Array2D _h_blocks; + + // Arrays to store kernels to act on each component of weak form. Named + // according to test variable + hephaestus::NamedFieldsMap>> _blf_kernels_map; + + hephaestus::NamedFieldsMap>> _lf_kernels_map; + + hephaestus::NamedFieldsMap>> _nlf_kernels_map; + + hephaestus::NamedFieldsMap< + hephaestus::NamedFieldsMap>>> + _mblf_kernels_map_map; + + mutable mfem::OperatorHandle _jacobian; +}; + +/* +Class to store weak form components for time dependent PDEs +*/ +class TimeDependentEquationSystem : public EquationSystem +{ +public: + TimeDependentEquationSystem(); + ~TimeDependentEquationSystem() override = default; + + static std::string GetTimeDerivativeName(std::string name) + { + return std::string("d") + name + std::string("_dt"); + } + + void AddTrialVariableNameIfMissing(const std::string & trial_var_name) override; + + virtual void SetTimeStep(double dt); + virtual void UpdateEquationSystem(hephaestus::BCMap & bc_map, hephaestus::Sources & sources); + mfem::ConstantCoefficient _dt_coef; // Coefficient for timestep scaling + std::vector _trial_var_time_derivative_names; +}; + +} // namespace hephaestus diff --git a/framework/include/mfem/kernels/MFEMDiffusionKernel.h b/framework/include/mfem/kernels/MFEMDiffusionKernel.h index 4d75fd62..24013432 100644 --- a/framework/include/mfem/kernels/MFEMDiffusionKernel.h +++ b/framework/include/mfem/kernels/MFEMDiffusionKernel.h @@ -1,6 +1,6 @@ #pragma once #include "MFEMBilinearFormKernel.h" -#include "kernels.hpp" +#include "kernels.h" class MFEMDiffusionKernel : public MFEMBilinearFormKernel { diff --git a/framework/include/mfem/materials/MFEMMaterial.h b/framework/include/mfem/materials/MFEMMaterial.h index efadda0c..14c49fde 100644 --- a/framework/include/mfem/materials/MFEMMaterial.h +++ b/framework/include/mfem/materials/MFEMMaterial.h @@ -2,7 +2,7 @@ #include "GeneralUserObject.h" #include "MFEMCoefficient.h" -#include "coefficients.hpp" +#include "coefficients.h" class MFEMMaterial : public GeneralUserObject { @@ -16,7 +16,7 @@ class MFEMMaterial : public GeneralUserObject virtual void initialize() override {} virtual void finalize() override {} - virtual void storeCoefficients(hephaestus::Subdomain & subdomain) {} + virtual void storeCoefficients(Subdomain & subdomain) {} std::vector blocks; }; diff --git a/framework/include/mfem/problem/MFEMProblem.h b/framework/include/mfem/problem/MFEMProblem.h index 1be63adc..ab6eea5e 100644 --- a/framework/include/mfem/problem/MFEMProblem.h +++ b/framework/include/mfem/problem/MFEMProblem.h @@ -23,7 +23,7 @@ #include "SystemBase.h" #include "Transient.h" #include "Steady.h" -#include "hephaestus.hpp" +#include "hephaestus.h" #include "libmesh/string_to_enum.h" #include "libmesh/point.h" @@ -173,7 +173,7 @@ class MFEMProblem : public ExternalProblem std::string _formulation_name; int _order; - hephaestus::Coefficients _coefficients; + Coefficients _coefficients; hephaestus::InputParameters _solver_options; hephaestus::Outputs _outputs; hephaestus::InputParameters _exec_params; diff --git a/framework/include/mfem/problem_operators/equation_system_problem_operator.h b/framework/include/mfem/problem_operators/equation_system_problem_operator.h new file mode 100644 index 00000000..fc489cac --- /dev/null +++ b/framework/include/mfem/problem_operators/equation_system_problem_operator.h @@ -0,0 +1,39 @@ +#pragma once +#include "problem_operator.h" +#include "problem_operator_interface.h" +#include "equation_system_interface.h" + +namespace hephaestus +{ +/// Steady-state problem operator with an equation system. +class EquationSystemProblemOperator : public ProblemOperator, public EquationSystemInterface +{ +public: + EquationSystemProblemOperator(hephaestus::Problem &) = delete; + + EquationSystemProblemOperator(hephaestus::Problem & problem, + std::unique_ptr equation_system) + : ProblemOperator(problem), _equation_system(std::move(equation_system)) + { + } + + void SetGridFunctions() override; + void Init(mfem::Vector & X) override; + + ~EquationSystemProblemOperator() override = default; + + [[nodiscard]] hephaestus::EquationSystem * GetEquationSystem() const override + { + if (!_equation_system) + { + MFEM_ABORT("No equation system has been added to ProblemOperator."); + } + + return _equation_system.get(); + } + +private: + std::unique_ptr _equation_system{nullptr}; +}; + +} // namespace hephaestus \ No newline at end of file diff --git a/framework/include/mfem/problem_operators/problem_operator.h b/framework/include/mfem/problem_operators/problem_operator.h new file mode 100644 index 00000000..c127ffa4 --- /dev/null +++ b/framework/include/mfem/problem_operators/problem_operator.h @@ -0,0 +1,22 @@ +#pragma once +#include "../common/pfem_extras.hpp" +#include "hephaestus_solvers.h" +#include "problem_builder_base.h" +#include "problem_operator_interface.h" + +namespace hephaestus +{ +/// Steady-state problem operator with no equation system. +class ProblemOperator : public mfem::Operator, public ProblemOperatorInterface +{ +public: + ProblemOperator(hephaestus::Problem & problem) : ProblemOperatorInterface(problem) {} + ~ProblemOperator() override = default; + + void SetGridFunctions() override; + + virtual void Solve(mfem::Vector & X) {} + void Mult(const mfem::Vector & x, mfem::Vector & y) const override {} +}; + +} // namespace hephaestus \ No newline at end of file diff --git a/framework/include/mfem/problem_operators/problem_operator_interface.h b/framework/include/mfem/problem_operators/problem_operator_interface.h new file mode 100644 index 00000000..70f55b11 --- /dev/null +++ b/framework/include/mfem/problem_operators/problem_operator_interface.h @@ -0,0 +1,30 @@ +#pragma once +#include "problem_builder_base.h" + +namespace hephaestus +{ +/// Interface inherited by ProblemOperator and TimeDomainProblemOperator. Removes duplicated code in both classes. +class ProblemOperatorInterface +{ +public: + ProblemOperatorInterface(hephaestus::Problem & problem) : _problem(problem) {} + virtual ~ProblemOperatorInterface() = default; + + virtual void SetGridFunctions(); + virtual void Init(mfem::Vector & X); + + mfem::Array _true_offsets, _block_true_offsets; + + mfem::BlockVector _true_x, _true_rhs; + mfem::OperatorHandle _equation_system_operator; + +protected: + // Reference to the current problem. + hephaestus::Problem & _problem; + + // Vector of names of state gridfunctions used in formulation, ordered by appearance in block + // vector during solve. + std::vector _trial_var_names; + std::vector _trial_variables; +}; +} \ No newline at end of file diff --git a/framework/include/mfem/problem_operators/time_domain_equation_system_problem_operator.h b/framework/include/mfem/problem_operators/time_domain_equation_system_problem_operator.h new file mode 100644 index 00000000..87d7ef08 --- /dev/null +++ b/framework/include/mfem/problem_operators/time_domain_equation_system_problem_operator.h @@ -0,0 +1,46 @@ +#pragma once +#include "../common/pfem_extras.hpp" +#include "time_domain_problem_operator.h" +#include "problem_operator_interface.h" +#include "equation_system_interface.h" + +namespace hephaestus +{ + +/// Problem operator for time-dependent problems with an equation system. +class TimeDomainEquationSystemProblemOperator : public TimeDomainProblemOperator, + public EquationSystemInterface +{ +public: + TimeDomainEquationSystemProblemOperator(hephaestus::Problem &) = delete; + TimeDomainEquationSystemProblemOperator( + hephaestus::Problem & problem, + std::unique_ptr equation_system) + : TimeDomainProblemOperator(problem), _equation_system{std::move(equation_system)} + { + } + + void SetGridFunctions() override; + void Init(mfem::Vector & X) override; + + void ImplicitSolve(const double dt, const mfem::Vector & X, mfem::Vector & dX_dt) override; + + [[nodiscard]] hephaestus::TimeDependentEquationSystem * GetEquationSystem() const override + { + if (!_equation_system) + { + MFEM_ABORT("No equation system has been added."); + } + + return _equation_system.get(); + } + +protected: + void BuildEquationSystemOperator(double dt); + +private: + std::vector _trial_variable_time_derivatives; + std::unique_ptr _equation_system{nullptr}; +}; + +} // namespace hephaestus \ No newline at end of file diff --git a/framework/include/mfem/problem_operators/time_domain_problem_operator.h b/framework/include/mfem/problem_operators/time_domain_problem_operator.h new file mode 100644 index 00000000..dd695ffe --- /dev/null +++ b/framework/include/mfem/problem_operators/time_domain_problem_operator.h @@ -0,0 +1,28 @@ +#pragma once +#include "../common/pfem_extras.hpp" +#include "hephaestus_solvers.h" +#include "problem_builder_base.h" +#include "problem_operator_interface.h" + +namespace hephaestus +{ + +std::string GetTimeDerivativeName(const std::string & name); + +std::vector GetTimeDerivativeNames(std::vector gridfunction_names); + +/// Problem operator for time-dependent problems with no equation system. The user will need to subclass this since the solve is not +/// implemented. +class TimeDomainProblemOperator : public mfem::TimeDependentOperator, + public ProblemOperatorInterface +{ +public: + TimeDomainProblemOperator(hephaestus::Problem & problem) : ProblemOperatorInterface(problem) {} + ~TimeDomainProblemOperator() override = default; + + void SetGridFunctions() override; + + void ImplicitSolve(const double dt, const mfem::Vector & X, mfem::Vector & dX_dt) override {} +}; + +} // namespace hephaestus \ No newline at end of file diff --git a/framework/src/mfem/problem/MFEMProblem.C b/framework/src/mfem/problem/MFEMProblem.C index 5de8121f..61326401 100644 --- a/framework/src/mfem/problem/MFEMProblem.C +++ b/framework/src/mfem/problem/MFEMProblem.C @@ -174,7 +174,7 @@ MFEMProblem::addMaterial(const std::string & kernel_name, for (unsigned int bid = 0; bid < mfem_material.blocks.size(); ++bid) { int block = std::stoi(mfem_material.blocks[bid]); - hephaestus::Subdomain mfem_subdomain(name, block); + Subdomain mfem_subdomain(name, block); mfem_material.storeCoefficients(mfem_subdomain); _coefficients._subdomains.push_back(mfem_subdomain); } From 8f0d582bde062e5b40deee3b12bfa234c2ee4e3c Mon Sep 17 00:00:00 2001 From: Edward Palmer Date: Thu, 27 Jun 2024 10:11:53 +0000 Subject: [PATCH 3/8] Fixes includes, removes spdlog dependency. --- framework/src/mfem/problem/MFEMProblem.C | 1 - 1 file changed, 1 deletion(-) diff --git a/framework/src/mfem/problem/MFEMProblem.C b/framework/src/mfem/problem/MFEMProblem.C index 61326401..71ba179a 100644 --- a/framework/src/mfem/problem/MFEMProblem.C +++ b/framework/src/mfem/problem/MFEMProblem.C @@ -23,7 +23,6 @@ MFEMProblem::MFEMProblem(const InputParameters & params) _outputs(), _exec_params() { - hephaestus::logger.set_level(spdlog::level::info); } MFEMProblem::~MFEMProblem() {} From 414b5ed7d885d29fd4fb5994ff236bc9672eb5df Mon Sep 17 00:00:00 2001 From: Edward Palmer Date: Thu, 27 Jun 2024 10:11:53 +0000 Subject: [PATCH 4/8] Changes source file extensions from .c to .C --- framework/src/mfem/bcs/boundary_conditions.C | 131 ++++++ .../mfem/equation_systems/equation_system.C | 437 ++++++++++++++++++ .../equation_system_problem_operator.C | 20 + .../mfem/problem_operators/problem_operator.C | 13 + .../problem_operator_interface.C | 43 ++ ..._domain_equation_system_problem_operator.C | 61 +++ .../time_domain_problem_operator.C | 30 ++ 7 files changed, 735 insertions(+) create mode 100644 framework/src/mfem/bcs/boundary_conditions.C create mode 100644 framework/src/mfem/equation_systems/equation_system.C create mode 100644 framework/src/mfem/problem_operators/equation_system_problem_operator.C create mode 100644 framework/src/mfem/problem_operators/problem_operator.C create mode 100644 framework/src/mfem/problem_operators/problem_operator_interface.C create mode 100644 framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C create mode 100644 framework/src/mfem/problem_operators/time_domain_problem_operator.C diff --git a/framework/src/mfem/bcs/boundary_conditions.C b/framework/src/mfem/bcs/boundary_conditions.C new file mode 100644 index 00000000..d6131d9d --- /dev/null +++ b/framework/src/mfem/bcs/boundary_conditions.C @@ -0,0 +1,131 @@ +#include "boundary_conditions.h" + +namespace hephaestus +{ + +mfem::Array +BCMap::GetEssentialBdrMarkers(const std::string & name_, mfem::Mesh * mesh_) +{ + mfem::Array global_ess_markers(mesh_->bdr_attributes.Max()); + global_ess_markers = 0; + mfem::Array ess_bdrs(mesh_->bdr_attributes.Max()); + ess_bdrs = 0; + + for (auto const & [name, bc_] : *this) + { + if (bc_->_name == name_) + { + auto bc = std::dynamic_pointer_cast(bc_); + if (bc != nullptr) + { + ess_bdrs = bc->GetMarkers(*mesh_); + for (auto it = 0; it != mesh_->bdr_attributes.Max(); ++it) + { + global_ess_markers[it] = std::max(global_ess_markers[it], ess_bdrs[it]); + } + } + } + } + return global_ess_markers; +} + +void +BCMap::ApplyEssentialBCs(const std::string & name_, + mfem::Array & ess_tdof_list, + mfem::GridFunction & gridfunc, + mfem::Mesh * mesh_) +{ + for (auto const & [name, bc_] : *this) + { + if (bc_->_name == name_) + { + auto bc = std::dynamic_pointer_cast(bc_); + if (bc != nullptr) + { + bc->ApplyBC(gridfunc, mesh_); + } + } + } + mfem::Array ess_bdr = GetEssentialBdrMarkers(name_, mesh_); + gridfunc.FESpace()->GetEssentialTrueDofs(ess_bdr, ess_tdof_list); +} + +void +BCMap::ApplyEssentialBCs(const std::string & name_, + mfem::Array & ess_tdof_list, + mfem::ParComplexGridFunction & gridfunc, + mfem::Mesh * mesh_) +{ + for (auto const & [name, bc_] : *this) + { + if (bc_->_name == name_) + { + auto bc = std::dynamic_pointer_cast(bc_); + if (bc != nullptr) + { + bc->ApplyBC(gridfunc, mesh_); + } + } + } + mfem::Array ess_bdr = GetEssentialBdrMarkers(name_, mesh_); + gridfunc.FESpace()->GetEssentialTrueDofs(ess_bdr, ess_tdof_list); +}; + +void +BCMap::ApplyIntegratedBCs(const std::string & name_, mfem::LinearForm & lf, mfem::Mesh * mesh_) +{ + + for (auto const & [name, bc_] : *this) + { + if (bc_->_name == name_) + { + auto bc = std::dynamic_pointer_cast(bc_); + if (bc != nullptr) + { + bc->GetMarkers(*mesh_); + bc->ApplyBC(lf); + } + } + } +}; + +void +BCMap::ApplyIntegratedBCs(const std::string & name_, + mfem::ParComplexLinearForm & clf, + mfem::Mesh * mesh_) +{ + + for (auto const & [name, bc_] : *this) + { + if (bc_->_name == name_) + { + auto bc = std::dynamic_pointer_cast(bc_); + if (bc != nullptr) + { + bc->GetMarkers(*mesh_); + bc->ApplyBC(clf); + } + } + } +}; + +void +BCMap::ApplyIntegratedBCs(const std::string & name_, + mfem::ParSesquilinearForm & slf, + mfem::Mesh * mesh_) +{ + for (auto const & [name, bc_] : *this) + { + if (bc_->_name == name_) + { + auto bc = std::dynamic_pointer_cast(bc_); + if (bc != nullptr) + { + bc->GetMarkers(*mesh_); + bc->ApplyBC(slf); + } + } + } +}; + +} // namespace hephaestus diff --git a/framework/src/mfem/equation_systems/equation_system.C b/framework/src/mfem/equation_systems/equation_system.C new file mode 100644 index 00000000..b3b6eafd --- /dev/null +++ b/framework/src/mfem/equation_systems/equation_system.C @@ -0,0 +1,437 @@ +#include "equation_system.h" + +namespace hephaestus +{ + +EquationSystem::~EquationSystem() { _h_blocks.DeleteAll(); } + +bool +EquationSystem::VectorContainsName(const std::vector & the_vector, + const std::string & name) const +{ + + auto iter = std::find(the_vector.begin(), the_vector.end(), name); + + return (iter != the_vector.end()); +} + +void +EquationSystem::AddTrialVariableNameIfMissing(const std::string & trial_var_name) +{ + if (!VectorContainsName(_trial_var_names, trial_var_name)) + { + _trial_var_names.push_back(trial_var_name); + } +} + +void +EquationSystem::AddTestVariableNameIfMissing(const std::string & test_var_name) +{ + if (!VectorContainsName(_test_var_names, test_var_name)) + { + _test_var_names.push_back(test_var_name); + } +} + +void +EquationSystem::AddKernel(const std::string & test_var_name, + std::shared_ptr blf_kernel) +{ + AddTestVariableNameIfMissing(test_var_name); + + if (!_blf_kernels_map.Has(test_var_name)) + { + // 1. Create kernels vector. + auto kernels = std::make_shared>>(); + + // 2. Register with map to prevent leaks. + _blf_kernels_map.Register(test_var_name, std::move(kernels)); + } + + _blf_kernels_map.GetRef(test_var_name).push_back(std::move(blf_kernel)); +} + +void +EquationSystem::AddKernel(const std::string & test_var_name, + std::shared_ptr lf_kernel) +{ + AddTestVariableNameIfMissing(test_var_name); + + if (!_lf_kernels_map.Has(test_var_name)) + { + auto kernels = std::make_shared>>(); + + _lf_kernels_map.Register(test_var_name, std::move(kernels)); + } + + _lf_kernels_map.GetRef(test_var_name).push_back(std::move(lf_kernel)); +} + +void +EquationSystem::AddKernel(const std::string & test_var_name, + std::shared_ptr nlf_kernel) +{ + AddTestVariableNameIfMissing(test_var_name); + + if (!_nlf_kernels_map.Has(test_var_name)) + { + auto kernels = std::make_shared>>(); + + _nlf_kernels_map.Register(test_var_name, std::move(kernels)); + } + + _nlf_kernels_map.GetRef(test_var_name).push_back(std::move(nlf_kernel)); +} + +void +EquationSystem::AddKernel(const std::string & trial_var_name, + const std::string & test_var_name, + std::shared_ptr mblf_kernel) +{ + AddTestVariableNameIfMissing(test_var_name); + + // Register new mblf kernels map if not present for this test variable + if (!_mblf_kernels_map_map.Has(test_var_name)) + { + auto kernel_field_map = std::make_shared< + hephaestus::NamedFieldsMap>>>(); + + _mblf_kernels_map_map.Register(test_var_name, std::move(kernel_field_map)); + } + + // Register new mblf kernels map if not present for the test/trial variable + // pair + if (!_mblf_kernels_map_map.Get(test_var_name)->Has(trial_var_name)) + { + auto kernels = std::make_shared>>(); + + _mblf_kernels_map_map.Get(test_var_name)->Register(trial_var_name, std::move(kernels)); + } + + _mblf_kernels_map_map.GetRef(test_var_name) + .Get(trial_var_name) + ->push_back(std::move(mblf_kernel)); +} + +void +EquationSystem::ApplyBoundaryConditions(hephaestus::BCMap & bc_map) +{ + _ess_tdof_lists.resize(_test_var_names.size()); + for (int i = 0; i < _test_var_names.size(); i++) + { + auto test_var_name = _test_var_names.at(i); + // Set default value of gridfunction used in essential BC. Values + // overwritten in applyEssentialBCs + *(_xs.at(i)) = 0.0; + bc_map.ApplyEssentialBCs( + test_var_name, _ess_tdof_lists.at(i), *(_xs.at(i)), _test_pfespaces.at(i)->GetParMesh()); + bc_map.ApplyIntegratedBCs( + test_var_name, _lfs.GetRef(test_var_name), _test_pfespaces.at(i)->GetParMesh()); + } +} +void +EquationSystem::FormLinearSystem(mfem::OperatorHandle & op, + mfem::BlockVector & trueX, + mfem::BlockVector & trueRHS) +{ + + // Allocate block operator + _h_blocks.DeleteAll(); + _h_blocks.SetSize(_test_var_names.size(), _test_var_names.size()); + // Form diagonal blocks. + for (int i = 0; i < _test_var_names.size(); i++) + { + auto & test_var_name = _test_var_names.at(i); + auto blf = _blfs.Get(test_var_name); + auto lf = _lfs.Get(test_var_name); + mfem::Vector aux_x, aux_rhs; + _h_blocks(i, i) = new mfem::HypreParMatrix; + blf->FormLinearSystem( + _ess_tdof_lists.at(i), *(_xs.at(i)), *lf, *_h_blocks(i, i), aux_x, aux_rhs); + trueX.GetBlock(i) = aux_x; + trueRHS.GetBlock(i) = aux_rhs; + } + + // Form off-diagonal blocks + for (int i = 0; i < _test_var_names.size(); i++) + { + auto test_var_name = _test_var_names.at(i); + for (int j = 0; j < _test_var_names.size(); j++) + { + auto trial_var_name = _test_var_names.at(j); + + mfem::Vector aux_x, aux_rhs; + mfem::ParLinearForm aux_lf(_test_pfespaces.at(i)); + aux_lf = 0.0; + if (_mblfs.Has(test_var_name) && _mblfs.Get(test_var_name)->Has(trial_var_name)) + { + auto mblf = _mblfs.Get(test_var_name)->Get(trial_var_name); + _h_blocks(i, j) = new mfem::HypreParMatrix; + mblf->FormRectangularLinearSystem(_ess_tdof_lists.at(j), + _ess_tdof_lists.at(i), + *(_xs.at(j)), + aux_lf, + *_h_blocks(i, j), + aux_x, + aux_rhs); + trueRHS.GetBlock(i) += aux_rhs; + } + } + } + // Sync memory + for (int i = 0; i < _test_var_names.size(); i++) + { + trueX.GetBlock(0).SyncAliasMemory(trueX); + trueRHS.GetBlock(0).SyncAliasMemory(trueRHS); + } + + // Create monolithic matrix + op.Reset(mfem::HypreParMatrixFromBlocks(_h_blocks)); +} + +void +EquationSystem::BuildJacobian(mfem::BlockVector & trueX, mfem::BlockVector & trueRHS) +{ + height = trueX.Size(); + width = trueRHS.Size(); + FormLinearSystem(_jacobian, trueX, trueRHS); +} + +void +EquationSystem::Mult(const mfem::Vector & x, mfem::Vector & residual) const +{ + _jacobian->Mult(x, residual); +} + +mfem::Operator & +EquationSystem::GetGradient(const mfem::Vector & u) const +{ + return *_jacobian; +} + +void +EquationSystem::RecoverFEMSolution(mfem::BlockVector & trueX, + hephaestus::GridFunctions & gridfunctions) +{ + for (int i = 0; i < _test_var_names.size(); i++) + { + auto & test_var_name = _test_var_names.at(i); + trueX.GetBlock(i).SyncAliasMemory(trueX); + gridfunctions.Get(test_var_name)->Distribute(&(trueX.GetBlock(i))); + } +} + +void +EquationSystem::Init(hephaestus::GridFunctions & gridfunctions, + const hephaestus::FESpaces & fespaces, + hephaestus::BCMap & bc_map, + Coefficients & coefficients) +{ + + // Add optional kernels to the EquationSystem + AddKernels(); + + for (auto & test_var_name : _test_var_names) + { + if (!gridfunctions.Has(test_var_name)) + { + MFEM_ABORT("Test variable " << test_var_name + << " requested by equation system during initialisation was " + "not found in gridfunctions"); + } + // Store pointers to variable FESpaces + _test_pfespaces.push_back(gridfunctions.Get(test_var_name)->ParFESpace()); + // Create auxiliary gridfunctions for applying Dirichlet conditions + _xs.emplace_back( + std::make_unique(gridfunctions.Get(test_var_name)->ParFESpace())); + } + + // Initialise bilinear forms + + for (const auto & [test_var_name, blf_kernels] : _blf_kernels_map) + { + for (auto & i : *blf_kernels) + { + i->Init(gridfunctions, fespaces, bc_map, coefficients); + } + } + // Initialise linear form kernels + for (const auto & [test_var_name, lf_kernels] : _lf_kernels_map) + { + for (auto & i : *lf_kernels) + { + i->Init(gridfunctions, fespaces, bc_map, coefficients); + } + } + // Initialise nonlinear form kernels + for (const auto & [test_var_name, nlf_kernels] : _nlf_kernels_map) + { + for (auto & i : *nlf_kernels) + { + i->Init(gridfunctions, fespaces, bc_map, coefficients); + } + } + // Initialise mixed bilinear form kernels + for (const auto & [test_var_name, mblf_kernels_map] : _mblf_kernels_map_map) + { + for (const auto & [trial_var_name, mblf_kernels] : *mblf_kernels_map) + { + for (auto & i : *mblf_kernels) + { + i->Init(gridfunctions, fespaces, bc_map, coefficients); + } + } + } +} + +void +EquationSystem::BuildLinearForms(hephaestus::BCMap & bc_map, hephaestus::Sources & sources) +{ + // Register linear forms + for (int i = 0; i < _test_var_names.size(); i++) + { + auto test_var_name = _test_var_names.at(i); + _lfs.Register(test_var_name, std::make_shared(_test_pfespaces.at(i))); + _lfs.GetRef(test_var_name) = 0.0; + } + // Apply boundary conditions + ApplyBoundaryConditions(bc_map); + + for (auto & test_var_name : _test_var_names) + { + // Apply kernels + auto lf = _lfs.Get(test_var_name); + // Assemble. Must be done before applying kernels that add to lf. + lf->Assemble(); + + if (_lf_kernels_map.Has(test_var_name)) + { + auto lf_kernels = _lf_kernels_map.GetRef(test_var_name); + + for (auto & lf_kernel : lf_kernels) + { + lf_kernel->Apply(lf); + } + } + + if (test_var_name == _test_var_names.at(0)) + { + sources.Apply(lf); + } + } +} + +void +EquationSystem::BuildBilinearForms() +{ + // Register bilinear forms + for (int i = 0; i < _test_var_names.size(); i++) + { + auto test_var_name = _test_var_names.at(i); + _blfs.Register(test_var_name, std::make_shared(_test_pfespaces.at(i))); + + // Apply kernels + auto blf = _blfs.Get(test_var_name); + if (_blf_kernels_map.Has(test_var_name)) + { + auto blf_kernels = _blf_kernels_map.GetRef(test_var_name); + + for (auto & blf_kernel : blf_kernels) + { + blf_kernel->Apply(blf); + } + } + // Assemble + blf->Assemble(); + } +} + +void +EquationSystem::BuildMixedBilinearForms() +{ + // Register mixed linear forms. Note that not all combinations may + // have a kernel + + // Create mblf for each test/trial pair + for (int i = 0; i < _test_var_names.size(); i++) + { + auto test_var_name = _test_var_names.at(i); + auto test_mblfs = std::make_shared>(); + for (int j = 0; j < _test_var_names.size(); j++) + { + auto trial_var_name = _test_var_names.at(j); + + // Register MixedBilinearForm if kernels exist for it, and assemble + // kernels + if (_mblf_kernels_map_map.Has(test_var_name) && + _mblf_kernels_map_map.Get(test_var_name)->Has(trial_var_name)) + { + auto mblf_kernels = _mblf_kernels_map_map.GetRef(test_var_name).GetRef(trial_var_name); + auto mblf = std::make_shared(_test_pfespaces.at(j), + _test_pfespaces.at(i)); + // Apply all mixed kernels with this test/trial pair + for (auto & mblf_kernel : mblf_kernels) + { + mblf_kernel->Apply(mblf.get()); + } + // Assemble mixed bilinear forms + mblf->Assemble(); + // Register mixed bilinear forms associated with a single trial variable + // for the current test variable + test_mblfs->Register(trial_var_name, mblf); + } + } + // Register all mixed bilinear form sets associated with a single test + // variable + _mblfs.Register(test_var_name, test_mblfs); + } +} + +void +EquationSystem::BuildEquationSystem(hephaestus::BCMap & bc_map, hephaestus::Sources & sources) +{ + BuildLinearForms(bc_map, sources); + BuildBilinearForms(); + BuildMixedBilinearForms(); +} + +TimeDependentEquationSystem::TimeDependentEquationSystem() : _dt_coef(1.0) {} + +void +TimeDependentEquationSystem::AddTrialVariableNameIfMissing(const std::string & var_name) +{ + EquationSystem::AddTrialVariableNameIfMissing(var_name); + std::string var_time_derivative_name = GetTimeDerivativeName(var_name); + if (std::find(_trial_var_time_derivative_names.begin(), + _trial_var_time_derivative_names.end(), + var_time_derivative_name) == _trial_var_time_derivative_names.end()) + { + _trial_var_time_derivative_names.push_back(var_time_derivative_name); + } +} + +void +TimeDependentEquationSystem::SetTimeStep(double dt) +{ + if (fabs(dt - _dt_coef.constant) > 1.0e-12 * dt) + { + _dt_coef.constant = dt; + for (auto test_var_name : _test_var_names) + { + auto blf = _blfs.Get(test_var_name); + blf->Update(); + blf->Assemble(); + } + } +} + +void +TimeDependentEquationSystem::UpdateEquationSystem(hephaestus::BCMap & bc_map, + hephaestus::Sources & sources) +{ + BuildLinearForms(bc_map, sources); + BuildBilinearForms(); + BuildMixedBilinearForms(); +} + +} // namespace hephaestus diff --git a/framework/src/mfem/problem_operators/equation_system_problem_operator.C b/framework/src/mfem/problem_operators/equation_system_problem_operator.C new file mode 100644 index 00000000..78019937 --- /dev/null +++ b/framework/src/mfem/problem_operators/equation_system_problem_operator.C @@ -0,0 +1,20 @@ +#include "equation_system_problem_operator.h" + +namespace hephaestus +{ +void +EquationSystemProblemOperator::SetGridFunctions() +{ + _trial_var_names = GetEquationSystem()->_trial_var_names; + ProblemOperator::SetGridFunctions(); +} + +void +EquationSystemProblemOperator::Init(mfem::Vector & X) +{ + ProblemOperator::Init(X); + + GetEquationSystem()->BuildEquationSystem(_problem._bc_map, _problem._sources); +} + +} // namespace hephaestus \ No newline at end of file diff --git a/framework/src/mfem/problem_operators/problem_operator.C b/framework/src/mfem/problem_operators/problem_operator.C new file mode 100644 index 00000000..33323510 --- /dev/null +++ b/framework/src/mfem/problem_operators/problem_operator.C @@ -0,0 +1,13 @@ +#include "problem_operator.h" + +namespace hephaestus +{ + +void +ProblemOperator::SetGridFunctions() +{ + ProblemOperatorInterface::SetGridFunctions(); + width = height = _true_offsets[_trial_variables.size()]; +}; + +} // namespace hephaestus \ No newline at end of file diff --git a/framework/src/mfem/problem_operators/problem_operator_interface.C b/framework/src/mfem/problem_operators/problem_operator_interface.C new file mode 100644 index 00000000..e49043f0 --- /dev/null +++ b/framework/src/mfem/problem_operators/problem_operator_interface.C @@ -0,0 +1,43 @@ +#include "problem_operator_interface.h" + +namespace hephaestus +{ +void +ProblemOperatorInterface::SetGridFunctions() +{ + _trial_variables = _problem._gridfunctions.Get(_trial_var_names); + + // Set operator size and block structure + _block_true_offsets.SetSize(_trial_variables.size() + 1); + _block_true_offsets[0] = 0; + for (unsigned int ind = 0; ind < _trial_variables.size(); ++ind) + { + _block_true_offsets[ind + 1] = _trial_variables.at(ind)->ParFESpace()->TrueVSize(); + } + _block_true_offsets.PartialSum(); + + _true_offsets.SetSize(_trial_variables.size() + 1); + _true_offsets[0] = 0; + for (unsigned int ind = 0; ind < _trial_variables.size(); ++ind) + { + _true_offsets[ind + 1] = _trial_variables.at(ind)->ParFESpace()->GetVSize(); + } + _true_offsets.PartialSum(); + + _true_x.Update(_block_true_offsets); + _true_rhs.Update(_block_true_offsets); +} + +void +ProblemOperatorInterface::Init(mfem::Vector & X) +{ + for (size_t i = 0; i < _trial_variables.size(); ++i) + { + mfem::ParGridFunction * trial_var = _trial_variables.at(i); + + trial_var->MakeRef(trial_var->ParFESpace(), const_cast(X), _true_offsets[i]); + *trial_var = 0.0; + } +} + +} \ No newline at end of file diff --git a/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C b/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C new file mode 100644 index 00000000..9a9d5be8 --- /dev/null +++ b/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C @@ -0,0 +1,61 @@ +#include "time_domain_equation_system_problem_operator.h" + +namespace hephaestus +{ + +void +TimeDomainEquationSystemProblemOperator::SetGridFunctions() +{ + _trial_var_names = GetEquationSystem()->_trial_var_names; + _trial_variable_time_derivatives = + _problem._gridfunctions.Get(GetEquationSystem()->_trial_var_time_derivative_names); + + TimeDomainProblemOperator::SetGridFunctions(); +} + +void +TimeDomainEquationSystemProblemOperator::Init(mfem::Vector & X) +{ + TimeDomainProblemOperator::Init(X); + + // Define material property coefficients + for (size_t i = 0; i < _trial_variables.size(); ++i) + { + *(_trial_variable_time_derivatives.at(i)) = 0.0; + } + + GetEquationSystem()->BuildEquationSystem(_problem._bc_map, _problem._sources); +} + +void +TimeDomainEquationSystemProblemOperator::ImplicitSolve(const double dt, + const mfem::Vector & X, + mfem::Vector & dX_dt) +{ + dX_dt = 0.0; + for (unsigned int ind = 0; ind < _trial_variables.size(); ++ind) + { + _trial_variables.at(ind)->MakeRef( + _trial_variables.at(ind)->ParFESpace(), const_cast(X), _true_offsets[ind]); + _trial_variable_time_derivatives.at(ind)->MakeRef( + _trial_variable_time_derivatives.at(ind)->ParFESpace(), dX_dt, _true_offsets[ind]); + } + _problem._coefficients.SetTime(GetTime()); + BuildEquationSystemOperator(dt); + + _problem._nonlinear_solver->SetSolver(*_problem._jacobian_solver); + _problem._nonlinear_solver->SetOperator(*GetEquationSystem()); + _problem._nonlinear_solver->Mult(_true_rhs, _true_x); + + GetEquationSystem()->RecoverFEMSolution(_true_x, _problem._gridfunctions); +} + +void +TimeDomainEquationSystemProblemOperator::BuildEquationSystemOperator(double dt) +{ + GetEquationSystem()->SetTimeStep(dt); + GetEquationSystem()->UpdateEquationSystem(_problem._bc_map, _problem._sources); + GetEquationSystem()->BuildJacobian(_true_x, _true_rhs); +} + +} // namespace hephaestus \ No newline at end of file diff --git a/framework/src/mfem/problem_operators/time_domain_problem_operator.C b/framework/src/mfem/problem_operators/time_domain_problem_operator.C new file mode 100644 index 00000000..7b991886 --- /dev/null +++ b/framework/src/mfem/problem_operators/time_domain_problem_operator.C @@ -0,0 +1,30 @@ +#include "time_domain_problem_operator.h" + +namespace hephaestus +{ + +std::string +GetTimeDerivativeName(const std::string & name) +{ + return std::string("d") + name + std::string("_dt"); +} + +std::vector +GetTimeDerivativeNames(std::vector gridfunction_names) +{ + std::vector time_derivative_names; + for (auto & gridfunction_name : gridfunction_names) + { + time_derivative_names.push_back(GetTimeDerivativeName(gridfunction_name)); + } + return time_derivative_names; +} + +void +TimeDomainProblemOperator::SetGridFunctions() +{ + ProblemOperatorInterface::SetGridFunctions(); + width = height = _true_offsets[_trial_variables.size()]; +} + +} // namespace hephaestus \ No newline at end of file From 5da020d93bd9c4c492c2656250335c96b5af49f0 Mon Sep 17 00:00:00 2001 From: Edward Palmer Date: Thu, 27 Jun 2024 10:15:11 +0000 Subject: [PATCH 5/8] Renames hephaestus namespace to platypus. --- .../include/mfem/bcs/MFEMBoundaryCondition.h | 4 +- .../include/mfem/bcs/boundary_conditions.h | 6 +-- .../mfem/equation_systems/equation_system.h | 46 +++++++++---------- .../mfem/kernels/MFEMDiffusionKernel.h | 9 ++-- framework/include/mfem/problem/MFEMProblem.h | 16 +++---- .../equation_system_problem_operator.h | 14 +++--- .../mfem/problem_operators/problem_operator.h | 6 +-- .../problem_operator_interface.h | 6 +-- ..._domain_equation_system_problem_operator.h | 14 +++--- .../time_domain_problem_operator.h | 6 +-- .../src/mfem/bcs/MFEMBoundaryCondition.C | 2 +- .../src/mfem/bcs/MFEMScalarDirichletBC.C | 2 +- .../src/mfem/bcs/MFEMVectorDirichletBC.C | 2 +- .../mfem/bcs/MFEMVectorNormalIntegratedBC.C | 2 +- framework/src/mfem/bcs/boundary_conditions.C | 16 +++---- .../mfem/equation_systems/equation_system.C | 26 +++++------ .../src/mfem/kernels/MFEMDiffusionKernel.C | 2 +- framework/src/mfem/problem/MFEMProblem.C | 19 ++++---- .../equation_system_problem_operator.C | 4 +- .../mfem/problem_operators/problem_operator.C | 4 +- .../problem_operator_interface.C | 2 +- ..._domain_equation_system_problem_operator.C | 4 +- .../time_domain_problem_operator.C | 4 +- 23 files changed, 106 insertions(+), 110 deletions(-) diff --git a/framework/include/mfem/bcs/MFEMBoundaryCondition.h b/framework/include/mfem/bcs/MFEMBoundaryCondition.h index 411a6185..c25d3473 100644 --- a/framework/include/mfem/bcs/MFEMBoundaryCondition.h +++ b/framework/include/mfem/bcs/MFEMBoundaryCondition.h @@ -14,7 +14,7 @@ class MFEMBoundaryCondition : public GeneralUserObject MFEMBoundaryCondition(const InputParameters & parameters); ~MFEMBoundaryCondition() override {} - inline virtual std::shared_ptr getBC() const + inline virtual std::shared_ptr getBC() const { return _boundary_condition; } @@ -27,5 +27,5 @@ class MFEMBoundaryCondition : public GeneralUserObject std::vector _boundary_names; mfem::Array bdr_attr; - std::shared_ptr _boundary_condition{nullptr}; + std::shared_ptr _boundary_condition{nullptr}; }; diff --git a/framework/include/mfem/bcs/boundary_conditions.h b/framework/include/mfem/bcs/boundary_conditions.h index 2da2a6f6..18f88174 100644 --- a/framework/include/mfem/bcs/boundary_conditions.h +++ b/framework/include/mfem/bcs/boundary_conditions.h @@ -4,10 +4,10 @@ #include "named_fields_map.h" #include "robin_bcs.h" -namespace hephaestus +namespace platypus { -class BCMap : public hephaestus::NamedFieldsMap +class BCMap : public platypus::NamedFieldsMap { public: mfem::Array GetEssentialBdrMarkers(const std::string & name_, mfem::Mesh * mesh_); @@ -33,4 +33,4 @@ class BCMap : public hephaestus::NamedFieldsMap mfem::Mesh * mesh_); }; -} // namespace hephaestus +} // namespace platypus diff --git a/framework/include/mfem/equation_systems/equation_system.h b/framework/include/mfem/equation_systems/equation_system.h index fd99db92..62437cb8 100644 --- a/framework/include/mfem/equation_systems/equation_system.h +++ b/framework/include/mfem/equation_systems/equation_system.h @@ -5,7 +5,7 @@ #include "named_fields_map.h" #include "sources.h" -namespace hephaestus +namespace platypus { /* @@ -15,10 +15,10 @@ mixed and nonlinear forms) and build methods class EquationSystem : public mfem::Operator { public: - using ParBilinearFormKernel = hephaestus::Kernel; - using ParLinearFormKernel = hephaestus::Kernel; - using ParNonlinearFormKernel = hephaestus::Kernel; - using ParMixedBilinearFormKernel = hephaestus::Kernel; + using ParBilinearFormKernel = platypus::Kernel; + using ParLinearFormKernel = platypus::Kernel; + using ParNonlinearFormKernel = platypus::Kernel; + using ParMixedBilinearFormKernel = platypus::Kernel; EquationSystem() = default; ~EquationSystem() override; @@ -35,10 +35,10 @@ class EquationSystem : public mfem::Operator std::vector _test_pfespaces; // Components of weak form. // Named according to test variable - hephaestus::NamedFieldsMap _blfs; - hephaestus::NamedFieldsMap _lfs; - hephaestus::NamedFieldsMap _nlfs; - hephaestus::NamedFieldsMap> + platypus::NamedFieldsMap _blfs; + platypus::NamedFieldsMap _lfs; + platypus::NamedFieldsMap _nlfs; + platypus::NamedFieldsMap> _mblfs; // named according to trial variable // add test variable to EquationSystem; @@ -58,20 +58,20 @@ class EquationSystem : public mfem::Operator const std::string & test_var_name, std::shared_ptr mblf_kernel); - virtual void ApplyBoundaryConditions(hephaestus::BCMap & bc_map); + virtual void ApplyBoundaryConditions(platypus::BCMap & bc_map); // override to add kernels virtual void AddKernels() {} // Build forms - virtual void Init(hephaestus::GridFunctions & gridfunctions, - const hephaestus::FESpaces & fespaces, - hephaestus::BCMap & bc_map, + virtual void Init(platypus::GridFunctions & gridfunctions, + const platypus::FESpaces & fespaces, + platypus::BCMap & bc_map, Coefficients & coefficients); - virtual void BuildLinearForms(hephaestus::BCMap & bc_map, hephaestus::Sources & sources); + virtual void BuildLinearForms(platypus::BCMap & bc_map, platypus::Sources & sources); virtual void BuildBilinearForms(); virtual void BuildMixedBilinearForms(); - virtual void BuildEquationSystem(hephaestus::BCMap & bc_map, hephaestus::Sources & sources); + virtual void BuildEquationSystem(platypus::BCMap & bc_map, platypus::Sources & sources); // Form linear system, with essential boundary conditions accounted for virtual void FormLinearSystem(mfem::OperatorHandle & op, @@ -89,7 +89,7 @@ class EquationSystem : public mfem::Operator // Update variable from solution vector after solve virtual void RecoverFEMSolution(mfem::BlockVector & trueX, - hephaestus::GridFunctions & gridfunctions); + platypus::GridFunctions & gridfunctions); std::vector> _ess_tdof_lists; @@ -104,14 +104,14 @@ class EquationSystem : public mfem::Operator // Arrays to store kernels to act on each component of weak form. Named // according to test variable - hephaestus::NamedFieldsMap>> _blf_kernels_map; + platypus::NamedFieldsMap>> _blf_kernels_map; - hephaestus::NamedFieldsMap>> _lf_kernels_map; + platypus::NamedFieldsMap>> _lf_kernels_map; - hephaestus::NamedFieldsMap>> _nlf_kernels_map; + platypus::NamedFieldsMap>> _nlf_kernels_map; - hephaestus::NamedFieldsMap< - hephaestus::NamedFieldsMap>>> + platypus::NamedFieldsMap< + platypus::NamedFieldsMap>>> _mblf_kernels_map_map; mutable mfem::OperatorHandle _jacobian; @@ -134,9 +134,9 @@ class TimeDependentEquationSystem : public EquationSystem void AddTrialVariableNameIfMissing(const std::string & trial_var_name) override; virtual void SetTimeStep(double dt); - virtual void UpdateEquationSystem(hephaestus::BCMap & bc_map, hephaestus::Sources & sources); + virtual void UpdateEquationSystem(platypus::BCMap & bc_map, platypus::Sources & sources); mfem::ConstantCoefficient _dt_coef; // Coefficient for timestep scaling std::vector _trial_var_time_derivative_names; }; -} // namespace hephaestus +} // namespace platypus diff --git a/framework/include/mfem/kernels/MFEMDiffusionKernel.h b/framework/include/mfem/kernels/MFEMDiffusionKernel.h index 24013432..b8c3cf6d 100644 --- a/framework/include/mfem/kernels/MFEMDiffusionKernel.h +++ b/framework/include/mfem/kernels/MFEMDiffusionKernel.h @@ -14,12 +14,9 @@ class MFEMDiffusionKernel : public MFEMBilinearFormKernel virtual void initialize() override {} virtual void finalize() override {} - std::shared_ptr> getKernel() override - { - return _kernel; - } + std::shared_ptr> getKernel() override { return _kernel; } protected: - hephaestus::InputParameters _kernel_params; - std::shared_ptr _kernel{nullptr}; + platypus::InputParameters _kernel_params; + std::shared_ptr _kernel{nullptr}; }; diff --git a/framework/include/mfem/problem/MFEMProblem.h b/framework/include/mfem/problem/MFEMProblem.h index ab6eea5e..0da282e8 100644 --- a/framework/include/mfem/problem/MFEMProblem.h +++ b/framework/include/mfem/problem/MFEMProblem.h @@ -151,9 +151,9 @@ class MFEMProblem : public ExternalProblem * builders. */ template - void addKernel(std::string var_name, std::shared_ptr> kernel) + void addKernel(std::string var_name, std::shared_ptr> kernel) { - using namespace hephaestus; + using namespace platypus; EquationSystemProblemBuilderInterface * eqn_system_problem_builder{nullptr}; @@ -174,12 +174,12 @@ class MFEMProblem : public ExternalProblem int _order; Coefficients _coefficients; - hephaestus::InputParameters _solver_options; - hephaestus::Outputs _outputs; - hephaestus::InputParameters _exec_params; + platypus::InputParameters _solver_options; + platypus::Outputs _outputs; + platypus::InputParameters _exec_params; - std::shared_ptr mfem_problem_builder{nullptr}; + std::shared_ptr mfem_problem_builder{nullptr}; - std::unique_ptr mfem_problem{nullptr}; - std::unique_ptr executioner{nullptr}; + std::unique_ptr mfem_problem{nullptr}; + std::unique_ptr executioner{nullptr}; }; diff --git a/framework/include/mfem/problem_operators/equation_system_problem_operator.h b/framework/include/mfem/problem_operators/equation_system_problem_operator.h index fc489cac..9b507a18 100644 --- a/framework/include/mfem/problem_operators/equation_system_problem_operator.h +++ b/framework/include/mfem/problem_operators/equation_system_problem_operator.h @@ -3,16 +3,16 @@ #include "problem_operator_interface.h" #include "equation_system_interface.h" -namespace hephaestus +namespace platypus { /// Steady-state problem operator with an equation system. class EquationSystemProblemOperator : public ProblemOperator, public EquationSystemInterface { public: - EquationSystemProblemOperator(hephaestus::Problem &) = delete; + EquationSystemProblemOperator(platypus::Problem &) = delete; - EquationSystemProblemOperator(hephaestus::Problem & problem, - std::unique_ptr equation_system) + EquationSystemProblemOperator(platypus::Problem & problem, + std::unique_ptr equation_system) : ProblemOperator(problem), _equation_system(std::move(equation_system)) { } @@ -22,7 +22,7 @@ class EquationSystemProblemOperator : public ProblemOperator, public EquationSys ~EquationSystemProblemOperator() override = default; - [[nodiscard]] hephaestus::EquationSystem * GetEquationSystem() const override + [[nodiscard]] platypus::EquationSystem * GetEquationSystem() const override { if (!_equation_system) { @@ -33,7 +33,7 @@ class EquationSystemProblemOperator : public ProblemOperator, public EquationSys } private: - std::unique_ptr _equation_system{nullptr}; + std::unique_ptr _equation_system{nullptr}; }; -} // namespace hephaestus \ No newline at end of file +} // namespace platypus \ No newline at end of file diff --git a/framework/include/mfem/problem_operators/problem_operator.h b/framework/include/mfem/problem_operators/problem_operator.h index c127ffa4..f07c3947 100644 --- a/framework/include/mfem/problem_operators/problem_operator.h +++ b/framework/include/mfem/problem_operators/problem_operator.h @@ -4,13 +4,13 @@ #include "problem_builder_base.h" #include "problem_operator_interface.h" -namespace hephaestus +namespace platypus { /// Steady-state problem operator with no equation system. class ProblemOperator : public mfem::Operator, public ProblemOperatorInterface { public: - ProblemOperator(hephaestus::Problem & problem) : ProblemOperatorInterface(problem) {} + ProblemOperator(platypus::Problem & problem) : ProblemOperatorInterface(problem) {} ~ProblemOperator() override = default; void SetGridFunctions() override; @@ -19,4 +19,4 @@ class ProblemOperator : public mfem::Operator, public ProblemOperatorInterface void Mult(const mfem::Vector & x, mfem::Vector & y) const override {} }; -} // namespace hephaestus \ No newline at end of file +} // namespace platypus \ No newline at end of file diff --git a/framework/include/mfem/problem_operators/problem_operator_interface.h b/framework/include/mfem/problem_operators/problem_operator_interface.h index 70f55b11..efd3ab88 100644 --- a/framework/include/mfem/problem_operators/problem_operator_interface.h +++ b/framework/include/mfem/problem_operators/problem_operator_interface.h @@ -1,13 +1,13 @@ #pragma once #include "problem_builder_base.h" -namespace hephaestus +namespace platypus { /// Interface inherited by ProblemOperator and TimeDomainProblemOperator. Removes duplicated code in both classes. class ProblemOperatorInterface { public: - ProblemOperatorInterface(hephaestus::Problem & problem) : _problem(problem) {} + ProblemOperatorInterface(platypus::Problem & problem) : _problem(problem) {} virtual ~ProblemOperatorInterface() = default; virtual void SetGridFunctions(); @@ -20,7 +20,7 @@ class ProblemOperatorInterface protected: // Reference to the current problem. - hephaestus::Problem & _problem; + platypus::Problem & _problem; // Vector of names of state gridfunctions used in formulation, ordered by appearance in block // vector during solve. diff --git a/framework/include/mfem/problem_operators/time_domain_equation_system_problem_operator.h b/framework/include/mfem/problem_operators/time_domain_equation_system_problem_operator.h index 87d7ef08..970aa421 100644 --- a/framework/include/mfem/problem_operators/time_domain_equation_system_problem_operator.h +++ b/framework/include/mfem/problem_operators/time_domain_equation_system_problem_operator.h @@ -4,7 +4,7 @@ #include "problem_operator_interface.h" #include "equation_system_interface.h" -namespace hephaestus +namespace platypus { /// Problem operator for time-dependent problems with an equation system. @@ -12,10 +12,10 @@ class TimeDomainEquationSystemProblemOperator : public TimeDomainProblemOperator public EquationSystemInterface { public: - TimeDomainEquationSystemProblemOperator(hephaestus::Problem &) = delete; + TimeDomainEquationSystemProblemOperator(platypus::Problem &) = delete; TimeDomainEquationSystemProblemOperator( - hephaestus::Problem & problem, - std::unique_ptr equation_system) + platypus::Problem & problem, + std::unique_ptr equation_system) : TimeDomainProblemOperator(problem), _equation_system{std::move(equation_system)} { } @@ -25,7 +25,7 @@ class TimeDomainEquationSystemProblemOperator : public TimeDomainProblemOperator void ImplicitSolve(const double dt, const mfem::Vector & X, mfem::Vector & dX_dt) override; - [[nodiscard]] hephaestus::TimeDependentEquationSystem * GetEquationSystem() const override + [[nodiscard]] platypus::TimeDependentEquationSystem * GetEquationSystem() const override { if (!_equation_system) { @@ -40,7 +40,7 @@ class TimeDomainEquationSystemProblemOperator : public TimeDomainProblemOperator private: std::vector _trial_variable_time_derivatives; - std::unique_ptr _equation_system{nullptr}; + std::unique_ptr _equation_system{nullptr}; }; -} // namespace hephaestus \ No newline at end of file +} // namespace platypus \ No newline at end of file diff --git a/framework/include/mfem/problem_operators/time_domain_problem_operator.h b/framework/include/mfem/problem_operators/time_domain_problem_operator.h index dd695ffe..73160f44 100644 --- a/framework/include/mfem/problem_operators/time_domain_problem_operator.h +++ b/framework/include/mfem/problem_operators/time_domain_problem_operator.h @@ -4,7 +4,7 @@ #include "problem_builder_base.h" #include "problem_operator_interface.h" -namespace hephaestus +namespace platypus { std::string GetTimeDerivativeName(const std::string & name); @@ -17,7 +17,7 @@ class TimeDomainProblemOperator : public mfem::TimeDependentOperator, public ProblemOperatorInterface { public: - TimeDomainProblemOperator(hephaestus::Problem & problem) : ProblemOperatorInterface(problem) {} + TimeDomainProblemOperator(platypus::Problem & problem) : ProblemOperatorInterface(problem) {} ~TimeDomainProblemOperator() override = default; void SetGridFunctions() override; @@ -25,4 +25,4 @@ class TimeDomainProblemOperator : public mfem::TimeDependentOperator, void ImplicitSolve(const double dt, const mfem::Vector & X, mfem::Vector & dX_dt) override {} }; -} // namespace hephaestus \ No newline at end of file +} // namespace platypus \ No newline at end of file diff --git a/framework/src/mfem/bcs/MFEMBoundaryCondition.C b/framework/src/mfem/bcs/MFEMBoundaryCondition.C index 6d596296..75c169bd 100644 --- a/framework/src/mfem/bcs/MFEMBoundaryCondition.C +++ b/framework/src/mfem/bcs/MFEMBoundaryCondition.C @@ -27,5 +27,5 @@ MFEMBoundaryCondition::MFEMBoundaryCondition(const InputParameters & parameters) bdr_attr[i] = std::stoi(_boundary_names[i]); } _boundary_condition = - std::make_shared(getParam("variable"), bdr_attr); + std::make_shared(getParam("variable"), bdr_attr); } diff --git a/framework/src/mfem/bcs/MFEMScalarDirichletBC.C b/framework/src/mfem/bcs/MFEMScalarDirichletBC.C index 90d68e61..74aba027 100644 --- a/framework/src/mfem/bcs/MFEMScalarDirichletBC.C +++ b/framework/src/mfem/bcs/MFEMScalarDirichletBC.C @@ -15,6 +15,6 @@ MFEMScalarDirichletBC::MFEMScalarDirichletBC(const InputParameters & parameters) : MFEMBoundaryCondition(parameters), _coef(const_cast(&getUserObject("coefficient"))) { - _boundary_condition = std::make_shared( + _boundary_condition = std::make_shared( getParam("variable"), bdr_attr, _coef->getCoefficient().get()); } diff --git a/framework/src/mfem/bcs/MFEMVectorDirichletBC.C b/framework/src/mfem/bcs/MFEMVectorDirichletBC.C index 496a1aa1..3e806ea7 100644 --- a/framework/src/mfem/bcs/MFEMVectorDirichletBC.C +++ b/framework/src/mfem/bcs/MFEMVectorDirichletBC.C @@ -17,6 +17,6 @@ MFEMVectorDirichletBC::MFEMVectorDirichletBC(const InputParameters & parameters) _vec_coef(const_cast( &getUserObject("vector_coefficient"))) { - _boundary_condition = std::make_shared( + _boundary_condition = std::make_shared( getParam("variable"), bdr_attr, _vec_coef->getVectorCoefficient().get()); } diff --git a/framework/src/mfem/bcs/MFEMVectorNormalIntegratedBC.C b/framework/src/mfem/bcs/MFEMVectorNormalIntegratedBC.C index 8c4e1fe9..0741e0ef 100644 --- a/framework/src/mfem/bcs/MFEMVectorNormalIntegratedBC.C +++ b/framework/src/mfem/bcs/MFEMVectorNormalIntegratedBC.C @@ -19,7 +19,7 @@ MFEMVectorNormalIntegratedBC::MFEMVectorNormalIntegratedBC(const InputParameters &getUserObject("vector_coefficient"))) { - _boundary_condition = std::make_shared( + _boundary_condition = std::make_shared( getParam("variable"), bdr_attr, std::make_unique(*_vec_coef->getVectorCoefficient())); diff --git a/framework/src/mfem/bcs/boundary_conditions.C b/framework/src/mfem/bcs/boundary_conditions.C index d6131d9d..3260b09b 100644 --- a/framework/src/mfem/bcs/boundary_conditions.C +++ b/framework/src/mfem/bcs/boundary_conditions.C @@ -1,6 +1,6 @@ #include "boundary_conditions.h" -namespace hephaestus +namespace platypus { mfem::Array @@ -15,7 +15,7 @@ BCMap::GetEssentialBdrMarkers(const std::string & name_, mfem::Mesh * mesh_) { if (bc_->_name == name_) { - auto bc = std::dynamic_pointer_cast(bc_); + auto bc = std::dynamic_pointer_cast(bc_); if (bc != nullptr) { ess_bdrs = bc->GetMarkers(*mesh_); @@ -39,7 +39,7 @@ BCMap::ApplyEssentialBCs(const std::string & name_, { if (bc_->_name == name_) { - auto bc = std::dynamic_pointer_cast(bc_); + auto bc = std::dynamic_pointer_cast(bc_); if (bc != nullptr) { bc->ApplyBC(gridfunc, mesh_); @@ -60,7 +60,7 @@ BCMap::ApplyEssentialBCs(const std::string & name_, { if (bc_->_name == name_) { - auto bc = std::dynamic_pointer_cast(bc_); + auto bc = std::dynamic_pointer_cast(bc_); if (bc != nullptr) { bc->ApplyBC(gridfunc, mesh_); @@ -79,7 +79,7 @@ BCMap::ApplyIntegratedBCs(const std::string & name_, mfem::LinearForm & lf, mfem { if (bc_->_name == name_) { - auto bc = std::dynamic_pointer_cast(bc_); + auto bc = std::dynamic_pointer_cast(bc_); if (bc != nullptr) { bc->GetMarkers(*mesh_); @@ -99,7 +99,7 @@ BCMap::ApplyIntegratedBCs(const std::string & name_, { if (bc_->_name == name_) { - auto bc = std::dynamic_pointer_cast(bc_); + auto bc = std::dynamic_pointer_cast(bc_); if (bc != nullptr) { bc->GetMarkers(*mesh_); @@ -118,7 +118,7 @@ BCMap::ApplyIntegratedBCs(const std::string & name_, { if (bc_->_name == name_) { - auto bc = std::dynamic_pointer_cast(bc_); + auto bc = std::dynamic_pointer_cast(bc_); if (bc != nullptr) { bc->GetMarkers(*mesh_); @@ -128,4 +128,4 @@ BCMap::ApplyIntegratedBCs(const std::string & name_, } }; -} // namespace hephaestus +} // namespace platypus diff --git a/framework/src/mfem/equation_systems/equation_system.C b/framework/src/mfem/equation_systems/equation_system.C index b3b6eafd..ac57a714 100644 --- a/framework/src/mfem/equation_systems/equation_system.C +++ b/framework/src/mfem/equation_systems/equation_system.C @@ -1,6 +1,6 @@ #include "equation_system.h" -namespace hephaestus +namespace platypus { EquationSystem::~EquationSystem() { _h_blocks.DeleteAll(); } @@ -94,7 +94,7 @@ EquationSystem::AddKernel(const std::string & trial_var_name, if (!_mblf_kernels_map_map.Has(test_var_name)) { auto kernel_field_map = std::make_shared< - hephaestus::NamedFieldsMap>>>(); + platypus::NamedFieldsMap>>>(); _mblf_kernels_map_map.Register(test_var_name, std::move(kernel_field_map)); } @@ -114,7 +114,7 @@ EquationSystem::AddKernel(const std::string & trial_var_name, } void -EquationSystem::ApplyBoundaryConditions(hephaestus::BCMap & bc_map) +EquationSystem::ApplyBoundaryConditions(platypus::BCMap & bc_map) { _ess_tdof_lists.resize(_test_var_names.size()); for (int i = 0; i < _test_var_names.size(); i++) @@ -211,7 +211,7 @@ EquationSystem::GetGradient(const mfem::Vector & u) const void EquationSystem::RecoverFEMSolution(mfem::BlockVector & trueX, - hephaestus::GridFunctions & gridfunctions) + platypus::GridFunctions & gridfunctions) { for (int i = 0; i < _test_var_names.size(); i++) { @@ -222,9 +222,9 @@ EquationSystem::RecoverFEMSolution(mfem::BlockVector & trueX, } void -EquationSystem::Init(hephaestus::GridFunctions & gridfunctions, - const hephaestus::FESpaces & fespaces, - hephaestus::BCMap & bc_map, +EquationSystem::Init(platypus::GridFunctions & gridfunctions, + const platypus::FESpaces & fespaces, + platypus::BCMap & bc_map, Coefficients & coefficients) { @@ -285,7 +285,7 @@ EquationSystem::Init(hephaestus::GridFunctions & gridfunctions, } void -EquationSystem::BuildLinearForms(hephaestus::BCMap & bc_map, hephaestus::Sources & sources) +EquationSystem::BuildLinearForms(platypus::BCMap & bc_map, platypus::Sources & sources) { // Register linear forms for (int i = 0; i < _test_var_names.size(); i++) @@ -356,7 +356,7 @@ EquationSystem::BuildMixedBilinearForms() for (int i = 0; i < _test_var_names.size(); i++) { auto test_var_name = _test_var_names.at(i); - auto test_mblfs = std::make_shared>(); + auto test_mblfs = std::make_shared>(); for (int j = 0; j < _test_var_names.size(); j++) { auto trial_var_name = _test_var_names.at(j); @@ -388,7 +388,7 @@ EquationSystem::BuildMixedBilinearForms() } void -EquationSystem::BuildEquationSystem(hephaestus::BCMap & bc_map, hephaestus::Sources & sources) +EquationSystem::BuildEquationSystem(platypus::BCMap & bc_map, platypus::Sources & sources) { BuildLinearForms(bc_map, sources); BuildBilinearForms(); @@ -426,12 +426,12 @@ TimeDependentEquationSystem::SetTimeStep(double dt) } void -TimeDependentEquationSystem::UpdateEquationSystem(hephaestus::BCMap & bc_map, - hephaestus::Sources & sources) +TimeDependentEquationSystem::UpdateEquationSystem(platypus::BCMap & bc_map, + platypus::Sources & sources) { BuildLinearForms(bc_map, sources); BuildBilinearForms(); BuildMixedBilinearForms(); } -} // namespace hephaestus +} // namespace platypus diff --git a/framework/src/mfem/kernels/MFEMDiffusionKernel.C b/framework/src/mfem/kernels/MFEMDiffusionKernel.C index bdd2ee3f..0c22086d 100644 --- a/framework/src/mfem/kernels/MFEMDiffusionKernel.C +++ b/framework/src/mfem/kernels/MFEMDiffusionKernel.C @@ -20,6 +20,6 @@ MFEMDiffusionKernel::MFEMDiffusionKernel(const InputParameters & parameters) : MFEMBilinearFormKernel(parameters), _kernel_params{{{"VariableName", getParam("variable")}, {"CoefficientName", getParam("coefficient")}}}, - _kernel{std::make_shared(_kernel_params)} + _kernel{std::make_shared(_kernel_params)} { } diff --git a/framework/src/mfem/problem/MFEMProblem.C b/framework/src/mfem/problem/MFEMProblem.C index 71ba179a..34361880 100644 --- a/framework/src/mfem/problem/MFEMProblem.C +++ b/framework/src/mfem/problem/MFEMProblem.C @@ -68,13 +68,13 @@ MFEMProblem::initialSetup() // NB: set to false to avoid reconstructing problem operator. mfem_problem_builder->FinalizeProblem(false); - hephaestus::InputParameters exec_params; + platypus::InputParameters exec_params; Transient * _moose_executioner = dynamic_cast(_app.getExecutioner()); if (_moose_executioner != nullptr) { auto mfem_transient_problem_builder = - std::dynamic_pointer_cast(mfem_problem_builder); + std::dynamic_pointer_cast(mfem_problem_builder); if (mfem_transient_problem_builder == nullptr) { mooseError("Specified formulation does not support Transient executioners"); @@ -86,15 +86,14 @@ MFEMProblem::initialSetup() exec_params.SetParam("TimeStep", float(dt())); exec_params.SetParam("EndTime", float(_moose_executioner->endTime())); exec_params.SetParam("VisualisationSteps", getParam("vis_steps")); - exec_params.SetParam("Problem", - static_cast(mfem_problem.get())); + exec_params.SetParam("Problem", static_cast(mfem_problem.get())); - executioner = std::make_unique(exec_params); + executioner = std::make_unique(exec_params); } else if (dynamic_cast(_app.getExecutioner())) { auto mfem_steady_problem_builder = - std::dynamic_pointer_cast(mfem_problem_builder); + std::dynamic_pointer_cast(mfem_problem_builder); if (mfem_steady_problem_builder == nullptr) { mooseError("Specified formulation does not support Steady executioners"); @@ -103,9 +102,9 @@ MFEMProblem::initialSetup() mfem_problem = mfem_steady_problem_builder->ReturnProblem(); exec_params.SetParam("Problem", - static_cast(mfem_problem.get())); + static_cast(mfem_problem.get())); - executioner = std::make_unique(exec_params); + executioner = std::make_unique(exec_params); } else { @@ -129,7 +128,7 @@ MFEMProblem::externalSolve() return; } - auto * transient_mfem_exec = dynamic_cast(executioner.get()); + auto * transient_mfem_exec = dynamic_cast(executioner.get()); if (transient_mfem_exec != nullptr) { transient_mfem_exec->_t_step = dt(); @@ -189,7 +188,7 @@ MFEMProblem::addCoefficient(const std::string & user_object_name, _coefficients._scalars.Register(name, mfem_coef->getCoefficient()); // Add associated auxsolvers for CoupledCoefficients - auto coupled_coef = std::dynamic_pointer_cast( + auto coupled_coef = std::dynamic_pointer_cast( _coefficients._scalars.GetShared(name)); if (coupled_coef != nullptr) { diff --git a/framework/src/mfem/problem_operators/equation_system_problem_operator.C b/framework/src/mfem/problem_operators/equation_system_problem_operator.C index 78019937..9c9b8fe0 100644 --- a/framework/src/mfem/problem_operators/equation_system_problem_operator.C +++ b/framework/src/mfem/problem_operators/equation_system_problem_operator.C @@ -1,6 +1,6 @@ #include "equation_system_problem_operator.h" -namespace hephaestus +namespace platypus { void EquationSystemProblemOperator::SetGridFunctions() @@ -17,4 +17,4 @@ EquationSystemProblemOperator::Init(mfem::Vector & X) GetEquationSystem()->BuildEquationSystem(_problem._bc_map, _problem._sources); } -} // namespace hephaestus \ No newline at end of file +} // namespace platypus \ No newline at end of file diff --git a/framework/src/mfem/problem_operators/problem_operator.C b/framework/src/mfem/problem_operators/problem_operator.C index 33323510..e6f3c034 100644 --- a/framework/src/mfem/problem_operators/problem_operator.C +++ b/framework/src/mfem/problem_operators/problem_operator.C @@ -1,6 +1,6 @@ #include "problem_operator.h" -namespace hephaestus +namespace platypus { void @@ -10,4 +10,4 @@ ProblemOperator::SetGridFunctions() width = height = _true_offsets[_trial_variables.size()]; }; -} // namespace hephaestus \ No newline at end of file +} // namespace platypus \ No newline at end of file diff --git a/framework/src/mfem/problem_operators/problem_operator_interface.C b/framework/src/mfem/problem_operators/problem_operator_interface.C index e49043f0..170b4f2c 100644 --- a/framework/src/mfem/problem_operators/problem_operator_interface.C +++ b/framework/src/mfem/problem_operators/problem_operator_interface.C @@ -1,6 +1,6 @@ #include "problem_operator_interface.h" -namespace hephaestus +namespace platypus { void ProblemOperatorInterface::SetGridFunctions() diff --git a/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C b/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C index 9a9d5be8..80e21aca 100644 --- a/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C +++ b/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C @@ -1,6 +1,6 @@ #include "time_domain_equation_system_problem_operator.h" -namespace hephaestus +namespace platypus { void @@ -58,4 +58,4 @@ TimeDomainEquationSystemProblemOperator::BuildEquationSystemOperator(double dt) GetEquationSystem()->BuildJacobian(_true_x, _true_rhs); } -} // namespace hephaestus \ No newline at end of file +} // namespace platypus \ No newline at end of file diff --git a/framework/src/mfem/problem_operators/time_domain_problem_operator.C b/framework/src/mfem/problem_operators/time_domain_problem_operator.C index 7b991886..68cbf7ae 100644 --- a/framework/src/mfem/problem_operators/time_domain_problem_operator.C +++ b/framework/src/mfem/problem_operators/time_domain_problem_operator.C @@ -1,6 +1,6 @@ #include "time_domain_problem_operator.h" -namespace hephaestus +namespace platypus { std::string @@ -27,4 +27,4 @@ TimeDomainProblemOperator::SetGridFunctions() width = height = _true_offsets[_trial_variables.size()]; } -} // namespace hephaestus \ No newline at end of file +} // namespace platypus \ No newline at end of file From c7417e8b888ba2de198dc6edba46bd014c0b1956 Mon Sep 17 00:00:00 2001 From: Edward Palmer Date: Thu, 27 Jun 2024 10:15:51 +0000 Subject: [PATCH 6/8] Renames hephaestus to platypus. --- framework/include/mfem/problem/MFEMProblem.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/framework/include/mfem/problem/MFEMProblem.h b/framework/include/mfem/problem/MFEMProblem.h index 0da282e8..e5d96002 100644 --- a/framework/include/mfem/problem/MFEMProblem.h +++ b/framework/include/mfem/problem/MFEMProblem.h @@ -23,7 +23,7 @@ #include "SystemBase.h" #include "Transient.h" #include "Steady.h" -#include "hephaestus.h" +#include "platypus.h" #include "libmesh/string_to_enum.h" #include "libmesh/point.h" From 986c92ca2e81d56d6f62daa978d947a79c310b05 Mon Sep 17 00:00:00 2001 From: Edward Palmer Date: Thu, 27 Jun 2024 10:15:51 +0000 Subject: [PATCH 7/8] Puts Subdomain and Coefficients back into namespaces. --- framework/include/mfem/equation_systems/equation_system.h | 2 +- framework/include/mfem/materials/MFEMMaterial.h | 2 +- framework/include/mfem/problem/MFEMProblem.h | 2 +- framework/src/mfem/equation_systems/equation_system.C | 2 +- framework/src/mfem/problem/MFEMProblem.C | 2 +- 5 files changed, 5 insertions(+), 5 deletions(-) diff --git a/framework/include/mfem/equation_systems/equation_system.h b/framework/include/mfem/equation_systems/equation_system.h index 62437cb8..7784051f 100644 --- a/framework/include/mfem/equation_systems/equation_system.h +++ b/framework/include/mfem/equation_systems/equation_system.h @@ -67,7 +67,7 @@ class EquationSystem : public mfem::Operator virtual void Init(platypus::GridFunctions & gridfunctions, const platypus::FESpaces & fespaces, platypus::BCMap & bc_map, - Coefficients & coefficients); + platypus::Coefficients & coefficients); virtual void BuildLinearForms(platypus::BCMap & bc_map, platypus::Sources & sources); virtual void BuildBilinearForms(); virtual void BuildMixedBilinearForms(); diff --git a/framework/include/mfem/materials/MFEMMaterial.h b/framework/include/mfem/materials/MFEMMaterial.h index 14c49fde..d4a3e5c5 100644 --- a/framework/include/mfem/materials/MFEMMaterial.h +++ b/framework/include/mfem/materials/MFEMMaterial.h @@ -16,7 +16,7 @@ class MFEMMaterial : public GeneralUserObject virtual void initialize() override {} virtual void finalize() override {} - virtual void storeCoefficients(Subdomain & subdomain) {} + virtual void storeCoefficients(platypus::Subdomain & subdomain) {} std::vector blocks; }; diff --git a/framework/include/mfem/problem/MFEMProblem.h b/framework/include/mfem/problem/MFEMProblem.h index e5d96002..55b93d98 100644 --- a/framework/include/mfem/problem/MFEMProblem.h +++ b/framework/include/mfem/problem/MFEMProblem.h @@ -173,7 +173,7 @@ class MFEMProblem : public ExternalProblem std::string _formulation_name; int _order; - Coefficients _coefficients; + platypus::Coefficients _coefficients; platypus::InputParameters _solver_options; platypus::Outputs _outputs; platypus::InputParameters _exec_params; diff --git a/framework/src/mfem/equation_systems/equation_system.C b/framework/src/mfem/equation_systems/equation_system.C index ac57a714..216d8fe7 100644 --- a/framework/src/mfem/equation_systems/equation_system.C +++ b/framework/src/mfem/equation_systems/equation_system.C @@ -225,7 +225,7 @@ void EquationSystem::Init(platypus::GridFunctions & gridfunctions, const platypus::FESpaces & fespaces, platypus::BCMap & bc_map, - Coefficients & coefficients) + platypus::Coefficients & coefficients) { // Add optional kernels to the EquationSystem diff --git a/framework/src/mfem/problem/MFEMProblem.C b/framework/src/mfem/problem/MFEMProblem.C index 34361880..ccb3c249 100644 --- a/framework/src/mfem/problem/MFEMProblem.C +++ b/framework/src/mfem/problem/MFEMProblem.C @@ -172,7 +172,7 @@ MFEMProblem::addMaterial(const std::string & kernel_name, for (unsigned int bid = 0; bid < mfem_material.blocks.size(); ++bid) { int block = std::stoi(mfem_material.blocks[bid]); - Subdomain mfem_subdomain(name, block); + platypus::Subdomain mfem_subdomain(name, block); mfem_material.storeCoefficients(mfem_subdomain); _coefficients._subdomains.push_back(mfem_subdomain); } From f1614b2bddf0934ad0bec210ae60b18f4f80c00f Mon Sep 17 00:00:00 2001 From: Edward Palmer Date: Fri, 28 Jun 2024 14:45:58 +0000 Subject: [PATCH 8/8] Removes sources and auxsolvers. --- .../mfem/equation_systems/equation_system.h | 7 +++---- framework/include/mfem/problem/MFEMProblem.h | 5 +---- .../mfem/equation_systems/equation_system.C | 16 +++++---------- framework/src/mfem/problem/MFEMProblem.C | 20 ++----------------- .../equation_system_problem_operator.C | 2 +- ..._domain_equation_system_problem_operator.C | 4 ++-- 6 files changed, 14 insertions(+), 40 deletions(-) diff --git a/framework/include/mfem/equation_systems/equation_system.h b/framework/include/mfem/equation_systems/equation_system.h index 7784051f..0f380ead 100644 --- a/framework/include/mfem/equation_systems/equation_system.h +++ b/framework/include/mfem/equation_systems/equation_system.h @@ -3,7 +3,6 @@ #include "inputs.h" #include "kernel_base.h" #include "named_fields_map.h" -#include "sources.h" namespace platypus { @@ -68,10 +67,10 @@ class EquationSystem : public mfem::Operator const platypus::FESpaces & fespaces, platypus::BCMap & bc_map, platypus::Coefficients & coefficients); - virtual void BuildLinearForms(platypus::BCMap & bc_map, platypus::Sources & sources); + virtual void BuildLinearForms(platypus::BCMap & bc_map); virtual void BuildBilinearForms(); virtual void BuildMixedBilinearForms(); - virtual void BuildEquationSystem(platypus::BCMap & bc_map, platypus::Sources & sources); + virtual void BuildEquationSystem(platypus::BCMap & bc_map); // Form linear system, with essential boundary conditions accounted for virtual void FormLinearSystem(mfem::OperatorHandle & op, @@ -134,7 +133,7 @@ class TimeDependentEquationSystem : public EquationSystem void AddTrialVariableNameIfMissing(const std::string & trial_var_name) override; virtual void SetTimeStep(double dt); - virtual void UpdateEquationSystem(platypus::BCMap & bc_map, platypus::Sources & sources); + virtual void UpdateEquationSystem(platypus::BCMap & bc_map); mfem::ConstantCoefficient _dt_coef; // Coefficient for timestep scaling std::vector _trial_var_time_derivative_names; }; diff --git a/framework/include/mfem/problem/MFEMProblem.h b/framework/include/mfem/problem/MFEMProblem.h index 55b93d98..4481413d 100644 --- a/framework/include/mfem/problem/MFEMProblem.h +++ b/framework/include/mfem/problem/MFEMProblem.h @@ -15,7 +15,6 @@ #include "MFEMBilinearFormKernel.h" #include "MFEMLinearFormKernel.h" #include "MFEMFormulation.h" -#include "MFEMAuxSolver.h" #include "MFEMDataCollection.h" #include "MFEMFESpace.h" #include "Function.h" @@ -109,9 +108,7 @@ class MFEMProblem : public ExternalProblem const std::string & name, InputParameters & parameters) override; /** - * Override of ExternalProblem::addAuxKernel. Uses ExternalProblem::addAuxKernel to create a - * GeneralUserObject representing the auxkernel in MOOSE, and creates corresponding MFEM auxsolver - * to be used in the MFEM solve. + * Override of ExternalProblem::addAuxKernel. */ void addAuxKernel(const std::string & kernel_name, const std::string & name, diff --git a/framework/src/mfem/equation_systems/equation_system.C b/framework/src/mfem/equation_systems/equation_system.C index 216d8fe7..6a3e3366 100644 --- a/framework/src/mfem/equation_systems/equation_system.C +++ b/framework/src/mfem/equation_systems/equation_system.C @@ -285,7 +285,7 @@ EquationSystem::Init(platypus::GridFunctions & gridfunctions, } void -EquationSystem::BuildLinearForms(platypus::BCMap & bc_map, platypus::Sources & sources) +EquationSystem::BuildLinearForms(platypus::BCMap & bc_map) { // Register linear forms for (int i = 0; i < _test_var_names.size(); i++) @@ -313,11 +313,6 @@ EquationSystem::BuildLinearForms(platypus::BCMap & bc_map, platypus::Sources & s lf_kernel->Apply(lf); } } - - if (test_var_name == _test_var_names.at(0)) - { - sources.Apply(lf); - } } } @@ -388,9 +383,9 @@ EquationSystem::BuildMixedBilinearForms() } void -EquationSystem::BuildEquationSystem(platypus::BCMap & bc_map, platypus::Sources & sources) +EquationSystem::BuildEquationSystem(platypus::BCMap & bc_map) { - BuildLinearForms(bc_map, sources); + BuildLinearForms(bc_map); BuildBilinearForms(); BuildMixedBilinearForms(); } @@ -426,10 +421,9 @@ TimeDependentEquationSystem::SetTimeStep(double dt) } void -TimeDependentEquationSystem::UpdateEquationSystem(platypus::BCMap & bc_map, - platypus::Sources & sources) +TimeDependentEquationSystem::UpdateEquationSystem(platypus::BCMap & bc_map) { - BuildLinearForms(bc_map, sources); + BuildLinearForms(bc_map); BuildBilinearForms(); BuildMixedBilinearForms(); } diff --git a/framework/src/mfem/problem/MFEMProblem.C b/framework/src/mfem/problem/MFEMProblem.C index ccb3c249..66dd591a 100644 --- a/framework/src/mfem/problem/MFEMProblem.C +++ b/framework/src/mfem/problem/MFEMProblem.C @@ -186,14 +186,6 @@ MFEMProblem::addCoefficient(const std::string & user_object_name, FEProblemBase::addUserObject(user_object_name, name, parameters); MFEMCoefficient * mfem_coef(&getUserObject(name)); _coefficients._scalars.Register(name, mfem_coef->getCoefficient()); - - // Add associated auxsolvers for CoupledCoefficients - auto coupled_coef = std::dynamic_pointer_cast( - _coefficients._scalars.GetShared(name)); - if (coupled_coef != nullptr) - { - mfem_problem_builder->AddAuxSolver(name, std::move(coupled_coef)); - } } void @@ -271,16 +263,8 @@ MFEMProblem::addAuxKernel(const std::string & kernel_name, { std::string base_auxkernel = parameters.get("_moose_base"); - if (base_auxkernel == "MFEMAuxKernel") // MFEM auxsolver. - { - FEProblemBase::addUserObject(kernel_name, name, parameters); - MFEMAuxSolver * mfem_auxsolver(&getUserObject(name)); - - mfem_problem_builder->AddPostprocessor(name, mfem_auxsolver->getAuxSolver()); - mfem_auxsolver->storeCoefficients(_coefficients); - } - else if (base_auxkernel == "AuxKernel" || base_auxkernel == "VectorAuxKernel" || - base_auxkernel == "ArrayAuxKernel") // MOOSE auxkernels. + if (base_auxkernel == "AuxKernel" || base_auxkernel == "VectorAuxKernel" || + base_auxkernel == "ArrayAuxKernel") // MOOSE auxkernels. { FEProblemBase::addAuxKernel(kernel_name, name, parameters); } diff --git a/framework/src/mfem/problem_operators/equation_system_problem_operator.C b/framework/src/mfem/problem_operators/equation_system_problem_operator.C index 9c9b8fe0..bc9c48e0 100644 --- a/framework/src/mfem/problem_operators/equation_system_problem_operator.C +++ b/framework/src/mfem/problem_operators/equation_system_problem_operator.C @@ -14,7 +14,7 @@ EquationSystemProblemOperator::Init(mfem::Vector & X) { ProblemOperator::Init(X); - GetEquationSystem()->BuildEquationSystem(_problem._bc_map, _problem._sources); + GetEquationSystem()->BuildEquationSystem(_problem._bc_map); } } // namespace platypus \ No newline at end of file diff --git a/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C b/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C index 80e21aca..099fb086 100644 --- a/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C +++ b/framework/src/mfem/problem_operators/time_domain_equation_system_problem_operator.C @@ -24,7 +24,7 @@ TimeDomainEquationSystemProblemOperator::Init(mfem::Vector & X) *(_trial_variable_time_derivatives.at(i)) = 0.0; } - GetEquationSystem()->BuildEquationSystem(_problem._bc_map, _problem._sources); + GetEquationSystem()->BuildEquationSystem(_problem._bc_map); } void @@ -54,7 +54,7 @@ void TimeDomainEquationSystemProblemOperator::BuildEquationSystemOperator(double dt) { GetEquationSystem()->SetTimeStep(dt); - GetEquationSystem()->UpdateEquationSystem(_problem._bc_map, _problem._sources); + GetEquationSystem()->UpdateEquationSystem(_problem._bc_map); GetEquationSystem()->BuildJacobian(_true_x, _true_rhs); }