https://mooseframework.inl.gov
Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Static Public Attributes | Protected Member Functions | Static Protected Member Functions | Protected Attributes | List of all members
ReactorMeshParams Class Reference

A class to store mesh information that is globally applicable to a reactor. More...

#include <ReactorMeshParams.h>

Inheritance diagram for ReactorMeshParams:
[legend]

Public Types

typedef DataFileName DataFileParameterType
 

Public Member Functions

 ReactorMeshParams (const InputParameters &parameters)
 
std::unique_ptr< MeshBase > generate () override
 
void generateData () override
 
std::unique_ptr< MeshBase > generateInternal ()
 
const std::set< MeshGeneratorName > & getRequestedMeshGenerators () const
 
const std::set< MeshGeneratorName > & getRequestedMeshGeneratorsForSub () const
 
void addParentMeshGenerator (const MeshGenerator &mg, const AddParentChildKey)
 
void addChildMeshGenerator (const MeshGenerator &mg, const AddParentChildKey)
 
const std::set< const MeshGenerator *, Comparator > & getParentMeshGenerators () const
 
const std::set< const MeshGenerator *, Comparator > & getChildMeshGenerators () const
 
const std::set< const MeshGenerator *, Comparator > & getSubMeshGenerators () const
 
bool isParentMeshGenerator (const MeshGeneratorName &name, const bool direct=true) const
 
bool isChildMeshGenerator (const MeshGeneratorName &name, const bool direct=true) const
 
bool isNullMeshName (const MeshGeneratorName &name) const
 
bool hasSaveMesh () const
 
bool hasOutput () const
 
const std::string & getSavedMeshName () const
 
bool hasGenerateData () const
 
bool isDataOnly () const
 
virtual bool enabled () const
 
std::shared_ptr< MooseObjectgetSharedPtr ()
 
std::shared_ptr< const MooseObjectgetSharedPtr () const
 
MooseAppgetMooseApp () const
 
const std::string & type () const
 
virtual const std::string & name () const
 
std::string typeAndName () const
 
std::string errorPrefix (const std::string &error_type) const
 
void callMooseError (std::string msg, const bool with_prefix) const
 
MooseObjectParameterName uniqueParameterName (const std::string &parameter_name) const
 
const InputParametersparameters () const
 
MooseObjectName uniqueName () const
 
const T & getParam (const std::string &name) const
 
std::vector< std::pair< T1, T2 > > getParam (const std::string &param1, const std::string &param2) const
 
const T * queryParam (const std::string &name) const
 
const T & getRenamedParam (const std::string &old_name, const std::string &new_name) const
 
getCheckedPointerParam (const std::string &name, const std::string &error_string="") const
 
bool isParamValid (const std::string &name) const
 
bool isParamSetByUser (const std::string &nm) const
 
void paramError (const std::string &param, Args... args) const
 
void paramWarning (const std::string &param, Args... args) const
 
void paramInfo (const std::string &param, Args... args) const
 
void connectControllableParams (const std::string &parameter, const std::string &object_type, const std::string &object_name, const std::string &object_parameter) const
 
void mooseError (Args &&... args) const
 
void mooseErrorNonPrefixed (Args &&... args) const
 
void mooseDocumentedError (const std::string &repo_name, const unsigned int issue_num, Args &&... args) const
 
void mooseWarning (Args &&... args) const
 
void mooseWarningNonPrefixed (Args &&... args) const
 
void mooseDeprecated (Args &&... args) const
 
void mooseInfo (Args &&... args) const
 
std::string getDataFileName (const std::string &param) const
 
std::string getDataFileNameByName (const std::string &relative_path) const
 
std::string getDataFilePath (const std::string &relative_path) const
 
const Parallel::Communicator & comm () const
 
processor_id_type n_processors () const
 
processor_id_type processor_id () const
 

Static Public Member Functions

static InputParameters validParams ()
 
static bool hasGenerateData (const InputParameters &params)
 
static void setHasGenerateData (InputParameters &params)
 

Public Attributes

const ConsoleStream _console
 

Static Public Attributes

static const std::string data_only_param
 
static constexpr auto SYSTEM
 
static constexpr auto NAME
 

Protected Member Functions

T & copyMeshProperty (const std::string &target_data_name, const std::string &source_data_name, const std::string &source_mesh)
 
T & copyMeshProperty (const std::string &source_data_name, const std::string &source_mesh)
 
std::unique_ptr< MeshBase > & getMesh (const std::string &param_name, const bool allow_invalid=false)
 
std::vector< std::unique_ptr< MeshBase > *> getMeshes (const std::string &param_name)
 
std::unique_ptr< MeshBase > & getMeshByName (const MeshGeneratorName &mesh_generator_name)
 
std::vector< std::unique_ptr< MeshBase > *> getMeshesByName (const std::vector< MeshGeneratorName > &mesh_generator_names)
 
void declareMeshForSub (const std::string &param_name)
 
void declareMeshesForSub (const std::string &param_name)
 
void declareMeshForSubByName (const MeshGeneratorName &mesh_generator_name)
 
void declareMeshesForSubByName (const std::vector< MeshGeneratorName > &mesh_generator_names)
 
std::unique_ptr< MeshBase > buildMeshBaseObject (unsigned int dim=libMesh::invalid_uint)
 
std::unique_ptr< ReplicatedMesh > buildReplicatedMesh (unsigned int dim=libMesh::invalid_uint)
 
std::unique_ptr< DistributedMesh > buildDistributedMesh (unsigned int dim=libMesh::invalid_uint)
 
void addMeshSubgenerator (const std::string &type, const std::string &name, Ts... extra_input_parameters)
 
void addMeshSubgenerator (const std::string &type, const std::string &name, InputParameters params)
 
void declareNullMeshName (const MeshGeneratorName &name)
 
const T & getMeshProperty (const std::string &data_name, const std::string &prefix)
 
const T & getMeshProperty (const std::string &data_name)
 
bool hasMeshProperty (const std::string &data_name, const std::string &prefix) const
 
bool hasMeshProperty (const std::string &data_name, const std::string &prefix) const
 
bool hasMeshProperty (const std::string &data_name) const
 
bool hasMeshProperty (const std::string &data_name) const
 
std::string meshPropertyName (const std::string &data_name) const
 
T & declareMeshProperty (const std::string &data_name, Args &&... args)
 
T & declareMeshProperty (const std::string &data_name, const T &data_value)
 
T & declareMeshProperty (const std::string &data_name, Args &&... args)
 
T & declareMeshProperty (const std::string &data_name, const T &data_value)
 
T & setMeshProperty (const std::string &data_name, Args &&... args)
 
T & setMeshProperty (const std::string &data_name, const T &data_value)
 
T & setMeshProperty (const std::string &data_name, Args &&... args)
 
T & setMeshProperty (const std::string &data_name, const T &data_value)
 

Static Protected Member Functions

static std::string meshPropertyName (const std::string &data_name, const std::string &prefix)
 

Protected Attributes

const MooseEnum _dim
 The number of dimension in the mesh. More...
 
const MooseEnum _geom
 The geometry type for the reactor. More...
 
const Real _assembly_pitch
 The the flat-to-flat size of assemblies in the reactor. More...
 
std::vector< Real_axial_regions
 The heights of the axial regions. More...
 
std::vector< unsigned int_axial_mesh_intervals
 The number of mesh divisions in each axial region. More...
 
boundary_id_type _top_boundary
 Boundary id assigned to top boundary of extruded mesh. More...
 
boundary_id_type _bottom_boundary
 Boundary id assigned to bottom boundary of extruded mesh. More...
 
boundary_id_type _radial_boundary
 Boundary id assigned to outer radial boundary of core mesh. More...
 
MooseMesh *const _mesh
 
const bool & _enabled
 
MooseApp_app
 
const std::string _type
 
const std::string _name
 
const InputParameters_pars
 
Factory_factory
 
ActionFactory_action_factory
 
const Parallel::Communicator & _communicator
 

Detailed Description

A class to store mesh information that is globally applicable to a reactor.

Definition at line 18 of file ReactorMeshParams.h.

Constructor & Destructor Documentation

◆ ReactorMeshParams()

ReactorMeshParams::ReactorMeshParams ( const InputParameters parameters)

Definition at line 65 of file ReactorMeshParams.C.

67  _dim(getParam<MooseEnum>("dim")),
68  _geom(getParam<MooseEnum>("geom")),
69  _assembly_pitch(getParam<Real>("assembly_pitch"))
70 {
71  if ((unsigned int)(_dim) == 2)
72  {
73  std::vector<std::string> invalid_params = {
74  "axial_regions", "axial_mesh_intervals", "top_boundary_id", "bottom_boundary_id"};
75  for (const auto & param : invalid_params)
76  if (isParamValid(param))
77  paramError(param, param + " should not be defined for 2-D meshes");
78  }
79  else
80  {
81  _axial_regions = getParam<std::vector<Real>>("axial_regions");
82  _axial_mesh_intervals = getParam<std::vector<unsigned int>>("axial_mesh_intervals");
83 
84  if (_axial_regions.size() != _axial_mesh_intervals.size())
85  mooseError(
86  "The number of axial regions is not consistent with the number of axial intervals.");
88  this->declareMeshProperty(RGMB::axial_mesh_intervals, _axial_mesh_intervals);
89  }
90 
91  this->declareMeshProperty(RGMB::mesh_dimensions, (unsigned int)std::stoul(_dim));
92  this->declareMeshProperty(RGMB::mesh_geometry, std::string(_geom));
95  getParam<bool>(RGMB::region_id_as_block_name));
96 
98  this->declareMeshProperty(RGMB::flexible_assembly_stitching, flexible_assembly_stitching);
101  getParam<unsigned int>("num_sectors_at_flexible_boundary"));
102  if (parameters.isParamSetByUser("num_sectors_at_flexible_boundary") &&
104  paramWarning(
105  "num_sectors_at_flexible_boundary",
106  "This parameter is only relevant when ReactorMeshParams/flexible_assembly_stitching is set "
107  "to true. This value will be ignored");
108 
109  // Option to bypass mesh generation is controlled by presence of Mesh/data_driven_generator
110  // and whether the current generator is in data only mode
111  const auto & moose_mesh = _app.actionWarehouse().getMesh();
112  const auto data_driven_generator =
113  moose_mesh->parameters().get<std::string>("data_driven_generator");
114  bool bypass_meshgen = (data_driven_generator != "") && isDataOnly();
115  this->declareMeshProperty(RGMB::bypass_meshgen, bypass_meshgen);
116 
117  if (isParamValid("top_boundary_id"))
118  {
119  _top_boundary = getParam<boundary_id_type>("top_boundary_id");
121  }
122  if (isParamValid("bottom_boundary_id"))
123  {
124  _bottom_boundary = getParam<boundary_id_type>("bottom_boundary_id");
126  }
127  if (isParamValid("radial_boundary_id"))
128  {
129  _radial_boundary = getParam<boundary_id_type>("radial_boundary_id");
131  if (isParamValid("top_boundary_id") && _radial_boundary == _top_boundary)
132  mooseError("top_boundary_id and radial_boundary_id must be unique values");
133  if (isParamValid("bottom_boundary_id") && _radial_boundary == _bottom_boundary)
134  mooseError("bottom_boundary_id and radial_boundary_id must be unique values");
135  }
136  if (isParamValid("top_boundary_id") && isParamValid("bottom_boundary_id") &&
138  mooseError("top_boundary_id and bottom_boundary_id must be unique values");
139 }
static const std::string region_id_as_block_name
const MooseEnum _geom
The geometry type for the reactor.
const std::shared_ptr< MooseMesh > & getMesh() const
static const std::string mesh_geometry
MeshGenerator(const InputParameters &parameters)
static const std::string axial_mesh_sizes
static const std::string assembly_pitch
static const std::string radial_boundary_id
bool isParamValid(const std::string &name) const
boundary_id_type _bottom_boundary
Boundary id assigned to bottom boundary of extruded mesh.
static const std::string mesh_dimensions
boundary_id_type _radial_boundary
Boundary id assigned to outer radial boundary of core mesh.
const Real _assembly_pitch
The the flat-to-flat size of assemblies in the reactor.
ActionWarehouse & actionWarehouse()
static const std::string top_boundary_id
void paramError(const std::string &param, Args... args) const
std::vector< unsigned int > _axial_mesh_intervals
The number of mesh divisions in each axial region.
bool isParamSetByUser(const std::string &name) const
const MooseEnum _dim
The number of dimension in the mesh.
static const std::string flexible_assembly_stitching
MooseApp & _app
static const std::string axial_mesh_intervals
boundary_id_type _top_boundary
Boundary id assigned to top boundary of extruded mesh.
void mooseError(Args &&... args) const
const InputParameters & parameters() const
T & declareMeshProperty(const std::string &data_name, Args &&... args)
void paramWarning(const std::string &param, Args... args) const
static const std::string bypass_meshgen
bool isDataOnly() const
static const std::string num_sectors_flexible_stitching
static const std::string bottom_boundary_id
std::vector< Real > _axial_regions
The heights of the axial regions.

Member Function Documentation

◆ generate()

std::unique_ptr< MeshBase > ReactorMeshParams::generate ( )
overridevirtual

Implements MeshGenerator.

Definition at line 142 of file ReactorMeshParams.C.

143 {
144  // If mesh generation is requested and bypass_mesh is true, return a null mesh. generate()
145  // mesh should not be called with this option specified
146  if (getMeshProperty<bool>(RGMB::bypass_meshgen))
147  {
148  auto null_mesh = nullptr;
149  return null_mesh;
150  }
151  auto mesh = buildMeshBaseObject();
152  return dynamic_pointer_cast<MeshBase>(mesh);
153 }
MeshBase & mesh
std::unique_ptr< T_DEST, T_DELETER > dynamic_pointer_cast(std::unique_ptr< T_SRC, T_DELETER > &src)
static const std::string bypass_meshgen
std::unique_ptr< MeshBase > buildMeshBaseObject(unsigned int dim=libMesh::invalid_uint)

◆ generateData()

void ReactorMeshParams::generateData ( )
inlineoverridevirtual

Reimplemented from MeshGenerator.

Definition at line 27 of file ReactorMeshParams.h.

27 {};

◆ validParams()

InputParameters ReactorMeshParams::validParams ( )
static

Definition at line 25 of file ReactorMeshParams.C.

26 {
28  MooseEnum dims("2=2 3", "2");
29  params.addRequiredParam<MooseEnum>("dim", dims, "The dimension of the mesh to be generated");
30 
31  MooseEnum geoms("Square Hex", "Square");
32  params.addRequiredParam<MooseEnum>("geom", geoms, "The geometry type of the reactor mesh");
33 
34  params.addRequiredParam<Real>("assembly_pitch", "Center to center distance of assemblies");
35  params.addParam<boundary_id_type>("top_boundary_id",
36  "The boundary ID to set on top boundary of the extruded mesh");
37  params.addParam<boundary_id_type>(
38  "bottom_boundary_id", "The boundary ID to set on bottom boundary of the extruded mesh");
39  params.addParam<boundary_id_type>(
40  "radial_boundary_id",
41  "The boundary ID to set on the outer radial boundary of a CoreMeshGenerator object");
42  params.addParam<std::vector<Real>>("axial_regions", "Length of each axial region");
43  params.addParam<std::vector<unsigned int>>(
44  "axial_mesh_intervals",
45  "Number of elements in the Z direction for each axial region");
46  params.addParam<bool>("region_id_as_block_name", false, "Set block names based on region id");
47  params.addParam<bool>(
48  "flexible_assembly_stitching",
49  false,
50  "Use FlexiblePatternGenerator for stitching dissimilar assemblies together");
51  params.addRangeCheckedParam<unsigned int>(
52  "num_sectors_at_flexible_boundary",
53  6,
54  "num_sectors_at_flexible_boundary>2",
55  "Number of sectors to use at assembly boundary interface when flexible patterning is used "
56  "(Defaults to 6)");
57  params.addClassDescription("This ReactorMeshParams object acts as storage for persistent "
58  "information about the reactor geometry.");
59 
60  // Declare that this generator has a generateData method
62  return params;
63 }
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
void addRequiredParam(const std::string &name, const std::string &doc_string)
int8_t boundary_id_type
static InputParameters validParams()
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
static void setHasGenerateData(InputParameters &params)
void addClassDescription(const std::string &doc_string)
void addRangeCheckedParam(const std::string &name, const T &value, const std::string &parsed_function, const std::string &doc_string)

Member Data Documentation

◆ _assembly_pitch

const Real ReactorMeshParams::_assembly_pitch
protected

The the flat-to-flat size of assemblies in the reactor.

Definition at line 37 of file ReactorMeshParams.h.

Referenced by ReactorMeshParams().

◆ _axial_mesh_intervals

std::vector<unsigned int> ReactorMeshParams::_axial_mesh_intervals
protected

The number of mesh divisions in each axial region.

Definition at line 43 of file ReactorMeshParams.h.

Referenced by ReactorMeshParams().

◆ _axial_regions

std::vector<Real> ReactorMeshParams::_axial_regions
protected

The heights of the axial regions.

Definition at line 40 of file ReactorMeshParams.h.

Referenced by ReactorMeshParams().

◆ _bottom_boundary

boundary_id_type ReactorMeshParams::_bottom_boundary
protected

Boundary id assigned to bottom boundary of extruded mesh.

Definition at line 49 of file ReactorMeshParams.h.

Referenced by ReactorMeshParams().

◆ _dim

const MooseEnum ReactorMeshParams::_dim
protected

The number of dimension in the mesh.

Definition at line 27 of file ReactorMeshParams.h.

Referenced by ReactorMeshParams().

◆ _geom

const MooseEnum ReactorMeshParams::_geom
protected

The geometry type for the reactor.

Definition at line 34 of file ReactorMeshParams.h.

Referenced by ReactorMeshParams().

◆ _radial_boundary

boundary_id_type ReactorMeshParams::_radial_boundary
protected

Boundary id assigned to outer radial boundary of core mesh.

Definition at line 52 of file ReactorMeshParams.h.

Referenced by ReactorMeshParams().

◆ _top_boundary

boundary_id_type ReactorMeshParams::_top_boundary
protected

Boundary id assigned to top boundary of extruded mesh.

Definition at line 46 of file ReactorMeshParams.h.

Referenced by ReactorMeshParams().


The documentation for this class was generated from the following files: