https://mooseframework.inl.gov
SCMDetailedTriSubChannelMeshGenerator.h
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 #pragma once
11 
12 #include "MeshGenerator.h"
13 #include "SubChannelEnums.h"
14 
19 {
20 public:
22  virtual std::unique_ptr<MeshBase> generate() override;
23 
24 protected:
26  EChannelType getSubchannelType(unsigned int index) const { return _subch_type[index]; }
27  Point rotatePoint(Point b, Real theta);
28  Point translatePoint(Point & b, Point & translation_vector);
30  Point getPinPosition(unsigned int i) { return _pin_position[i]; }
32  std::vector<Real> getSubchannelPosition(unsigned int i) { return _subchannel_position[i]; }
34  std::vector<unsigned int> getSubChannelPins(unsigned int i) { return _chan_to_pin_map[i]; }
35 
43  std::vector<Real> _z_grid;
45  const Real _pitch;
49  const unsigned int _n_rings;
53  std::vector<EChannelType> _subch_type;
55  std::vector<Point> _pin_position;
57  std::vector<std::vector<Real>> _subchannel_position;
59  const unsigned int & _block_id;
61  const unsigned int _n_cells;
63  unsigned int _nrods;
65  std::vector<std::vector<unsigned int>> _pins_in_rings;
67  std::map<unsigned int, Real> _orientation_map;
69  unsigned int _n_channels;
71  std::vector<std::vector<unsigned int>> _chan_to_pin_map;
73  const bool _verbose;
74 
75 public:
77 };
const unsigned int _n_rings
Number of rings in the geometry.
const unsigned int & _block_id
Subdomain ID used for the mesh block.
std::vector< std::vector< Real > > _subchannel_position
x,y coordinates of the subchannels
const Real _pitch
Distance between the neighbor fuel pins, pitch.
virtual std::unique_ptr< MeshBase > generate() override
Point getPinPosition(unsigned int i)
returns the position of pin given pin index
Mesh generator that builds a 3D mesh representing triangular subchannels.
EChannelType getSubchannelType(unsigned int index) const
returns the type of the subchannel given the index
std::vector< Real > _z_grid
axial location of nodes
SCMDetailedTriSubChannelMeshGenerator(const InputParameters &parameters)
std::vector< unsigned int > getSubChannelPins(unsigned int i)
returns the index of neighboring pins given subchannel index
Point translatePoint(Point &b, Point &translation_vector)
EChannelType
Enum for describing the center, edge and corner subchannels or gap types.
const Real _unheated_length_exit
unheated length of the fuel Pin at the exit of the assembly
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const Real _flat_to_flat
Half of gap between adjacent assemblies.
std::vector< Point > _pin_position
x,y coordinates of the fuel pins
std::vector< EChannelType > _subch_type
Subchannel type.
const InputParameters & parameters() const
std::vector< std::vector< unsigned int > > _pins_in_rings
fuel pins that are belonging to each ring
std::vector< Real > getSubchannelPosition(unsigned int i)
returns the position of subchannel given pin index
const Real _unheated_length_entry
unheated length of the fuel Pin at the entry of the assembly
const unsigned int _n_cells
Number of cells in the axial direction.
std::vector< std::vector< unsigned int > > _chan_to_pin_map
stores the fuel pins belonging to each subchannel
const bool _verbose
Flag to print out the detailed mesh assembly and coordinates.
const Real _heated_length
heated length of the fuel Pin
std::map< unsigned int, Real > _orientation_map
map inner and outer rings