https://mooseframework.inl.gov
SCMHTCSchadModified.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 "SCMHTCSchadModified.h"
11 
13 
16 {
18  params.addClassDescription(
19  "Class that computes the convective heat transfer coefficient using the "
20  "Schad-Modified correlation. Only use for fuel-pins.");
21  return params;
22 }
23 
25  : SCMHTCClosureBase(parameters)
26 {
27  // Check that the correlation not used for the duct (not supported yet)
28  if (const auto * duct_uo = _scm_problem.getDuctHTCClosure(); duct_uo && duct_uo == this)
29  mooseError("'Schad-Modified' is not yet supported for the 'duct_htc_correlation'.");
30 }
31 
32 Real
34  const NusseltStruct & nusselt_args) const
35 {
36  const auto pre = computeNusseltNumberPreInfo(nusselt_args);
37  const auto Pe = pre.Re * pre.Pr;
38 
39  if (pre.poD < 1.1 || pre.poD > 1.5)
40  flagSolutionWarning(
41  "Pitch over pin diameter ratio out of range for the Schad-Modified correlation.");
42 
43  const Real poly = -16.15 + 24.96 * pre.poD - 8.55 * Utility::pow<2>(pre.poD);
44  auto NuT = 0.0;
45  if (Pe <= 1000 && Pe >= 150)
46  {
47  NuT = poly * std::pow(Pe, 0.3);
48  }
49  else if (Pe < 150)
50  {
51  NuT = poly * 4.496;
52  flagSolutionWarning(
53  "Peclet number (Pe) below recommended range for the Schad-Modified correlation.");
54  }
55  else
56  {
57  flagSolutionWarning(
58  "Peclet number (Pe) above recommended range for the Schad-Modified correlation.");
59  NuT = poly * std::pow(Pe, 0.3);
60  }
61 
62  return blendTurbulentNusseltNumber(pre, NuT);
63 }
R poly(const C &c, const T x, const bool derivative=false)
static InputParameters validParams()
NusseltPreInfo computeNusseltNumberPreInfo(const NusseltStruct &nusselt_info) const
Computes all the data needed before computing the nusselt number. It&#39;s used by all closure models...
registerMooseObject("SubChannelApp", SCMHTCSchadModified)
structure with the needed information to compute the friction factor at a specific subchannel cell ...
const SubChannel1PhaseProblem & _scm_problem
Reference to the subchannel problem.
virtual Real computeNusseltNumber(const FrictionStruct &friction_info, const NusseltStruct &nusselt_info) const override
Computes the nusselt number for the local conditions.
static InputParameters validParams()
const SCMHTCClosureBase * getDuctHTCClosure() const
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
void mooseError(Args &&... args) const
void addClassDescription(const std::string &doc_string)
Base class for the convective heat transfer coefficients (HTC) closures used in SCM.
MooseUnits pow(const MooseUnits &, int)
SCMHTCSchadModified(const InputParameters &parameters)
Real blendTurbulentNusseltNumber(const NusseltPreInfo &nusselt_info, const Real turbulent_nusselt) const
Blends turbulent Nusselt number through the transition range using the base laminar value...
structure with the needed information to compute the Nusselt number at a specific subchannel cell and...
Class that calculates the HTC based on the Schad-Modified correlation It can be used only for fuel pi...