https://mooseframework.inl.gov
ADWallHeatTransferCoefficientGnielinskiMaterial.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 fluid");
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("Computes wall heat transfer coefficient for gases and water using "
39  "the Gnielinski correlation");
40  return params;
41 }
42 
44  const InputParameters & parameters)
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 
64  if (Re < 2300 || Re > 5E+6 || Pr < 0.5 || Pr > 2000)
65  {
66  mooseDoOnce(mooseWarning(
67  "The Gnielinski correlation is valid when Pr is between 0.5 and 2000, and Re is "
68  "between 2300 and 5000000. Be aware that using values out of this range may lead to "
69  "significant errors in your results!"));
70  }
71 
72  ADReal f = std::pow(1.82 * std::log10(Re) - 1.64, -2.0);
73  ADReal Nu = ((f / 8.0) * std::max(0.0, Re - 1000.0) * Pr) /
74  (1.0 + 12.7 * std::sqrt(f / 8.0) * (std::pow(Pr, 2.0 / 3.0) - 1.0));
76 }
static const std::string SPECIFIC_HEAT_CONSTANT_PRESSURE
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
const ADMaterialProperty< Real > & _k
Thermal conductivity.
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
void mooseWarning(Args &&... args) const
unsigned int _qp
static InputParameters validParams()
static const std::string TEMPERATURE_WALL
Definition: FlowModel.h:108
Real f(Real x)
Test function for Brents method.
auto wallHeatTransferCoefficient(const T1 &Nu, const T2 &k, const T3 &D_h)
Compute wall heat transfer coefficient.
const ADMaterialProperty< Real > & _D_h
Hydraulic diameter.
ADMaterialProperty< Real > & _Hw
Wall heat transfer coefficient.
Computes wall heat transfer coefficient for gases and water using the Gnielinski correlation.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
static const std::string HYDRAULIC_DIAMETER
void addClassDescription(const std::string &doc_string)
const ADMaterialProperty< Real > & _cp
Specific heat capacity.
registerMooseObject("ThermalHydraulicsApp", ADWallHeatTransferCoefficientGnielinskiMaterial)
MooseUnits pow(const MooseUnits &, int)