https://mooseframework.inl.gov
ADWallHeatTransferCoefficientWolfMcCarthyMaterial.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 
12 #include "FlowModelSinglePhase.h"
13 #include "Numerics.h"
14 
16 
19 {
21  params.addParam<MaterialPropertyName>("Hw",
23  "Heat transfer coefficient material property");
24  params.addParam<MaterialPropertyName>(
25  "rho", FlowModelSinglePhase::DENSITY, "Density of the liquid");
26  params.addParam<MaterialPropertyName>("vel", FlowModelSinglePhase::VELOCITY, "Fluid velocity");
27  params.addParam<MaterialPropertyName>(
28  "D_h", FlowModelSinglePhase::HYDRAULIC_DIAMETER, "Hydraulic diameter");
29  params.addParam<MaterialPropertyName>(
30  "cp", FlowModelSinglePhase::SPECIFIC_HEAT_CONSTANT_PRESSURE, "Specific heat of the fluid");
31  params.addParam<MaterialPropertyName>(
32  "mu", FlowModelSinglePhase::DYNAMIC_VISCOSITY, "Dynamic viscosity of the fluid");
33  params.addParam<MaterialPropertyName>(
34  "k", FlowModelSinglePhase::THERMAL_CONDUCTIVITY, "Heat conductivity of the fluid");
35  params.addParam<MaterialPropertyName>(
36  "T", FlowModelSinglePhase::TEMPERATURE, "Fluid temperature");
37  params.addParam<MaterialPropertyName>("T_wall", FlowModel::TEMPERATURE_WALL, "Wall temperature");
38  params.addClassDescription(
39  "Computes wall heat transfer coefficient using Wolf-McCarthy correlation");
40  return params;
41 }
42 
45  : Material(parameters),
46  _Hw(declareADProperty<Real>("Hw")),
47  _rho(getADMaterialProperty<Real>("rho")),
48  _vel(getADMaterialProperty<Real>("vel")),
49  _D_h(getADMaterialProperty<Real>("D_h")),
50  _k(getADMaterialProperty<Real>("k")),
51  _mu(getADMaterialProperty<Real>("mu")),
52  _cp(getADMaterialProperty<Real>("cp")),
53  _T(getADMaterialProperty<Real>("T")),
54  _T_wall(getADMaterialProperty<Real>("T_wall"))
55 {
56 }
57 
58 void
60 {
61  ADReal Pr = THM::Prandtl(_cp[_qp], _mu[_qp], _k[_qp]);
62  ADReal Re = std::max(1.0, THM::Reynolds(1., _rho[_qp], _vel[_qp], _D_h[_qp], _mu[_qp]));
63  ADReal Nu = 0.025 * std::pow(Re, 0.8) * std::pow(Pr, 0.4) *
64  std::pow(std::max(_T[_qp], _T_wall[_qp]) / _T[_qp], -0.55);
65 
67 }
static const std::string SPECIFIC_HEAT_CONSTANT_PRESSURE
registerMooseObject("ThermalHydraulicsApp", ADWallHeatTransferCoefficientWolfMcCarthyMaterial)
static const std::string DYNAMIC_VISCOSITY
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
static const std::string TEMPERATURE
auto Prandtl(const T1 &cp, const T2 &mu, const T3 &k)
Compute Prandtl number.
Definition: Numerics.h:133
static const std::string VELOCITY
auto Reynolds(const T1 &volume_fraction, const T2 &rho, const T3 &vel, const T4 &D_h, const T5 &mu)
Compute Reynolds number.
Definition: Numerics.h:118
static const std::string THERMAL_CONDUCTIVITY
static const std::string HEAT_TRANSFER_COEFFICIENT_WALL
static const std::string DENSITY
unsigned int _qp
Computes wall heat transfer coefficient using the Wolf-McCarthy correlation.
static InputParameters validParams()
static const std::string TEMPERATURE_WALL
Definition: FlowModel.h:108
auto wallHeatTransferCoefficient(const T1 &Nu, const T2 &k, const T3 &D_h)
Compute wall heat transfer coefficient.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
ADMaterialProperty< Real > & _Hw
Wall heat transfer coefficient.
static const std::string HYDRAULIC_DIAMETER
void addClassDescription(const std::string &doc_string)
MooseUnits pow(const MooseUnits &, int)