https://mooseframework.inl.gov
Public Member Functions | Static Public Member Functions | Protected Member Functions | Protected Attributes | Friends | List of all members
CSG::CSGLattice Class Referenceabstract

CSGLattice is the abstract class for defining lattices. More...

#include <CSGLattice.h>

Inheritance diagram for CSG::CSGLattice:
[legend]

Public Member Functions

 CSGLattice (const std::string &name, const std::string &lattice_type, const std::optional< OuterVariant > &outer=std::nullopt)
 Construct a new CSGLattice of specific type. More...
 
virtual ~CSGLattice ()=default
 Destructor. More...
 
virtual std::unique_ptr< CSGLatticeclone () const =0
 
const std::string & getName () const
 Get the name of lattice. More...
 
const std::string & getType () const
 Get the lattice type. More...
 
const std::string getOuterType () const
 Get the type of outer that fills the space around the lattice elements. More...
 
const CSGUniversegetOuterUniverse () const
 Get the outer universe if outer type is UNIVERSE. More...
 
const std::string & getOuterMaterial () const
 Get the outer material name if outer fype is CSG_MATERIAL. More...
 
std::vector< std::vector< std::reference_wrapper< const CSGUniverse > > > getUniverses () const
 Get the arrangement of CSGUniverses in the lattice. More...
 
const std::vector< std::vector< std::string > > getUniverseNameMap () const
 Get the arrangement of CSGUniverses in the lattice as their names. More...
 
bool hasUniverse (const std::string &name) const
 whether or not the universe of the specified name exists in the lattice More...
 
virtual std::unordered_map< std::string, AttributeVariantgetAttributes () const =0
 Get attributes that define the lattice (excluding the universe map). More...
 
virtual bool isValidIndex (const std::pair< int, int > index) const =0
 Checks if the given index location is a valid index for the lattice. More...
 
const CSGUniversegetUniverseAtIndex (const std::pair< int, int > index)
 Get the universe located at the given index. More...
 
const std::vector< std::pair< unsigned int, unsigned int > > getUniverseIndices (const std::string &univ_name) const
 get all locations in lattice where universe of the specified name exists More...
 
virtual bool isValidUniverseMap (std::vector< std::vector< std::reference_wrapper< const CSGUniverse >>> universes) const =0
 check that any provided list of list of CSGUniverses are the correct dimensions for the type of lattice More...
 
void resetOuter ()
 reset the outer fill around the lattice elements to be VOID More...
 
const std::vector< std::reference_wrapper< const CSGUniverse > > getUniqueUniverses () const
 Get the list of unique universe objects in the lattice. More...
 
bool operator== (const CSGLattice &other) const
 Operator overload for checking if two CSGLattice objects are equal. More...
 
bool operator!= (const CSGLattice &other) const
 Operator overload for checking if two CSGLattice objects are not equal. More...
 
const std::vector< std::pair< TransformationType, std::tuple< Real, Real, Real > > > & getTransformations () const
 Get the list of transformations. More...
 
std::vector< std::pair< std::string, std::tuple< Real, Real, Real > > > getTransformationsAsStrings () const
 Get the transformations of this object with string representations for types. More...
 

Static Public Member Functions

static bool isValidTransformationValue (TransformationType type, const std::tuple< Real, Real, Real > &values)
 Check if the transformation value is valid for the given type. More...
 
static std::string getTransformationTypeString (TransformationType type)
 Get the string representation of the transformation type. More...
 

Protected Member Functions

void setName (const std::string &name)
 
virtual void setUniverses (std::vector< std::vector< std::reference_wrapper< const CSGUniverse >>> universes)=0
 assign the vectors of universes as the lattice elements More...
 
void setUniverseAtIndex (const CSGUniverse &universe, const std::pair< int, int > index)
 replace the element at specified index in the lattice with the provided CSGUniverse. More...
 
virtual bool compareAttributes (const CSGLattice &other) const =0
 helper function to compare the attributes of the lattice type More...
 
void updateOuter (const std::string &outer_name)
 Update the outer of the lattice to be the provided material name. More...
 
void updateOuter (const CSGUniverse &outer_universe)
 Update the outer of the lattice to be the provided universe. More...
 
void addTransformation (TransformationType type, const std::tuple< Real, Real, Real > &values)
 Add a transformation to the list of transformations. More...
 
Point applyReverseTransformsToPoint (Point p) const
 update the value of point p by applying the inverse of the list of transformations to the point More...
 
 FRIEND_TEST (CSGLatticeTest, testSetName)
 Friends for unit testing. More...
 
 FRIEND_TEST (CSGLatticeTest, testUpdateOuter)
 
 FRIEND_TEST (CSGBaseTest, testAddLattice)
 
 FRIEND_TEST (CSGLatticeTest, testCartLatticeEquality)
 
 FRIEND_TEST (CSGSurfaceTest, testHalfspaceWithTransform)
 Friends for unit testing. More...
 
 FRIEND_TEST (CSGSurfaceTest, testHalfspaceWithNullTransform)
 

Protected Attributes

std::string _name
 Name of lattice. More...
 
const std::string _lattice_type
 Type of lattice. More...
 
std::vector< std::vector< std::reference_wrapper< const CSGUniverse > > > _universe_map
 Universes in the arrangement of how they appear in the lattice; dimensions depends on lattice type. More...
 
std::string _outer_type
 An enum for type of outer fill for lattice. More...
 
std::string _outer_material
 name of the outer material More...
 
const CSGUniverse_outer_universe
 outer object if fill is CSGUniverse More...
 
std::vector< std::pair< TransformationType, std::tuple< Real, Real, Real > > > _transformations
 List of transformations applied to this object. More...
 

Friends

class CSGLatticeList
 
class CSGBase
 

Detailed Description

CSGLattice is the abstract class for defining lattices.

Definition at line 34 of file CSGLattice.h.

Constructor & Destructor Documentation

◆ CSGLattice()

CSG::CSGLattice::CSGLattice ( const std::string &  name,
const std::string &  lattice_type,
const std::optional< OuterVariant > &  outer = std::nullopt 
)

Construct a new CSGLattice of specific type.

Parameters
nameunique name of lattice
lattice_typetype of lattice
outeroptional outer universe or material name that fills space around lattice elements. If not provided, outer is assumed to be VOID.

Definition at line 16 of file CSGLattice.C.

19  : _name(name), _lattice_type(lattice_type), _outer_type("VOID"), _outer_universe(nullptr)
20 {
22  // Handle the outer variant if provided
23  if (outer.has_value())
24  {
25  std::visit([this](auto && outer_arg) { updateOuter(outer_arg); }, outer.value());
26  }
27 }
std::string _outer_type
An enum for type of outer fill for lattice.
Definition: CSGLattice.h:228
std::string _name
Name of lattice.
Definition: CSGLattice.h:219
void updateOuter(const std::string &outer_name)
Update the outer of the lattice to be the provided material name.
Definition: CSGLattice.C:137
void checkValidCSGName(const std::string &name)
Check name of CSG component for disallowed characters and symbols.
Definition: CSGUtils.C:36
const CSGUniverse * _outer_universe
outer object if fill is CSGUniverse
Definition: CSGLattice.h:234
const std::string _lattice_type
Type of lattice.
Definition: CSGLattice.h:222

◆ ~CSGLattice()

virtual CSG::CSGLattice::~CSGLattice ( )
virtualdefault

Destructor.

Member Function Documentation

◆ addTransformation()

void CSG::CSGTransformationHelper::addTransformation ( TransformationType  type,
const std::tuple< Real, Real, Real > &  values 
)
protectedinherited

Add a transformation to the list of transformations.

Parameters
typeThe type of transformation
valuesThe values for the transformation

Definition at line 16 of file CSGTransformationHelper.C.

18 {
19  if (!isValidTransformationValue(type, values))
20  mooseError("Invalid transformation values provided for transformation type " +
22  _transformations.emplace_back(type, values);
23 }
static bool isValidTransformationValue(TransformationType type, const std::tuple< Real, Real, Real > &values)
Check if the transformation value is valid for the given type.
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311
static std::string getTransformationTypeString(TransformationType type)
Get the string representation of the transformation type.
std::vector< std::pair< TransformationType, std::tuple< Real, Real, Real > > > _transformations
List of transformations applied to this object.

◆ applyReverseTransformsToPoint()

Point CSG::CSGTransformationHelper::applyReverseTransformsToPoint ( Point  p) const
protectedinherited

update the value of point p by applying the inverse of the list of transformations to the point

Parameters
ppoint to transform
Returns
transformed point

Definition at line 74 of file CSGTransformationHelper.C.

Referenced by CSG::CSGSurface::getHalfspaceFromPoint().

75 {
76  // iterate list of transformations in reverse and apply the inverse operation
77  for (auto it = _transformations.rbegin(); it != _transformations.rend(); ++it)
78  {
79  auto trans_type = it->first;
80  auto val = it->second;
81 
82  if (trans_type == TransformationType::TRANSLATION)
83  {
84  Point offset(std::get<0>(val), std::get<1>(val), std::get<2>(val));
85  p -= offset;
86  }
87  else if (trans_type == TransformationType::SCALE)
88  {
89  Point scale(std::get<0>(val), std::get<1>(val), std::get<2>(val));
90  for (int i = 0; i < 3; ++i)
91  p(i) /= scale(i);
92  }
93  else if (trans_type == TransformationType::ROTATION)
94  {
95  // get the transpose of the original rotation matrix and apply to point p
96  const auto rot_matrix = RealTensorValue::intrinsic_rotation_matrix(
97  std::get<0>(val), std::get<1>(val), std::get<2>(val));
98  const auto rot_transpose = rot_matrix.transpose();
99  p = rot_transpose * p;
100  }
101  else
102  mooseError("Transformation type is not recognized.");
103  }
104  return p;
105 }
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311
void scale(MeshBase &mesh, const Real xs, const Real ys=0., const Real zs=0.)
std::vector< std::pair< TransformationType, std::tuple< Real, Real, Real > > > _transformations
List of transformations applied to this object.
static TensorValue< Real > intrinsic_rotation_matrix(Real phi, Real theta, Real psi)

◆ clone()

virtual std::unique_ptr<CSGLattice> CSG::CSGLattice::clone ( ) const
pure virtual

◆ compareAttributes()

virtual bool CSG::CSGLattice::compareAttributes ( const CSGLattice other) const
protectedpure virtual

helper function to compare the attributes of the lattice type

Implemented in CSG::CSGHexagonalLattice, and CSG::CSGCartesianLattice.

Referenced by operator==().

◆ FRIEND_TEST() [1/6]

CSG::CSGTransformationHelper::FRIEND_TEST ( CSGSurfaceTest  ,
testHalfspaceWithTransform   
)
protectedinherited

Friends for unit testing.

◆ FRIEND_TEST() [2/6]

CSG::CSGTransformationHelper::FRIEND_TEST ( CSGSurfaceTest  ,
testHalfspaceWithNullTransform   
)
protectedinherited

◆ FRIEND_TEST() [3/6]

CSG::CSGLattice::FRIEND_TEST ( CSGLatticeTest  ,
testSetName   
)
protected

Friends for unit testing.

◆ FRIEND_TEST() [4/6]

CSG::CSGLattice::FRIEND_TEST ( CSGLatticeTest  ,
testUpdateOuter   
)
protected

◆ FRIEND_TEST() [5/6]

CSG::CSGLattice::FRIEND_TEST ( CSGBaseTest  ,
testAddLattice   
)
protected

◆ FRIEND_TEST() [6/6]

CSG::CSGLattice::FRIEND_TEST ( CSGLatticeTest  ,
testCartLatticeEquality   
)
protected

◆ getAttributes()

virtual std::unordered_map<std::string, AttributeVariant> CSG::CSGLattice::getAttributes ( ) const
pure virtual

Get attributes that define the lattice (excluding the universe map).

Returns
map of string attribute name to value of that attribute

Implemented in CSG::CSGHexagonalLattice, and CSG::CSGCartesianLattice.

Referenced by CSG::CSGCartesianLattice::compareAttributes(), and CSG::CSGHexagonalLattice::compareAttributes().

◆ getName()

const std::string& CSG::CSGLattice::getName ( ) const
inline

◆ getOuterMaterial()

const std::string & CSG::CSGLattice::getOuterMaterial ( ) const

Get the outer material name if outer fype is CSG_MATERIAL.

Returns
name of the CSG material fill

Definition at line 120 of file CSGLattice.C.

Referenced by operator==().

121 {
122  if (getOuterType() != "CSG_MATERIAL")
123  mooseError("Lattice '" + getName() + "' has " + getOuterType() + " outer, not CSG_MATERIAL.");
124  else
125  return _outer_material;
126 }
std::string _outer_material
name of the outer material
Definition: CSGLattice.h:231
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311
const std::string & getName() const
Get the name of lattice.
Definition: CSGLattice.h:62
const std::string getOuterType() const
Get the type of outer that fills the space around the lattice elements.
Definition: CSGLattice.h:76

◆ getOuterType()

const std::string CSG::CSGLattice::getOuterType ( ) const
inline

Get the type of outer that fills the space around the lattice elements.

Returns
string of outer type: CSG_MATERIAL, UNIVERSE, or VOID

Definition at line 76 of file CSGLattice.h.

Referenced by CSG::CSGBase::addLatticeToList(), getOuterMaterial(), getOuterUniverse(), and operator==().

76 { return _outer_type; }
std::string _outer_type
An enum for type of outer fill for lattice.
Definition: CSGLattice.h:228

◆ getOuterUniverse()

const CSGUniverse & CSG::CSGLattice::getOuterUniverse ( ) const

Get the outer universe if outer type is UNIVERSE.

Returns
Reference to CSGUniverse

Definition at line 111 of file CSGLattice.C.

Referenced by CSG::CSGBase::addLatticeToList(), and operator==().

112 {
113  if (getOuterType() != "UNIVERSE")
114  mooseError("Lattice '" + getName() + "' has " + getOuterType() + " outer, not UNIVERSE.");
115  else
116  return *_outer_universe;
117 }
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311
const std::string & getName() const
Get the name of lattice.
Definition: CSGLattice.h:62
const CSGUniverse * _outer_universe
outer object if fill is CSGUniverse
Definition: CSGLattice.h:234
const std::string getOuterType() const
Get the type of outer that fills the space around the lattice elements.
Definition: CSGLattice.h:76

◆ getTransformations()

const std::vector<std::pair<TransformationType, std::tuple<Real, Real, Real> > >& CSG::CSGTransformationHelper::getTransformations ( ) const
inlineinherited

Get the list of transformations.

Returns
The list of transformations

Definition at line 47 of file CSGTransformationHelper.h.

Referenced by CSG::CSGSurface::getHalfspaceFromPoint(), CSG::CSGUniverse::operator==(), CSG::CSGSurface::operator==(), CSG::CSGCell::operator==(), and operator==().

48  {
49  return _transformations;
50  }
std::vector< std::pair< TransformationType, std::tuple< Real, Real, Real > > > _transformations
List of transformations applied to this object.

◆ getTransformationsAsStrings()

std::vector< std::pair< std::string, std::tuple< Real, Real, Real > > > CSG::CSGTransformationHelper::getTransformationsAsStrings ( ) const
inherited

Get the transformations of this object with string representations for types.

Returns
Vector of transformation pairs with string representations for types

Definition at line 65 of file CSGTransformationHelper.C.

66 {
67  std::vector<std::pair<std::string, std::tuple<Real, Real, Real>>> result;
68  for (const auto & transform_pair : _transformations)
69  result.emplace_back(getTransformationTypeString(transform_pair.first), transform_pair.second);
70  return result;
71 }
static std::string getTransformationTypeString(TransformationType type)
Get the string representation of the transformation type.
std::vector< std::pair< TransformationType, std::tuple< Real, Real, Real > > > _transformations
List of transformations applied to this object.

◆ getTransformationTypeString()

std::string CSG::CSGTransformationHelper::getTransformationTypeString ( TransformationType  type)
staticinherited

Get the string representation of the transformation type.

Parameters
typeThe transformation type
Returns
String name of the transformation type

Definition at line 56 of file CSGTransformationHelper.C.

Referenced by CSG::CSGTransformationHelper::addTransformation(), and CSG::CSGTransformationHelper::getTransformationsAsStrings().

57 {
58  // Set the enum to the value and convert it to string
60  enum_copy = static_cast<int>(type);
61  return std::string(enum_copy);
62 }
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type It sho...
Definition: MooseEnum.h:54
static const MooseEnum transformation_type_enum
MooseEnum for transformation types, matching the TransformationType enum values.

◆ getType()

const std::string& CSG::CSGLattice::getType ( ) const
inline

Get the lattice type.

Returns
std::string type of lattice

Definition at line 69 of file CSGLattice.h.

Referenced by CSG::CSGCartesianLattice::compareAttributes(), CSG::CSGHexagonalLattice::compareAttributes(), operator==(), CSG::CSGCartesianLattice::setUniverses(), and CSG::CSGHexagonalLattice::setUniverses().

69 { return _lattice_type; }
const std::string _lattice_type
Type of lattice.
Definition: CSGLattice.h:222

◆ getUniqueUniverses()

const std::vector< std::reference_wrapper< const CSGUniverse > > CSG::CSGLattice::getUniqueUniverses ( ) const

Get the list of unique universe objects in the lattice.

Returns
list of references to unique CSGUniverse objects

Definition at line 93 of file CSGLattice.C.

94 {
95  std::vector<std::reference_wrapper<const CSGUniverse>> unique_univs;
96  auto all_univs = getUniverses();
97 
98  for (const auto & ulist : all_univs)
99  for (const auto & u : ulist)
100  {
101  auto it = std::find_if(unique_univs.begin(),
102  unique_univs.end(),
103  [&u](const auto & ref) { return &ref.get() == &u.get(); });
104  if (it == unique_univs.end())
105  unique_univs.push_back(u);
106  }
107  return unique_univs;
108 }
std::vector< std::vector< std::reference_wrapper< const CSGUniverse > > > getUniverses() const
Get the arrangement of CSGUniverses in the lattice.
Definition: CSGLattice.h:97

◆ getUniverseAtIndex()

const CSGUniverse & CSG::CSGLattice::getUniverseAtIndex ( const std::pair< int, int index)

Get the universe located at the given index.

Parameters
indexpair of ints that specify the location in lattice
Returns
universe at the specified location

Definition at line 66 of file CSGLattice.C.

67 {
68  if (!isValidIndex(index))
69  mooseError("Index (" + std::to_string(index.first) + ", " + std::to_string(index.second) +
70  ") is not a valid index for lattice " + getName());
71  else
72  return _universe_map[index.first][index.second];
73 }
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311
virtual bool isValidIndex(const std::pair< int, int > index) const =0
Checks if the given index location is a valid index for the lattice.
const std::string & getName() const
Get the name of lattice.
Definition: CSGLattice.h:62
std::vector< std::vector< std::reference_wrapper< const CSGUniverse > > > _universe_map
Universes in the arrangement of how they appear in the lattice; dimensions depends on lattice type...
Definition: CSGLattice.h:225

◆ getUniverseIndices()

const std::vector< std::pair< unsigned int, unsigned int > > CSG::CSGLattice::getUniverseIndices ( const std::string &  univ_name) const

get all locations in lattice where universe of the specified name exists

Parameters
univ_namename of universe
Returns
vector of locations (pairs of ints)

Definition at line 76 of file CSGLattice.C.

77 {
78  if (!hasUniverse(univ_name))
79  mooseError("Universe " + univ_name + " does not exist in lattice " + getName());
80 
81  std::vector<std::pair<unsigned int, unsigned int>> indices;
82  for (auto i : index_range(_universe_map))
83  for (auto j : index_range(_universe_map[i]))
84  {
85  const CSGUniverse & univ = _universe_map[i][j];
86  if (univ.getName() == univ_name)
87  indices.push_back(std::make_pair(i, j));
88  }
89  return indices;
90 }
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311
const std::string & getName() const
Get the name of lattice.
Definition: CSGLattice.h:62
std::vector< std::vector< std::reference_wrapper< const CSGUniverse > > > _universe_map
Universes in the arrangement of how they appear in the lattice; dimensions depends on lattice type...
Definition: CSGLattice.h:225
bool hasUniverse(const std::string &name) const
whether or not the universe of the specified name exists in the lattice
Definition: CSGLattice.C:42
auto index_range(const T &sizable)

◆ getUniverseNameMap()

const std::vector< std::vector< std::string > > CSG::CSGLattice::getUniverseNameMap ( ) const

Get the arrangement of CSGUniverses in the lattice as their names.

Returns
list of list of universe names

Definition at line 52 of file CSGLattice.C.

53 {
54  std::vector<std::vector<std::string>> name_map;
55  for (auto & univ_list : _universe_map)
56  {
57  std::vector<std::string> name_list;
58  for (const CSGUniverse & univ : univ_list)
59  name_list.push_back(univ.getName());
60  name_map.push_back(name_list);
61  }
62  return name_map;
63 }
std::vector< std::vector< std::reference_wrapper< const CSGUniverse > > > _universe_map
Universes in the arrangement of how they appear in the lattice; dimensions depends on lattice type...
Definition: CSGLattice.h:225

◆ getUniverses()

std::vector<std::vector<std::reference_wrapper<const CSGUniverse> > > CSG::CSGLattice::getUniverses ( ) const
inline

Get the arrangement of CSGUniverses in the lattice.

Returns
list of list of universes in their lattice arrangement

Definition at line 97 of file CSGLattice.h.

Referenced by CSG::CSGBase::addLatticeToList(), CSG::CSGBase::createCell(), getUniqueUniverses(), and operator==().

98  {
99  return _universe_map;
100  }
std::vector< std::vector< std::reference_wrapper< const CSGUniverse > > > _universe_map
Universes in the arrangement of how they appear in the lattice; dimensions depends on lattice type...
Definition: CSGLattice.h:225

◆ hasUniverse()

bool CSG::CSGLattice::hasUniverse ( const std::string &  name) const

whether or not the universe of the specified name exists in the lattice

Parameters
nameof universe to search for
Returns
true if universe of that name exists in lattice

Definition at line 42 of file CSGLattice.C.

Referenced by getUniverseIndices().

43 {
44  for (auto list_univ : _universe_map)
45  for (const CSGUniverse & univ : list_univ)
46  if (univ.getName() == name)
47  return true;
48  return false; // no universe with matching name was found
49 }
std::string name(const ElemQuality q)
std::vector< std::vector< std::reference_wrapper< const CSGUniverse > > > _universe_map
Universes in the arrangement of how they appear in the lattice; dimensions depends on lattice type...
Definition: CSGLattice.h:225

◆ isValidIndex()

virtual bool CSG::CSGLattice::isValidIndex ( const std::pair< int, int index) const
pure virtual

Checks if the given index location is a valid index for the lattice.

Parameters
indexlocation
Returns
true if index is valid for the lattice

Implemented in CSG::CSGCartesianLattice, and CSG::CSGHexagonalLattice.

Referenced by getUniverseAtIndex(), and setUniverseAtIndex().

◆ isValidTransformationValue()

bool CSG::CSGTransformationHelper::isValidTransformationValue ( TransformationType  type,
const std::tuple< Real, Real, Real > &  values 
)
staticinherited

Check if the transformation value is valid for the given type.

Parameters
typeThe type of transformation
valuesThe values for the transformation
Returns
True if the values are valid for the type

Definition at line 26 of file CSGTransformationHelper.C.

Referenced by CSG::CSGTransformationHelper::addTransformation().

28 {
29  // Additional validation specific to each transformation type could be added here
30  switch (type)
31  {
33  // All translation values are inherently valid
34  return true;
35 
37  // Rotation uses euler notation; values are angles in degrees (phi, theta, psi)
38  // For consistency with TransformGenerator, there are no restrictions on the angles
39  // phi: rotation around Z-axis
40  // theta: rotation around new X-axis
41  // psi: rotation around new Z-axis
42  return true;
43 
45  // Scaling factors should be non-zero
46  if (std::get<0>(values) == 0.0 || std::get<1>(values) == 0.0 || std::get<2>(values) == 0.0)
47  return false;
48  return true;
49 
50  default:
51  mooseError("Unknown transformation type");
52  }
53 }
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311

◆ isValidUniverseMap()

virtual bool CSG::CSGLattice::isValidUniverseMap ( std::vector< std::vector< std::reference_wrapper< const CSGUniverse >>>  universes) const
pure virtual

check that any provided list of list of CSGUniverses are the correct dimensions for the type of lattice

Parameters
universeslist of list of universes to be used to define the lattice structure
Returns
true if universe dimensions are valid

Implemented in CSG::CSGHexagonalLattice, and CSG::CSGCartesianLattice.

◆ operator!=()

bool CSG::CSGLattice::operator!= ( const CSGLattice other) const

Operator overload for checking if two CSGLattice objects are not equal.

Definition at line 189 of file CSGLattice.C.

190 {
191  return !(*this == other);
192 }

◆ operator==()

bool CSG::CSGLattice::operator== ( const CSGLattice other) const

Operator overload for checking if two CSGLattice objects are equal.

Definition at line 153 of file CSGLattice.C.

154 {
155  if (this->getName() != other.getName())
156  return false;
157  if (this->getType() != other.getType())
158  return false;
159  if (this->getTransformations() != other.getTransformations())
160  return false;
161  if (this->getOuterType() != other.getOuterType())
162  return false;
163  if ((this->getOuterType() == "CSG_MATERIAL") &&
164  (this->getOuterMaterial() != other.getOuterMaterial()))
165  return false;
166  if ((this->getOuterType() == "UNIVERSE") &&
167  (this->getOuterUniverse() != other.getOuterUniverse()))
168  return false;
169  if (!this->compareAttributes(other))
170  return false;
171 
172  const auto & this_univs = this->getUniverses();
173  const auto & other_univs = other.getUniverses();
174  if (this_univs.size() != other_univs.size())
175  return false;
176  for (unsigned int i = 0; i < this_univs.size(); ++i)
177  {
178  if (this_univs[i].size() != other_univs[i].size())
179  return false;
180  for (unsigned int j = 0; j < this_univs[i].size(); j++)
181  if (this_univs[i][j].get() != other_univs[i][j].get())
182  return false;
183  }
184 
185  return true;
186 }
const CSGUniverse & getOuterUniverse() const
Get the outer universe if outer type is UNIVERSE.
Definition: CSGLattice.C:111
const std::string & getType() const
Get the lattice type.
Definition: CSGLattice.h:69
const std::string & getName() const
Get the name of lattice.
Definition: CSGLattice.h:62
const std::string & getOuterMaterial() const
Get the outer material name if outer fype is CSG_MATERIAL.
Definition: CSGLattice.C:120
virtual bool compareAttributes(const CSGLattice &other) const =0
helper function to compare the attributes of the lattice type
std::vector< std::vector< std::reference_wrapper< const CSGUniverse > > > getUniverses() const
Get the arrangement of CSGUniverses in the lattice.
Definition: CSGLattice.h:97
const std::string getOuterType() const
Get the type of outer that fills the space around the lattice elements.
Definition: CSGLattice.h:76
const std::vector< std::pair< TransformationType, std::tuple< Real, Real, Real > > > & getTransformations() const
Get the list of transformations.

◆ resetOuter()

void CSG::CSGLattice::resetOuter ( )

reset the outer fill around the lattice elements to be VOID

Definition at line 145 of file CSGLattice.C.

Referenced by CSG::CSGBase::resetLatticeOuter().

146 {
147  _outer_type = "VOID";
148  _outer_material = "";
149  _outer_universe = nullptr;
150 }
std::string _outer_material
name of the outer material
Definition: CSGLattice.h:231
std::string _outer_type
An enum for type of outer fill for lattice.
Definition: CSGLattice.h:228
const CSGUniverse * _outer_universe
outer object if fill is CSGUniverse
Definition: CSGLattice.h:234

◆ setName()

void CSG::CSGLattice::setName ( const std::string &  name)
inlineprotected

Definition at line 183 of file CSGLattice.h.

183 { _name = name; }
std::string name(const ElemQuality q)
std::string _name
Name of lattice.
Definition: CSGLattice.h:219

◆ setUniverseAtIndex()

void CSG::CSGLattice::setUniverseAtIndex ( const CSGUniverse universe,
const std::pair< int, int index 
)
protected

replace the element at specified index in the lattice with the provided CSGUniverse.

This will check that the _universe_map has been initialized and that the index is valid.

Parameters
universeuniverse to add to the lattice at the location index
indexlocation in lattice replace with provided universe

Definition at line 30 of file CSGLattice.C.

Referenced by CSG::CSGBase::setUniverseAtLatticeIndex().

31 {
32  std::string base_msg = "Cannot set universe at location (" + std::to_string(index.first) + ", " +
33  std::to_string(index.second) + ") for lattice " + getName() + ". ";
34  if (_universe_map.size() == 0)
35  mooseError(base_msg + "Universe map has not been initialized.");
36  if (!isValidIndex(index))
37  mooseError(base_msg + "Not a valid location.");
38  _universe_map[index.first][index.second] = universe;
39 }
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311
virtual bool isValidIndex(const std::pair< int, int > index) const =0
Checks if the given index location is a valid index for the lattice.
const std::string & getName() const
Get the name of lattice.
Definition: CSGLattice.h:62
std::vector< std::vector< std::reference_wrapper< const CSGUniverse > > > _universe_map
Universes in the arrangement of how they appear in the lattice; dimensions depends on lattice type...
Definition: CSGLattice.h:225

◆ setUniverses()

virtual void CSG::CSGLattice::setUniverses ( std::vector< std::vector< std::reference_wrapper< const CSGUniverse >>>  universes)
protectedpure virtual

assign the vectors of universes as the lattice elements

Parameters
universesvector of vectors of universes to be set as lattice elements, ordering depends on derived class

Implemented in CSG::CSGHexagonalLattice, and CSG::CSGCartesianLattice.

Referenced by CSG::CSGBase::setLatticeUniverses().

◆ updateOuter() [1/2]

void CSG::CSGLattice::updateOuter ( const std::string &  outer_name)
protected

Update the outer of the lattice to be the provided material name.

This will change outer type to CSG_MATERIAL even if it was a different type previously.

Parameters
outer_namename of CSG material that will fill space around lattice elements

Definition at line 137 of file CSGLattice.C.

Referenced by CSGLattice(), and CSG::CSGBase::setLatticeOuter().

138 {
139  _outer_type = "CSG_MATERIAL";
140  _outer_material = outer_name;
141  _outer_universe = nullptr;
142 }
std::string _outer_material
name of the outer material
Definition: CSGLattice.h:231
std::string _outer_type
An enum for type of outer fill for lattice.
Definition: CSGLattice.h:228
const CSGUniverse * _outer_universe
outer object if fill is CSGUniverse
Definition: CSGLattice.h:234

◆ updateOuter() [2/2]

void CSG::CSGLattice::updateOuter ( const CSGUniverse outer_universe)
protected

Update the outer of the lattice to be the provided universe.

This will change outer type to UNIVERSE even if it was a different type previously.

Parameters
outer_universepointer to outer universe that will fill space around lattice elements

Definition at line 129 of file CSGLattice.C.

130 {
131  _outer_type = "UNIVERSE";
132  _outer_universe = &outer_universe;
133  _outer_material = "";
134 }
std::string _outer_material
name of the outer material
Definition: CSGLattice.h:231
std::string _outer_type
An enum for type of outer fill for lattice.
Definition: CSGLattice.h:228
const CSGUniverse * _outer_universe
outer object if fill is CSGUniverse
Definition: CSGLattice.h:234

Friends And Related Function Documentation

◆ CSGBase

friend class CSGBase
friend

Definition at line 239 of file CSGLattice.h.

◆ CSGLatticeList

friend class CSGLatticeList
friend

Definition at line 237 of file CSGLattice.h.

Member Data Documentation

◆ _lattice_type

const std::string CSG::CSGLattice::_lattice_type
protected

Type of lattice.

Definition at line 222 of file CSGLattice.h.

Referenced by getType().

◆ _name

std::string CSG::CSGLattice::_name
protected

Name of lattice.

Definition at line 219 of file CSGLattice.h.

Referenced by getName(), and setName().

◆ _outer_material

std::string CSG::CSGLattice::_outer_material
mutableprotected

name of the outer material

Definition at line 231 of file CSGLattice.h.

Referenced by getOuterMaterial(), resetOuter(), and updateOuter().

◆ _outer_type

std::string CSG::CSGLattice::_outer_type
mutableprotected

An enum for type of outer fill for lattice.

Definition at line 228 of file CSGLattice.h.

Referenced by getOuterType(), resetOuter(), and updateOuter().

◆ _outer_universe

const CSGUniverse* CSG::CSGLattice::_outer_universe
protected

outer object if fill is CSGUniverse

Definition at line 234 of file CSGLattice.h.

Referenced by getOuterUniverse(), resetOuter(), and updateOuter().

◆ _transformations

std::vector<std::pair<TransformationType, std::tuple<Real, Real, Real> > > CSG::CSGTransformationHelper::_transformations
protectedinherited

◆ _universe_map

std::vector<std::vector<std::reference_wrapper<const CSGUniverse> > > CSG::CSGLattice::_universe_map
protected

Universes in the arrangement of how they appear in the lattice; dimensions depends on lattice type.

Definition at line 225 of file CSGLattice.h.

Referenced by getUniverseAtIndex(), getUniverseIndices(), getUniverseNameMap(), getUniverses(), hasUniverse(), setUniverseAtIndex(), CSG::CSGCartesianLattice::setUniverses(), and CSG::CSGHexagonalLattice::setUniverses().


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