OGS
CreateSmallDeformationProcess.cpp
Go to the documentation of this file.
1
12
13#include <cassert>
14
19#include "ParameterLib/Utils.h"
23
24namespace ProcessLib
25{
26namespace LIE
27{
28namespace SmallDeformation
29{
30template <int DisplacementDim>
31std::unique_ptr<Process> createSmallDeformationProcess(
32 std::string const& name,
33 MeshLib::Mesh& mesh,
34 std::unique_ptr<ProcessLib::AbstractJacobianAssembler>&& jacobian_assembler,
35 std::vector<ProcessVariable> const& variables,
36 std::vector<std::unique_ptr<ParameterLib::ParameterBase>> const& parameters,
37 std::optional<ParameterLib::CoordinateSystem> const&
38 local_coordinate_system,
39 unsigned const integration_order,
40 BaseLib::ConfigTree const& config)
41{
43 config.checkConfigParameter("type", "SMALL_DEFORMATION_WITH_LIE");
44 DBUG("Create SmallDeformationProcess with LIE.");
45
48 auto const pv_conf = config.getConfigSubtree("process_variables");
50 auto range =
52 pv_conf.getConfigParameterList<std::string>("process_variable");
53 std::vector<std::reference_wrapper<ProcessVariable>> per_process_variables;
54
55 std::size_t n_var_du = 0;
56 for (std::string const& pv_name : range)
57 {
58 if (pv_name != "displacement" &&
59 !pv_name.starts_with("displacement_jump"))
60 {
62 "Found a process variable name '{:s}'. It should be "
63 "'displacement' or 'displacement_jumpN' or "
64 "'displacement_junctionN'",
65 pv_name);
66 }
67 if (pv_name.starts_with("displacement_jump"))
68 {
69 n_var_du++;
70 }
71
72 auto variable = std::find_if(variables.cbegin(), variables.cend(),
73 [&pv_name](ProcessVariable const& v)
74 { return v.getName() == pv_name; });
75
76 if (variable == variables.end())
77 {
79 "Could not find process variable '{:s}' in the provided "
80 "variables "
81 "list for config tag <{:s}>.",
82 pv_name, "process_variable");
83 }
84 DBUG("Found process variable '{:s}' for config tag <{:s}>.",
85 variable->getName(), "process_variable");
86
87 per_process_variables.emplace_back(
88 const_cast<ProcessVariable&>(*variable));
89 }
90
91 if (n_var_du < 1)
92 {
93 OGS_FATAL("No displacement jump variables are specified");
94 }
95
96 DBUG("Associate displacement with process variable '{:s}'.",
97 per_process_variables.back().get().getName());
98
99 if (per_process_variables.back().get().getNumberOfGlobalComponents() !=
100 DisplacementDim)
101 {
102 OGS_FATAL(
103 "Number of components of the process variable '{:s}' is different "
104 "from the displacement dimension: got {:d}, expected {:d}",
105 per_process_variables.back().get().getName(),
106 per_process_variables.back().get().getNumberOfGlobalComponents(),
107 DisplacementDim);
108 }
109 std::vector<std::vector<std::reference_wrapper<ProcessVariable>>>
110 process_variables;
111 process_variables.push_back(std::move(per_process_variables));
112
114 auto solid_constitutive_relations =
115 MaterialLib::Solids::createConstitutiveRelations<DisplacementDim>(
116 parameters, local_coordinate_system, config);
117
118 // Fracture constitutive relation.
119 // read type;
120 auto const fracture_model_config =
122 config.getConfigSubtree("fracture_model");
123
124 auto const frac_type =
126 fracture_model_config.peekConfigParameter<std::string>("type");
127
128 std::unique_ptr<MaterialLib::Fracture::FractureModelBase<DisplacementDim>>
129 fracture_model = nullptr;
130 if (frac_type == "LinearElasticIsotropic")
131 {
133 DisplacementDim>(parameters, fracture_model_config);
134 }
135 else if (frac_type == "Coulomb")
136 {
137 fracture_model = MaterialLib::Fracture::createCoulomb<DisplacementDim>(
138 parameters, fracture_model_config);
139 }
140 else if (frac_type == "CohesiveZoneModeI")
141 {
142 fracture_model =
144 DisplacementDim>(parameters, fracture_model_config);
145 }
146 else
147 {
148 OGS_FATAL(
149 "Cannot construct fracture constitutive relation of given type "
150 "'{:s}'.",
151 frac_type);
152 }
153
154 // Fracture properties
155 std::vector<FractureProperty> fracture_properties;
156 for (
157 auto fracture_properties_config :
159 config.getConfigSubtreeList("fracture_properties"))
160 {
161 fracture_properties.emplace_back(
162 fracture_properties.size(),
164 fracture_properties_config.getConfigParameter<int>("material_id"),
165 ParameterLib::findParameter<double>(
167 fracture_properties_config, "initial_aperture", parameters, 1,
168 &mesh));
169 }
170
171 if (n_var_du < fracture_properties.size())
172 {
173 OGS_FATAL(
174 "The number of displacement jumps and the number of "
175 "<fracture_properties> are not consistent");
176 }
177
178 // Reference temperature
179 const auto& reference_temperature =
181 config.getConfigParameter<double>(
182 "reference_temperature", std::numeric_limits<double>::quiet_NaN());
183
185 auto const use_b_bar = config.getConfigParameter<bool>("use_b_bar", false);
186
188 materialIDs(mesh), std::move(solid_constitutive_relations),
189 std::move(fracture_model), std::move(fracture_properties),
190 reference_temperature, use_b_bar};
191
192 SecondaryVariableCollection secondary_variables;
193
194 ProcessLib::createSecondaryVariables(config, secondary_variables);
195
196 return std::make_unique<SmallDeformationProcess<DisplacementDim>>(
197 std::move(name), mesh, std::move(jacobian_assembler), parameters,
198 integration_order, std::move(process_variables),
199 std::move(process_data), std::move(secondary_variables));
200}
201
202template std::unique_ptr<Process> createSmallDeformationProcess<2>(
203 std::string const& name,
204 MeshLib::Mesh& mesh,
205 std::unique_ptr<ProcessLib::AbstractJacobianAssembler>&& jacobian_assembler,
206 std::vector<ProcessVariable> const& variables,
207 std::vector<std::unique_ptr<ParameterLib::ParameterBase>> const& parameters,
208 std::optional<ParameterLib::CoordinateSystem> const&
209 local_coordinate_system,
210 unsigned const integration_order,
211 BaseLib::ConfigTree const& config);
212
213template std::unique_ptr<Process> createSmallDeformationProcess<3>(
214 std::string const& name,
215 MeshLib::Mesh& mesh,
216 std::unique_ptr<ProcessLib::AbstractJacobianAssembler>&& jacobian_assembler,
217 std::vector<ProcessVariable> const& variables,
218 std::vector<std::unique_ptr<ParameterLib::ParameterBase>> const& parameters,
219 std::optional<ParameterLib::CoordinateSystem> const&
220 local_coordinate_system,
221 unsigned const integration_order,
222 BaseLib::ConfigTree const& config);
223
224} // namespace SmallDeformation
225} // namespace LIE
226} // namespace ProcessLib
#define OGS_FATAL(...)
Definition Error.h:26
void DBUG(fmt::format_string< Args... > fmt, Args &&... args)
Definition Logging.h:30
T peekConfigParameter(std::string const &param) const
T getConfigParameter(std::string const &param) const
Range< SubtreeIterator > getConfigSubtreeList(std::string const &root) const
ConfigTree getConfigSubtree(std::string const &root) const
Range< ValueIterator< T > > getConfigParameterList(std::string const &param) const
void checkConfigParameter(std::string const &param, std::string_view const value) const
Handles configuration of several secondary variables from the project file.
std::unique_ptr< FractureModelBase< DisplacementDim > > createCohesiveZoneModeI(std::vector< std::unique_ptr< ParameterLib::ParameterBase > > const &parameters, BaseLib::ConfigTree const &config)
std::unique_ptr< FractureModelBase< DisplacementDim > > createLinearElasticIsotropic(std::vector< std::unique_ptr< ParameterLib::ParameterBase > > const &parameters, BaseLib::ConfigTree const &config)
template std::unique_ptr< Process > createSmallDeformationProcess< 2 >(std::string const &name, MeshLib::Mesh &mesh, std::unique_ptr< ProcessLib::AbstractJacobianAssembler > &&jacobian_assembler, std::vector< ProcessVariable > const &variables, std::vector< std::unique_ptr< ParameterLib::ParameterBase > > const &parameters, std::optional< ParameterLib::CoordinateSystem > const &local_coordinate_system, unsigned const integration_order, BaseLib::ConfigTree const &config)
std::unique_ptr< Process > createSmallDeformationProcess(std::string const &name, MeshLib::Mesh &mesh, std::unique_ptr< ProcessLib::AbstractJacobianAssembler > &&jacobian_assembler, std::vector< ProcessVariable > const &variables, std::vector< std::unique_ptr< ParameterLib::ParameterBase > > const &parameters, std::optional< ParameterLib::CoordinateSystem > const &local_coordinate_system, unsigned const integration_order, BaseLib::ConfigTree const &config)
template std::unique_ptr< Process > createSmallDeformationProcess< 3 >(std::string const &name, MeshLib::Mesh &mesh, std::unique_ptr< ProcessLib::AbstractJacobianAssembler > &&jacobian_assembler, std::vector< ProcessVariable > const &variables, std::vector< std::unique_ptr< ParameterLib::ParameterBase > > const &parameters, std::optional< ParameterLib::CoordinateSystem > const &local_coordinate_system, unsigned const integration_order, BaseLib::ConfigTree const &config)
void createSecondaryVariables(BaseLib::ConfigTree const &config, SecondaryVariableCollection &secondary_variables)