27 std::map<
int, std::shared_ptr<MaterialPropertyLib::Medium>>
const& media)
29 std::array
const required_medium_properties = {
34 std::array
const required_liquid_properties = {
42 for (
auto const& m : media)
44 checkRequiredProperties(*m.second, required_medium_properties);
45 checkRequiredProperties(m.second->phase(
"AqueousLiquid"),
46 required_liquid_properties);
47 checkRequiredProperties(m.second->phase(
"Solid"),
48 required_solid_properties);
65 std::string
const& name,
67 std::unique_ptr<ProcessLib::AbstractJacobianAssembler>&& jacobian_assembler,
68 std::vector<ProcessVariable>
const& variables,
69 std::vector<std::unique_ptr<ParameterLib::ParameterBase>>
const& parameters,
70 unsigned const integration_order,
72 std::map<
int, std::shared_ptr<MaterialPropertyLib::Medium>>
const& media)
76 DBUG(
"Create ThermoRichardsFlowProcess.");
78 auto const coupling_scheme =
81 const bool use_monolithic_scheme =
82 !(coupling_scheme && (*coupling_scheme ==
"staggered"));
91 std::vector<std::vector<std::reference_wrapper<ProcessVariable>>>
93 if (use_monolithic_scheme)
103 variable_T = &per_process_variables[0].get();
104 variable_p = &per_process_variables[1].get();
105 process_variables.push_back(std::move(per_process_variables));
110 "So far, only the monolithic scheme is implemented for "
111 "THERMO_RICHARDS_FLOW");
119 Eigen::VectorXd specific_body_force;
121 std::vector<double>
const b =
124 "specific_body_force");
128 "specific body force (gravity vector) has {:d} components, "
129 "but mesh dimension is {:d}",
132 specific_body_force.resize(b.size());
133 std::copy_n(b.data(), b.size(), specific_body_force.data());
136 auto const is_linear =
143 "Check the media properties of ThermoRichardsFlow process "
146 DBUG(
"Media properties verified.");
148 bool const mass_lumping =
152 std::unique_ptr<SimplifiedElasticityModel> simplified_elasticity =
156 std::move(media_map), std::move(specific_body_force), mass_lumping,
157 std::move(simplified_elasticity)};
163 return std::make_unique<ThermoRichardsFlowProcess>(
164 std::move(name), mesh, std::move(jacobian_assembler), parameters,
165 integration_order, std::move(process_variables),
166 std::move(process_data), std::move(secondary_variables),
167 use_monolithic_scheme, is_linear);
std::unique_ptr< Process > createThermoRichardsFlowProcess(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 ¶meters, unsigned const integration_order, BaseLib::ConfigTree const &config, std::map< int, std::shared_ptr< MaterialPropertyLib::Medium > > const &media)