15 using namespace Eigen;
23 params.
addClassDescription(
"Computes axial heat rate (W/m) assigned to the fuel pins in a square " 24 "lattice arrangement");
27 "power",
"The postprocessor or Real to use for the total power of the subassembly [W]");
29 "filename",
"name of radial power profile .txt file (should be a single column) [UnitLess].");
33 "user provided normalized function of axial heat rate [Unitless]. " 34 "The integral over pin heated length should equal the heated length");
40 _power(getPostprocessorValue(
"power")),
42 _filename(getParam<
std::string>(
"filename")),
43 _axial_heat_rate(getFunction(
"axial_heat_rate"))
69 if (inFile.fail() && !inFile.eof())
73 mooseError(
name(),
" Radial profile file doesn't have correct size : ", n_pins);
88 auto fpin_power =
_power / sum;
108 for (
unsigned int iz = 1; iz < nz + 1; iz++)
111 auto z2 = z_grid[iz];
112 auto z1 = z_grid[iz - 1];
113 Point p1(0, 0, z1 - unheated_length_entry);
114 Point p2(0, 0, z2 - unheated_length_entry);
117 if (MooseUtils::absoluteFuzzyGreaterThan(z2, unheated_length_entry) &&
118 MooseUtils::absoluteFuzzyLessThan(z1, unheated_length_entry + heated_length))
121 for (
unsigned int i_pin = 0; i_pin < n_pins; i_pin++)
127 if (MooseUtils::absoluteFuzzyGreaterThan(z2, unheated_length_entry) &&
128 MooseUtils::absoluteFuzzyLessThan(z1, unheated_length_entry))
134 if (MooseUtils::absoluteFuzzyGreaterThan(z2, unheated_length_entry + heated_length) &&
135 MooseUtils::absoluteFuzzyLessThan(z1, unheated_length_entry + heated_length))
147 auto total_power = 0.0;
148 for (
unsigned int i_pin = 0; i_pin < n_pins; i_pin++)
158 _console <<
"###########################################" << std::endl;
159 _console <<
"Total power estimation by IC kernel before correction: " << total_power <<
" [W] " 169 Point p1(0, 0, unheated_length_entry);
173 if (MooseUtils::absoluteFuzzyGreaterEqual(
p(2), unheated_length_entry) &&
174 MooseUtils::absoluteFuzzyLessEqual(
p(2), unheated_length_entry + heated_length))
SCMQuadPowerIC(const InputParameters ¶ms)
const PostprocessorValue & _power
The total power of the assembly.
registerMooseObject("SubChannelApp", SCMQuadPowerIC)
unsigned int _numberoflines
The number of lines associated with the radial power profile .txt file.
virtual const std::vector< Real > & getZGrid() const
Get axial location of layers.
static InputParameters validParams()
An abstract class for ICs for quadrilateral subchannels.
Eigen::MatrixXd _ref_qprime
Average linear heat rate over the whole pin [W/m].
Real value(const Point &p) override
const QuadSubChannelMesh & _mesh
static InputParameters validParams()
const std::string & name() const
virtual const Real & getHeatedLength() const
Return heated length.
Eigen::MatrixXd _estimate_power
Matrix which will hold the total estimated power of each pin [W].
Eigen::MatrixXd _pin_power_correction
The correction that will be applied to the estimated calculation [unitless].
bool pinMeshExist() const
Return if Pin Mesh exists or not.
Eigen::MatrixXd _power_dis
Matrix that holds the relative pin power.
Eigen::MatrixXd _ref_power
Actual pin power [W].
virtual unsigned int getNumOfAxialCells() const
Return the number of axial cells.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const Function & _axial_heat_rate
void mooseError(Args &&... args) const
unsigned int getPinIndexFromPoint(const Point &p) const override
Return a pin index for a given physical point p
const ConsoleStream _console
virtual Real value(Real t, const Point &p) const
processor_id_type processor_id() const
unsigned int getNumOfPins() const override
Return the number of pins.
virtual const Real & getHeatedLengthEntry() const
Return unheated length at entry.
std::string _filename
The name of the radial power profile file.
virtual void initialSetup() override
Sets the axial heat rate for each pin according to a radial power distribution and a user defined axi...