https://mooseframework.inl.gov
HeatConductionCG.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 "HeatConductionCG.h"
11 #include "ADHeatConduction.h"
13 
14 // Register the actions for the objects actually used
15 registerPhysicsBaseTasks("HeatTransferApp", HeatConductionCG);
16 registerMooseAction("HeatTransferApp", HeatConductionCG, "add_kernel");
17 registerMooseAction("HeatTransferApp", HeatConductionCG, "add_bc");
18 registerMooseAction("HeatTransferApp", HeatConductionCG, "add_variable");
19 registerMooseAction("HeatTransferApp", HeatConductionCG, "add_ic");
20 registerMooseAction("HeatTransferApp", HeatConductionCG, "add_preconditioning");
21 
24 {
26  params.addClassDescription("Creates the heat conduction equation discretized with CG");
27 
28  // Material properties
29  params.transferParam<MaterialPropertyName>(ADHeatConduction::validParams(),
30  "thermal_conductivity");
31  params.transferParam<MaterialPropertyName>(HeatConductionTimeDerivative::validParams(),
32  "specific_heat");
33  params.addParam<MaterialPropertyName>("density", "density", "Density material property");
34  params.addParamNamesToGroup("thermal_conductivity specific_heat density", "Thermal properties");
35 
36  params.addParam<bool>(
37  "use_automatic_differentiation",
38  true,
39  "Whether to use automatic differentiation for all the terms in the equation");
40 
41  return params;
42 }
43 
45  : HeatConductionPhysicsBase(parameters), _use_ad(getParam<bool>("use_automatic_differentiation"))
46 {
47 }
48 
49 void
51 {
52  {
53  const std::string kernel_type = _use_ad ? "ADHeatConduction" : "HeatConduction";
54  InputParameters params = getFactory().getValidParams(kernel_type);
55  assignBlocks(params, _blocks);
56  params.set<NonlinearVariableName>("variable") = _temperature_name;
57  if (_use_ad)
58  params.applyParameter(parameters(), "thermal_conductivity");
59  else
60  params.set<MaterialPropertyName>("diffusion_coefficient") =
61  getParam<MaterialPropertyName>("thermal_conductivity");
62  getProblem().addKernel(kernel_type, prefix() + _temperature_name + "_conduction", params);
63  }
64  if (isParamValid("heat_source_var"))
65  {
66  const std::string kernel_type = _use_ad ? "ADCoupledForce" : "CoupledForce";
67  InputParameters params = getFactory().getValidParams(kernel_type);
68  assignBlocks(params, _blocks);
69  params.set<NonlinearVariableName>("variable") = _temperature_name;
70  params.set<std::vector<VariableName>>("v") = {getParam<VariableName>("heat_source_var")};
71  if (isParamValid("heat_source_blocks"))
72  params.set<std::vector<SubdomainName>>("block") =
73  getParam<std::vector<SubdomainName>>("heat_source_blocks");
74  getProblem().addKernel(kernel_type, prefix() + _temperature_name + "_source", params);
75  }
76  if (isParamValid("heat_source_functor"))
77  {
78  const std::string kernel_type = "BodyForce";
79  InputParameters params = getFactory().getValidParams(kernel_type);
80  assignBlocks(params, _blocks);
81  params.set<NonlinearVariableName>("variable") = _temperature_name;
82  const auto & functor_name = getParam<MooseFunctorName>("heat_source_functor");
83  if (MooseUtils::parsesToReal(functor_name))
84  params.set<Real>("value") = std::stod(functor_name);
85  else if (getProblem().hasFunction(functor_name))
86  params.set<FunctionName>("function") = functor_name;
87  else if (getProblem().hasPostprocessorValueByName(functor_name))
88  params.set<PostprocessorName>("postprocessor") = functor_name;
89  else
90  paramError("heat_source_functor", "Unsupported functor type.");
91  getProblem().addKernel(kernel_type, prefix() + _temperature_name + "_source_functor", params);
92  }
93  if (shouldCreateTimeDerivative(_temperature_name, _blocks, /*error if already defined*/ false))
94  {
95  const std::string kernel_type =
96  _use_ad ? "ADHeatConductionTimeDerivative" : "SpecificHeatConductionTimeDerivative";
97  InputParameters params = getFactory().getValidParams(kernel_type);
98  assignBlocks(params, _blocks);
99  params.set<NonlinearVariableName>("variable") = _temperature_name;
100  params.applyParameter(parameters(), "density_name");
101  params.applyParameter(parameters(), "specific_heat");
102  getProblem().addKernel(kernel_type, prefix() + _temperature_name + "_time", params);
103  }
104 }
105 
106 void
108 {
109  // We dont need to add anything for insulated boundaries, 0 flux is the default boundary condition
110  if (isParamValid("heat_flux_boundaries"))
111  {
112  const std::string bc_type = "FunctorNeumannBC";
113  InputParameters params = getFactory().getValidParams(bc_type);
114  params.set<NonlinearVariableName>("variable") = _temperature_name;
115 
116  const auto & heat_flux_boundaries = getParam<std::vector<BoundaryName>>("heat_flux_boundaries");
117  const auto & boundary_heat_fluxes =
118  getParam<std::vector<MooseFunctorName>>("boundary_heat_fluxes");
119  // Optimization if all the same
120  if (std::set<MooseFunctorName>(boundary_heat_fluxes.begin(), boundary_heat_fluxes.end())
121  .size() == 1 &&
122  heat_flux_boundaries.size() > 1)
123  {
124  params.set<std::vector<BoundaryName>>("boundary") = heat_flux_boundaries;
125  params.set<MooseFunctorName>("functor") = boundary_heat_fluxes[0];
127  bc_type, prefix() + _temperature_name + "_heat_flux_bc_all", params);
128  }
129  else
130  {
131  for (const auto i : index_range(heat_flux_boundaries))
132  {
133  params.set<std::vector<BoundaryName>>("boundary") = {heat_flux_boundaries[i]};
134  params.set<MooseFunctorName>("functor") = boundary_heat_fluxes[i];
136  prefix() + _temperature_name + "_heat_flux_bc_" +
137  heat_flux_boundaries[i],
138  params);
139  }
140  }
141  }
142  if (isParamValid("fixed_temperature_boundaries"))
143  {
144  const std::string bc_type = "FunctorDirichletBC";
145  InputParameters params = getFactory().getValidParams(bc_type);
146  params.set<NonlinearVariableName>("variable") = _temperature_name;
147 
148  const auto & temperature_boundaries =
149  getParam<std::vector<BoundaryName>>("fixed_temperature_boundaries");
150  const auto & boundary_temperatures =
151  getParam<std::vector<MooseFunctorName>>("boundary_temperatures");
152  // Optimization if all the same
153  if (std::set<MooseFunctorName>(boundary_temperatures.begin(), boundary_temperatures.end())
154  .size() == 1 &&
155  temperature_boundaries.size() > 1)
156  {
157  params.set<std::vector<BoundaryName>>("boundary") = temperature_boundaries;
158  params.set<MooseFunctorName>("functor") = boundary_temperatures[0];
160  bc_type, prefix() + _temperature_name + "_dirichlet_bc_all", params);
161  }
162  else
163  {
164  for (const auto i : index_range(temperature_boundaries))
165  {
166  params.set<std::vector<BoundaryName>>("boundary") = {temperature_boundaries[i]};
167  params.set<MooseFunctorName>("functor") = boundary_temperatures[i];
169  prefix() + _temperature_name + "_dirichlet_bc_" +
170  temperature_boundaries[i],
171  params);
172  }
173  }
174  }
175  if (isParamValid("fixed_convection_boundaries"))
176  {
177  const std::string bc_type = "ADConvectiveHeatFluxBC";
178  InputParameters params = getFactory().getValidParams(bc_type);
179  params.set<NonlinearVariableName>("variable") = _temperature_name;
180 
181  const auto & convective_boundaries =
182  getParam<std::vector<BoundaryName>>("fixed_convection_boundaries");
183  const auto & boundary_T_fluid =
184  getParam<std::vector<MooseFunctorName>>("fixed_convection_T_fluid");
185  const auto & boundary_htc = getParam<std::vector<MooseFunctorName>>("fixed_convection_htc");
186 
187  if (!_use_ad && convective_boundaries.size())
188  paramInfo("use_automatic_differentiation",
189  "No-AD is not implemented for convection boundaries");
190 
191  // Optimization if all the same
192  if (std::set<MooseFunctorName>(boundary_T_fluid.begin(), boundary_T_fluid.end()).size() == 1 &&
193  std::set<MooseFunctorName>(boundary_htc.begin(), boundary_htc.end()).size() == 1 &&
194  convective_boundaries.size() > 1)
195  {
196  params.set<std::vector<BoundaryName>>("boundary") = convective_boundaries;
197  params.set<MooseFunctorName>("T_infinity_functor") = boundary_T_fluid[0];
198  params.set<MooseFunctorName>("heat_transfer_coefficient_functor") = boundary_htc[0];
200  bc_type, prefix() + _temperature_name + "_fixed_convection_bc_all", params);
201  }
202  else
203  {
204  // Check sizes
205  if (convective_boundaries.size() != boundary_T_fluid.size())
206  paramError("fixed_convection_T_fluid",
207  "Should be as many convection boundaries (" +
208  std::to_string(convective_boundaries.size()) +
209  ") as fixed convection temperatures (" +
210  std::to_string(boundary_T_fluid.size()) + ")");
211  if (convective_boundaries.size() != boundary_htc.size())
212  paramError("fixed_convection_htc",
213  "Should be as many convection boundaries (" +
214  std::to_string(convective_boundaries.size()) +
215  ") as fixed convection heat exchange coefficients (" +
216  std::to_string(boundary_htc.size()) + ")");
217  for (const auto i : index_range(convective_boundaries))
218  {
219  params.set<std::vector<BoundaryName>>("boundary") = {convective_boundaries[i]};
220  params.set<MooseFunctorName>("T_infinity_functor") = boundary_T_fluid[i];
221  params.set<MooseFunctorName>("heat_transfer_coefficient_functor") = boundary_htc[i];
223  prefix() + _temperature_name + "_fixed_convection_bc_" +
224  convective_boundaries[i],
225  params);
226  }
227  }
228  }
229 }
230 
231 void
233 {
234  if (!shouldCreateVariable(_temperature_name, _blocks, /*error if aux*/ true))
235  {
236  reportPotentiallyMissedParameters({"system_names"}, "MooseVariable");
237  return;
238  }
239 
240  const std::string variable_type = "MooseVariable";
241  // defaults to linear lagrange FE family
242  InputParameters params = getFactory().getValidParams(variable_type);
243  params.set<SolverSystemName>("solver_sys") = getSolverSystem(_temperature_name);
244  assignBlocks(params, _blocks);
245 
246  getProblem().addVariable(variable_type, _temperature_name, params);
247 }
void addSolverVariables() override
std::string prefix() const
void addFEBCs() override
bool parsesToReal(const std::string &input)
void assignBlocks(InputParameters &params, const std::vector< SubdomainName > &blocks) const
bool shouldCreateVariable(const VariableName &var_name, const std::vector< SubdomainName > &blocks, const bool error_if_aux)
Factory & getFactory()
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)
static InputParameters validParams()
InputParameters getValidParams(const std::string &name) const
Base class to host common parameters and attributes to all Physics solving the heat conduction equati...
static InputParameters validParams()
bool shouldCreateTimeDerivative(const VariableName &var_name, const std::vector< SubdomainName > &blocks, const bool error_if_already_defined) const
virtual void addKernel(const std::string &kernel_name, const std::string &name, InputParameters &parameters)
std::vector< SubdomainName > _blocks
virtual void addBoundaryCondition(const std::string &bc_name, const std::string &name, InputParameters &parameters)
bool isParamValid(const std::string &name) const
virtual FEProblemBase & getProblem()
const SolverSystemName & getSolverSystem(unsigned int variable_index) const
static InputParameters validParams()
Contructor for Heat Equation time derivative term.
static InputParameters validParams()
const bool _use_ad
Whether to use automatic differentiation.
bool hasPostprocessorValueByName(const PostprocessorName &name) const
void paramError(const std::string &param, Args... args) const
void transferParam(const InputParameters &source_param, const std::string &name, const std::string &new_name="", const std::string &new_description="")
virtual void addVariable(const std::string &var_type, const std::string &var_name, InputParameters &params)
Creates all the objects needed to solve the heat conduction equations with CG.
void addFEKernels() override
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
HeatConductionCG(const InputParameters &parameters)
registerPhysicsBaseTasks("HeatTransferApp", HeatConductionCG)
void addClassDescription(const std::string &doc_string)
const InputParameters & parameters() const
void reportPotentiallyMissedParameters(const std::vector< std::string > &param_names, const std::string &object_type) const
const VariableName & _temperature_name
Name of the temperature variable.
void applyParameter(const InputParameters &common, const std::string &common_name, bool allow_private=false, bool override_default=false)
registerMooseAction("HeatTransferApp", HeatConductionCG, "add_kernel")
void paramInfo(const std::string &param, Args... args) const
auto index_range(const T &sizable)
void addParamNamesToGroup(const std::string &space_delim_names, const std::string group_name)