https://mooseframework.inl.gov
MechanicsActionPD.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 "Factory.h"
11 #include "FEProblemBase.h"
12 #include "Conversion.h"
13 #include "MooseObjectAction.h"
14 #include "MechanicsActionPD.h"
15 
16 #include "libmesh/string_to_enum.h"
17 
18 registerMooseAction("PeridynamicsApp", MechanicsActionPD, "setup_mesh_complete");
19 registerMooseAction("PeridynamicsApp", MechanicsActionPD, "create_problem_complete");
20 registerMooseAction("PeridynamicsApp", MechanicsActionPD, "add_aux_variable");
21 registerMooseAction("PeridynamicsApp", MechanicsActionPD, "add_user_object");
22 registerMooseAction("PeridynamicsApp", MechanicsActionPD, "add_ic");
23 registerMooseAction("PeridynamicsApp", MechanicsActionPD, "add_kernel");
24 
27 {
29  params.addClassDescription("Class for setting up peridynamic kernels");
30 
31  params.addRequiredParam<std::vector<VariableName>>(
32  "displacements", "Nonlinear variable names for the displacements");
33  MooseEnum formulation_option("BOND ORDINARY_STATE NONORDINARY_STATE");
35  "formulation", formulation_option, "Peridynamic formulation options");
36  MooseEnum stabilization_option("FORCE BOND_HORIZON_I BOND_HORIZON_II");
37  params.addParam<MooseEnum>("stabilization",
38  stabilization_option,
39  "Stabilization techniques for the peridynamic correspondence model");
40  params.addParam<bool>(
41  "full_jacobian",
42  false,
43  "Parameter to set whether to use full jacobian for state based formulation or not");
44  MooseEnum strain_type("SMALL FINITE", "SMALL");
45  params.addParam<MooseEnum>("strain", strain_type, "Strain formulation");
46  params.addParam<VariableName>("temperature", "Nonlinear variable name for the temperature");
47  params.addParam<VariableName>("out_of_plane_strain",
48  "Nonlinear variable name for the out_of_plane strain for "
49  "plane stress using the NOSPD formulation");
50  params.addParam<std::vector<SubdomainName>>("block",
51  {},
52  "List of ids of the blocks (subdomains) that the "
53  "peridynamic mechanics kernel will be applied to");
54  params.addParam<std::vector<AuxVariableName>>("save_in", {}, "The displacement residuals");
55  params.addParam<std::vector<AuxVariableName>>(
56  "diag_save_in", {}, "The displacement diagonal preconditioner terms");
57  params.addParam<std::vector<MaterialPropertyName>>(
58  "eigenstrain_names",
59  {},
60  "List of eigenstrains to be coupled in non-ordinary state-based mechanics kernels");
61 
62  return params;
63 }
64 
66  : Action(params),
67  _displacements(getParam<std::vector<VariableName>>("displacements")),
68  _ndisp(_displacements.size()),
69  _formulation(getParam<MooseEnum>("formulation")),
70  _stabilization(getParam<MooseEnum>("stabilization")),
71  _strain(getParam<MooseEnum>("strain")),
72  _subdomain_names(getParam<std::vector<SubdomainName>>("block")),
73  _subdomain_ids(),
74  _save_in(getParam<std::vector<AuxVariableName>>("save_in")),
75  _diag_save_in(getParam<std::vector<AuxVariableName>>("diag_save_in"))
76 {
77  // Consistency check
78  if (_formulation == "NONORDINARY_STATE" && !isParamValid("stabilization"))
79  mooseError("'stabilization' is a required parameter for non-ordinary state-based models only.");
80 
81  if (_save_in.size() != 0 && _save_in.size() != _ndisp)
82  mooseError("Number of save_in variables should equal to the number of displacement variables ",
83  _ndisp);
84 
85  if (_diag_save_in.size() != 0 && _diag_save_in.size() != _ndisp)
86  mooseError(
87  "Number of diag_save_in variables should equal to the number of displacement variables ",
88  _ndisp);
89 }
90 
91 void
93 {
94  if (_current_task == "setup_mesh_complete")
95  {
96  // get subdomain IDs
97  for (auto & name : _subdomain_names)
98  _subdomain_ids.insert(_mesh->getSubdomainID(name));
99  }
100  else if (_current_task == "create_problem_complete")
101  {
102  // Gather info about all other master actions for adding (aux)variables
103  auto actions = _awh.getActions<MechanicsActionPD>();
104  for (const auto & action : actions)
105  {
106  const auto size_before = _subdomain_id_union.size();
107  const auto added_size = action->_subdomain_ids.size();
108  _subdomain_id_union.insert(action->_subdomain_ids.begin(), action->_subdomain_ids.end());
109  const auto size_after = _subdomain_id_union.size();
110 
111  if (size_after != size_before + added_size)
112  mooseError("The block restrictions in the Peridynamics/Mechanics/Master actions must be "
113  "non-overlapping!");
114 
115  if (added_size == 0 && actions.size() > 1)
116  mooseError(
117  "No Peridynamics/Mechanics/Master action can be block unrestricted if more than one "
118  "Peridynamics/Mechanics/Master action is specified!");
119  }
120  }
121  else if (_current_task == "add_aux_variable")
122  {
123  // add the bond_status aux variable to all peridynamic domains
124  const std::string var_type = "MooseVariableConstMonomial";
125  InputParameters params = _factory.getValidParams(var_type);
126  params.set<MooseEnum>("order") = "CONSTANT";
127  params.set<MooseEnum>("family") = "MONOMIAL";
128 
129  if (!_subdomain_id_union.empty())
130  for (const SubdomainID & id : _subdomain_id_union)
131  params.set<std::vector<SubdomainName>>("block").push_back(Moose::stringify(id));
132 
133  _problem->addAuxVariable(var_type, "bond_status", params);
134  }
135  else if (_current_task == "add_ic")
136  {
137  const std::string ic_type = "ConstantIC";
138  const std::string ic_name = name() + "bond_status";
139 
140  InputParameters params = _factory.getValidParams(ic_type);
141  params.set<VariableName>("variable") = "bond_status";
142  params.set<Real>("value") = 1.0;
143 
144  // check whether this object is restricted to certain block?
145  if (isParamValid("block"))
146  params.set<std::vector<SubdomainName>>("block") = _subdomain_names;
147 
148  _problem->addInitialCondition(ic_type, ic_name, params);
149  }
150  else if (_current_task == "add_user_object")
151  {
152  // add ghosting UO
153  const std::string uo_type = "GhostElemPD";
154  const std::string uo_name = name() + "GhostElemPD";
155 
156  InputParameters params = _factory.getValidParams(uo_type);
157  params.set<bool>("use_displaced_mesh") = (_strain == "FINITE");
158 
159  _problem->addUserObject(uo_type, uo_name, params);
160  }
161  else if (_current_task == "add_kernel")
162  {
163  const std::string kernel_name = getKernelName();
164  InputParameters params = getKernelParameters(kernel_name);
165 
166  for (unsigned int i = 0; i < _ndisp; ++i)
167  {
168  const std::string kernel_object_name = name() + "Peridynamics_" + Moose::stringify(i);
169 
170  params.set<unsigned int>("component") = i;
171  params.set<NonlinearVariableName>("variable") = _displacements[i];
172 
173  if (_save_in.size() != 0)
174  params.set<std::vector<AuxVariableName>>("save_in") = {_save_in[i]};
175  if (_diag_save_in.size() != 0)
176  params.set<std::vector<AuxVariableName>>("diag_save_in") = {_diag_save_in[i]};
177 
178  _problem->addKernel(kernel_name, kernel_object_name, params);
179  }
180  }
181  else
182  mooseError("Task error in MechanicsActionPD!");
183 }
184 
185 std::string
187 {
188  std::string name;
189 
190  if (_formulation == "BOND")
191  {
192  name = "MechanicsBPD";
193  }
194  else if (_formulation == "ORDINARY_STATE")
195  {
196  name = "MechanicsOSPD";
197  }
198  else if (_formulation == "NONORDINARY_STATE")
199  {
200  if (_stabilization == "FORCE")
201  {
202  name = "ForceStabilizedSmallStrainMechanicsNOSPD";
203  }
204  else if (_stabilization == "BOND_HORIZON_I")
205  {
206  if (_strain == "SMALL")
207  name = "HorizonStabilizedFormISmallStrainMechanicsNOSPD";
208  else
209  name = "HorizonStabilizedFormIFiniteStrainMechanicsNOSPD";
210  }
211  else if (_stabilization == "BOND_HORIZON_II")
212  {
213  if (_strain == "SMALL")
214  name = "HorizonStabilizedFormIISmallStrainMechanicsNOSPD";
215  else
216  name = "HorizonStabilizedFormIIFiniteStrainMechanicsNOSPD";
217  }
218  else
219  paramError("stabilization", "Unknown PD stabilization scheme!");
220  }
221  else
222  paramError("formulation", "Unsupported peridynamic formulation!");
223 
224  return name;
225 }
226 
229 {
231 
232  params.applyParameters(parameters(),
233  {"displacements",
234  "temperature",
235  "out_of_plane_strain",
236  "eigenstrain_names",
237  "use_displaced_mesh",
238  "save_in",
239  "diag_save_in"});
240 
241  params.set<std::vector<VariableName>>("displacements") = _displacements;
242  if (isParamValid("temperature"))
243  params.set<std::vector<VariableName>>("temperature") = {getParam<VariableName>("temperature")};
244  if (isParamValid("out_of_plane_strain"))
245  params.set<std::vector<VariableName>>("out_of_plane_strain") = {
246  getParam<VariableName>("out_of_plane_strain")};
247 
248  // peridynamics modules are formulated based on initial configuration
249  params.set<bool>("use_displaced_mesh") = false;
250 
251  if (_formulation == "NONORDINARY_STATE" && isParamValid("eigenstrain_names"))
252  {
253  params.set<std::vector<MaterialPropertyName>>("eigenstrain_names") =
254  getParam<std::vector<MaterialPropertyName>>("eigenstrain_names");
255  }
256 
257  return params;
258 }
MechanicsActionPD(const InputParameters &params)
std::vector< AuxVariableName > _save_in
Residual debugging.
std::vector< AuxVariableName > _diag_save_in
std::set< SubdomainID > _subdomain_id_union
set of SubdomainID generated from the combined block restrictions of all TensorMechanics/Master actio...
ActionWarehouse & _awh
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
static InputParameters validParams()
const unsigned int _ndisp
T & set(const std::string &name, bool quiet_mode=false)
Action class to setup peridynamic models for solid mechanics problems.
virtual void act() override
InputParameters getValidParams(const std::string &name) const
void applyParameters(const InputParameters &common, const std::vector< std::string > &exclude={}, const bool allow_private=false)
virtual InputParameters getKernelParameters(std::string name)
Function to get the input parameters for a given kernel name.
virtual std::string getKernelName()
Function to get the kernel name based on the value of member variables: _formulation and _stabilizati...
virtual const std::string & name() const
const MooseEnum _strain
Option of strain formulation: SMALL or FINITE.
void addRequiredParam(const std::string &name, const std::string &doc_string)
bool isParamValid(const std::string &name) const
Factory & _factory
static InputParameters validParams()
const std::string name
Definition: Setup.h:20
registerMooseAction("PeridynamicsApp", MechanicsActionPD, "setup_mesh_complete")
const T & getParam(const std::string &name) const
const MooseEnum _formulation
Option of which peridynamic model needs to be setup: BOND, ORDINARY_STATE or NONORDINARY_STATE.
const std::string & _current_task
std::set< SubdomainID > _subdomain_ids
set of subdomain IDs generated from the passed in vector of subdomain names
void paramError(const std::string &param, Args... args) const
std::string stringify(const T &t)
std::shared_ptr< MooseMesh > & _mesh
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
std::vector< VariableName > _displacements
Displacement variables.
const MooseEnum _stabilization
Option of stabilization scheme for correspondence material model: FORCE, BOND_HORIZON_I or BOND_HORIZ...
void mooseError(Args &&... args) const
void addClassDescription(const std::string &doc_string)
std::shared_ptr< FEProblemBase > & _problem
const InputParameters & parameters() const
std::vector< SubdomainName > _subdomain_names
vector of subdomain names from provided blocks
std::vector< const T *> getActions()