https://mooseframework.inl.gov
ConservedAction.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 #include "ConservedAction.h"
11 // MOOSE includes
12 #include "Conversion.h"
13 #include "FEProblem.h"
14 #include "Factory.h"
15 #include "MooseObjectAction.h"
16 #include "MooseMesh.h"
17 #include "AddVariableAction.h"
18 
19 #include "libmesh/string_to_enum.h"
20 
21 using namespace libMesh;
22 
23 registerMooseAction("PhaseFieldApp", ConservedAction, "add_variable");
24 
25 registerMooseAction("PhaseFieldApp", ConservedAction, "add_kernel");
26 
29 {
31  params.addClassDescription(
32  "Set up the variable(s) and the kernels needed for a conserved phase field variable."
33  " Note that for a direct solve, the element family and order are overwritten with hermite "
34  "and third.");
35  MooseEnum solves("DIRECT REVERSE_SPLIT FORWARD_SPLIT");
36  params.addRequiredParam<MooseEnum>("solve_type", solves, "Split or direct solve?");
37  // Get MooseEnums for the possible order/family options for this variable
40  params.addParam<MooseEnum>("family",
41  families,
42  "Specifies the family of FE "
43  "shape functions to use for this variable");
44  params.addParam<MooseEnum>("order",
45  orders,
46  "Specifies the order of the FE "
47  "shape function to use for this variable");
48  params.addParam<Real>("scaling", 1.0, "Specifies a scaling factor to apply to this variable");
49  params.addParam<bool>("implicit", true, "Whether kernels are implicit or not");
50  params.addParam<bool>(
51  "use_displaced_mesh", false, "Whether to use displaced mesh in the kernels");
52  params.addParamNamesToGroup("scaling implicit use_displaced_mesh", "Advanced");
53  params.addRequiredParam<MaterialPropertyName>("mobility", "The mobility used with the kernel");
54  params.addCoupledVar("args", "Vector of nonlinear variable arguments this kernel depends on");
55  params.deprecateCoupledVar("args", "coupled_variables", "02/27/2024");
56 
57  params.addRequiredParam<MaterialPropertyName>(
58  "free_energy", "Base name of the free energy function F defined in a free energy material");
59  params.addRequiredParam<MaterialPropertyName>("kappa", "The kappa used with the kernel");
60  params.addParam<std::vector<SubdomainName>>(
61  "block", {}, "Block restriction for the variables and kernels");
62  return params;
63 }
64 
66  : Action(params),
67  _solve_type(getParam<MooseEnum>("solve_type").getEnum<SolveType>()),
68  _var_name(name()),
69  _scaling(getParam<Real>("scaling"))
70 {
71  switch (_solve_type)
72  {
73  case SolveType::DIRECT:
74  _fe_type = FEType(Utility::string_to_enum<Order>("THIRD"),
75  Utility::string_to_enum<FEFamily>("HERMITE"));
76  if (!parameters().isParamSetByAddParam("order") &&
77  !parameters().isParamSetByAddParam("family"))
78  mooseWarning("Order and family autoset to third and hermite in ConservedAction");
79  break;
82  _fe_type = FEType(Utility::string_to_enum<Order>(getParam<MooseEnum>("order")),
83  Utility::string_to_enum<FEFamily>(getParam<MooseEnum>("family")));
84  // Set name of chemical potential variable
85  _chempot_name = "chem_pot_" + _var_name;
86  break;
87  default:
88  paramError("solve_type", "Incorrect solve_type in ConservedAction");
89  }
90 }
91 
92 void
94 {
95  //
96  // Add variable(s)
97  //
98  if (_current_task == "add_variable")
99  {
101  auto var_params = _factory.getValidParams(type);
102  var_params.set<MooseEnum>("family") = Moose::stringify(_fe_type.family);
103  var_params.set<MooseEnum>("order") = _fe_type.order.get_order();
104  var_params.set<std::vector<Real>>("scaling") = {_scaling};
105  var_params.applySpecificParameters(parameters(), {"block"});
106 
107  // Create conserved variable _var_name
108  _problem->addVariable(type, _var_name, var_params);
109 
110  // Create chemical potential variable for split form
111  switch (_solve_type)
112  {
113  case SolveType::DIRECT:
114  break;
117  _problem->addVariable(type, _chempot_name, var_params);
118  }
119  }
120 
121  //
122  // Add Kernels
123  //
124  else if (_current_task == "add_kernel")
125  {
126  switch (_solve_type)
127  {
128  case SolveType::DIRECT:
129  // Add time derivative kernel
130  {
131  std::string kernel_type = "TimeDerivative";
132 
133  std::string kernel_name = _var_name + "_" + kernel_type;
134  InputParameters params = _factory.getValidParams(kernel_type);
135  params.set<NonlinearVariableName>("variable") = _var_name;
136  params.applyParameters(parameters());
137 
138  _problem->addKernel(kernel_type, kernel_name, params);
139  }
140 
141  // Add CahnHilliard kernel
142  {
143  std::string kernel_type = "CahnHilliard";
144 
145  std::string kernel_name = _var_name + "_" + kernel_type;
146  InputParameters params = _factory.getValidParams(kernel_type);
147  params.set<NonlinearVariableName>("variable") = _var_name;
148  params.set<MaterialPropertyName>("mob_name") = getParam<MaterialPropertyName>("mobility");
149  params.set<MaterialPropertyName>("f_name") =
150  getParam<MaterialPropertyName>("free_energy");
151  params.applyParameters(parameters());
152 
153  _problem->addKernel(kernel_type, kernel_name, params);
154  }
155 
156  // Add ACInterface kernel
157  {
158  std::string kernel_type = "CHInterface";
159 
160  std::string kernel_name = _var_name + "_" + kernel_type;
161  InputParameters params = _factory.getValidParams(kernel_type);
162  params.set<NonlinearVariableName>("variable") = _var_name;
163  params.set<MaterialPropertyName>("mob_name") = getParam<MaterialPropertyName>("mobility");
164  params.set<MaterialPropertyName>("kappa_name") = getParam<MaterialPropertyName>("kappa");
165  params.applyParameters(parameters());
166 
167  _problem->addKernel(kernel_type, kernel_name, params);
168  }
169  break;
170 
172  // Add time derivative kernel
173  {
174  std::string kernel_type = "CoupledTimeDerivative";
175 
176  std::string kernel_name = _var_name + "_" + kernel_type;
177  InputParameters params = _factory.getValidParams(kernel_type);
178  params.set<NonlinearVariableName>("variable") = _chempot_name;
179  params.set<std::vector<VariableName>>("v") = {_var_name};
180  params.applyParameters(parameters());
181 
182  _problem->addKernel(kernel_type, kernel_name, params);
183  }
184 
185  // Add SplitCHWRes kernel
186  {
187  std::string kernel_type = "SplitCHWRes";
188 
189  std::string kernel_name = _var_name + "_" + kernel_type;
190  InputParameters params = _factory.getValidParams(kernel_type);
191  params.set<NonlinearVariableName>("variable") = _chempot_name;
192  params.set<MaterialPropertyName>("mob_name") = getParam<MaterialPropertyName>("mobility");
193  params.applyParameters(parameters());
194 
195  _problem->addKernel(kernel_type, kernel_name, params);
196  }
197 
198  // Add SplitCHParsed kernel
199  {
200  std::string kernel_type = "SplitCHParsed";
201 
202  std::string kernel_name = _var_name + "_" + kernel_type;
203  InputParameters params = _factory.getValidParams(kernel_type);
204  params.set<NonlinearVariableName>("variable") = _var_name;
205  params.set<std::vector<VariableName>>("w") = {_chempot_name};
206  params.set<MaterialPropertyName>("f_name") =
207  getParam<MaterialPropertyName>("free_energy");
208  params.set<MaterialPropertyName>("kappa_name") = getParam<MaterialPropertyName>("kappa");
209  params.applyParameters(parameters());
210 
211  _problem->addKernel(kernel_type, kernel_name, params);
212  }
213  break;
214 
216  // Add time derivative kernel
217  {
218  std::string kernel_type = "TimeDerivative";
219 
220  std::string kernel_name = _var_name + "_" + kernel_type;
221  InputParameters params = _factory.getValidParams(kernel_type);
222  params.set<NonlinearVariableName>("variable") = _var_name;
223  params.applyParameters(parameters());
224 
225  _problem->addKernel(kernel_type, kernel_name, params);
226  }
227 
228  // Add MatDiffusion kernel for c residual
229  {
230  std::string kernel_type = "MatDiffusion";
231 
232  std::string kernel_name = _var_name + "_" + kernel_type;
233  InputParameters params = _factory.getValidParams(kernel_type);
234  params.set<NonlinearVariableName>("variable") = _var_name;
235  params.set<std::vector<VariableName>>("v") = {_chempot_name};
236  params.set<MaterialPropertyName>("diffusivity") =
237  getParam<MaterialPropertyName>("mobility");
238  params.applyParameters(parameters());
239 
240  _problem->addKernel(kernel_type, kernel_name, params);
241  }
242  // Add MatDiffusion kernel for chemical potential residual
243  {
244  std::string kernel_type = "MatDiffusion";
245 
246  std::string kernel_name = _chempot_name + "_" + kernel_type;
247  InputParameters params = _factory.getValidParams(kernel_type);
248  params.set<NonlinearVariableName>("variable") = _chempot_name;
249  params.set<std::vector<VariableName>>("v") = {_var_name};
250  params.set<MaterialPropertyName>("diffusivity") = getParam<MaterialPropertyName>("kappa");
251  params.applyParameters(parameters());
252 
253  _problem->addKernel(kernel_type, kernel_name, params);
254  }
255 
256  // Add CoupledMaterialDerivative kernel
257  {
258  std::string kernel_type = "CoupledMaterialDerivative";
259 
260  std::string kernel_name = _chempot_name + "_" + kernel_type;
261  InputParameters params = _factory.getValidParams(kernel_type);
262  params.set<NonlinearVariableName>("variable") = _chempot_name;
263  params.set<std::vector<VariableName>>("v") = {_var_name};
264  params.set<MaterialPropertyName>("f_name") =
265  getParam<MaterialPropertyName>("free_energy");
266  params.applyParameters(parameters());
267 
268  _problem->addKernel(kernel_type, kernel_name, params);
269  }
270 
271  // Add CoefReaction kernel
272  {
273  std::string kernel_type = "CoefReaction";
274 
275  std::string kernel_name = _chempot_name + "_" + kernel_type;
276  InputParameters params = _factory.getValidParams(kernel_type);
277  params.set<NonlinearVariableName>("variable") = _chempot_name;
278  params.set<Real>("coefficient") = -1.0;
279  params.applyParameters(parameters());
280 
281  _problem->addKernel(kernel_type, kernel_name, params);
282  }
283  }
284  }
285 }
virtual void act() override
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
T & set(const std::string &name, bool quiet_mode=false)
void applyParameters(const InputParameters &common, const std::vector< std::string > &exclude={}, const bool allow_private=false)
OrderWrapper order
The following methods are specializations for using the Parallel::packed_range_* routines for a vecto...
void mooseWarning(Args &&... args) const
void addRequiredParam(const std::string &name, const std::string &doc_string)
static MooseEnum getNonlinearVariableFamilies()
Factory & _factory
const Real _scaling
Scaling parameter.
static InputParameters validParams()
static MooseEnum getNonlinearVariableOrders()
registerMooseAction("PhaseFieldApp", ConservedAction, "add_variable")
static InputParameters validParams()
const std::string name
Definition: Setup.h:20
std::string _chempot_name
Name of chemical potential variable for split solves.
SolveType
Type of solve.
const NonlinearVariableName _var_name
Name of the variable being created.
const std::string & type() const
const std::string & _current_task
void deprecateCoupledVar(const std::string &old_name, const std::string &new_name, const std::string &removal_date)
static std::string variableType(const libMesh::FEType &fe_type, const bool is_fv=false, const bool is_array=false)
void paramError(const std::string &param, Args... args) const
std::string stringify(const T &t)
void addCoupledVar(const std::string &name, const std::string &doc_string)
const SolveType _solve_type
Type of solve to use used in the action.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
libMesh::FEType _fe_type
FEType for the variable being created.
void addClassDescription(const std::string &doc_string)
std::shared_ptr< FEProblemBase > & _problem
const InputParameters & parameters() const
ConservedAction(const InputParameters &params)
void addParamNamesToGroup(const std::string &space_delim_names, const std::string group_name)