https://mooseframework.inl.gov
HSBoundaryRadiation.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 "HSBoundaryRadiation.h"
11 #include "HeatConductionModel.h"
12 #include "HeatStructureInterface.h"
14 
15 registerMooseObject("ThermalHydraulicsApp", HSBoundaryRadiation);
16 
19 {
21 
22  params.addRequiredParam<MooseFunctorName>("emissivity", "Emissivity functor [-]");
23  params.addParam<MooseFunctorName>("view_factor", 1.0, "View factor functor [-]");
24  params.addRequiredParam<MooseFunctorName>("T_ambient", "Ambient temperature functor [K]");
25  params.addDeprecatedParam<PostprocessorName>(
26  "scale_pp",
27  "Post-processor by which to scale boundary condition",
28  "The 'scale' parameter is replacing the 'scale_pp' parameter. 'scale' is a function "
29  "parameter instead of a post-processor parameter. If you need to scale from a post-processor "
30  "value, use a PostprocessorFunction.");
31  params.addParam<MooseFunctorName>(
32  "scale", 1.0, "Functor by which to scale the boundary condition");
33  params.addParam<bool>(
34  "scale_heat_rate_pp",
35  true,
36  "If true, the scaling function is applied to the heat rate post-processor.");
37 
38  params.addClassDescription("Radiative heat transfer boundary condition for heat structure");
39 
40  return params;
41 }
42 
44 
45 void
47 {
48  const HeatStructureInterface & hs = getComponent<HeatStructureInterface>("hs");
49  const HeatStructureCylindricalBase * hs_cyl =
50  dynamic_cast<const HeatStructureCylindricalBase *>(&hs);
51  const bool is_cylindrical = hs_cyl != nullptr;
52 
53  {
54  const std::string class_name =
55  is_cylindrical ? "ADRadiativeHeatFluxRZBC" : "ADRadiativeHeatFluxBC";
56  InputParameters pars = _factory.getValidParams(class_name);
57  pars.set<NonlinearVariableName>("variable") = HeatConductionModel::TEMPERATURE;
58  pars.set<std::vector<BoundaryName>>("boundary") = _boundary;
59  pars.set<MooseFunctorName>("emissivity") = getParam<MooseFunctorName>("emissivity");
60  pars.set<MooseFunctorName>("T_ambient") = getParam<MooseFunctorName>("T_ambient");
61  pars.set<MooseFunctorName>("view_factor") = getParam<MooseFunctorName>("view_factor");
62  if (is_cylindrical)
63  {
64  pars.set<Point>("axis_point") = hs_cyl->getPosition();
65  pars.set<RealVectorValue>("axis_dir") = hs_cyl->getDirection();
66  }
67  pars.set<MooseFunctorName>("scale") = getParam<MooseFunctorName>("scale");
68  if (isParamValid("scale_pp"))
69  pars.set<PostprocessorName>("scale_pp") = getParam<PostprocessorName>("scale_pp");
70 
71  getTHMProblem().addBoundaryCondition(class_name, genName(name(), "bc"), pars);
72  }
73 
74  // Create integral PP for cylindrical heat structures
75  if (is_cylindrical)
76  {
77  const std::string class_name = "HeatRateRadiationRZ";
78  InputParameters pars = _factory.getValidParams(class_name);
79  pars.set<std::vector<BoundaryName>>("boundary") = _boundary;
80  pars.set<std::vector<VariableName>>("T") = {HeatConductionModel::TEMPERATURE};
81  pars.set<MooseFunctorName>("T_ambient") = getParam<MooseFunctorName>("T_ambient");
82  pars.set<MooseFunctorName>("emissivity") = getParam<MooseFunctorName>("emissivity");
83  pars.set<MooseFunctorName>("view_factor") = getParam<MooseFunctorName>("view_factor");
84  pars.set<Point>("axis_point") = hs_cyl->getPosition();
85  pars.set<RealVectorValue>("axis_dir") = hs_cyl->getDirection();
86  if (getParam<bool>("scale_heat_rate_pp"))
87  pars.set<MooseFunctorName>("scale") = getParam<MooseFunctorName>("scale");
88  pars.set<ExecFlagEnum>("execute_on") = {EXEC_INITIAL, EXEC_TIMESTEP_END};
89  getTHMProblem().addPostprocessor(class_name, genSafeName(name(), "integral"), pars);
90  }
91 }
std::string genName(const std::string &prefix, unsigned int id, const std::string &suffix="") const
Build a name from a prefix, number and possible suffix.
void addDeprecatedParam(const std::string &name, const T &value, const std::string &doc_string, const std::string &deprecation_message)
virtual void addMooseObjects() override
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
THMProblem & getTHMProblem() const
Gets the THM problem.
Definition: Component.C:135
T & set(const std::string &name, bool quiet_mode=false)
InputParameters getValidParams(const std::string &name) const
const ExecFlagType EXEC_TIMESTEP_END
std::string genSafeName(const std::string &prefix, const std::string &middle, const std::string &suffix="") const
Build a name from strings that is safe to use in input files (i.e.
virtual const std::string & name() const
void addRequiredParam(const std::string &name, const std::string &doc_string)
virtual void addBoundaryCondition(const std::string &bc_name, const std::string &name, InputParameters &parameters)
bool isParamValid(const std::string &name) const
virtual void addPostprocessor(const std::string &pp_name, const std::string &name, InputParameters &parameters)
Base class for cylindrical heat structure components.
Radiative heat transfer boundary condition for heat structure.
const std::vector< BoundaryName > & _boundary
Boundary names for which the boundary component applies.
Definition: HSBoundary.h:56
static const std::string TEMPERATURE
static InputParameters validParams()
Interface class for heat structure components.
registerMooseObject("ThermalHydraulicsApp", HSBoundaryRadiation)
HSBoundaryRadiation(const InputParameters &params)
static InputParameters validParams()
Definition: HSBoundary.C:15
Factory & _factory
The Factory associated with the MooseApp.
Definition: Component.h:446
void addClassDescription(const std::string &doc_string)
Base class for heat structure boundary components.
Definition: HSBoundary.h:18
const ExecFlagType EXEC_INITIAL