-
Notifications
You must be signed in to change notification settings - Fork 4
Create Geometry Input Files
The geometry in OpenMOC is described using constructive solid geometry (CSG), also sometimes referred to as combinatorial geometry. CSG allows a user to create complex objects using Boolean operators on a set of simpler surfaces. In the geometry model, each unique closed volume in defined by its bounding surfaces. In OpenMC, most quadratic surfaces can be modeled and used as bounding surfaces.
Every geometry.xml must have an XML declaration at the beginning of the file and a root element named geometry. Within the root element the user can define any number of cells, surfaces, and lattices. Let us look at the following example:
<?xml version="1.0">
<geometry>
<!-- This is a comment -->
<surface>
<id>1</id>
<type>circle</type>
<coeffs>0.0 0.0 5.0</coeffs>
<surface>
<cell>
<id>1</id>
<universe>0</universe>
<material>1</material>
<surfaces>-1</surfaces>
</cell>
</geometry>
At the beginning of this file is a comment, denoted by a tag starting with <!--
and ending with -->
. Comments, as well as any other type of input, may span multiple lines. One convenient feature of the XML input format is that sub-elements of the cell and surface elements can also be equivalently expressed of attributes of the original element, e.g. the geometry file above could be written as:
<?xml version="1.0">
<geometry>
<!-- This is a comment -->
<surface id="1" type="sphere" coeffs="0.0 0.0 0.0 5.0" boundary="vacuum" />
<cell id="1" universe="0" material="1" surfaces="-1" />
</geometry>
###Surfaces
Each surface element can have the following attributes or sub-elements:
-
id: A unique integer that can be used to identify the surface. Note: all ids must be less than 10,000.
-
type: The type of the surfaces. This can be x-plane, y-plane, plane, or circle.
-
coeffs: The corresponding coefficients for the given type of surface. See below for a list of the coefficients you must specify for a given surface
-
boundary: The boundary condition for the surface. This can be reflective or vacuum, or this attribute can be left empty if no boundary conditions are to be specified for the surface (default is none).
The following quadratic surfaces can be modeled:
-
x-plane: A plane perpendicular to the x-axis, i.e. a surface of the form x - x0 = 0 . The coefficients specified are “x0”.
-
y-plane: A plane perpendicular to the y-axis, i.e. a surface of the form y - y0 = 0. The coefficients specified are “y0”.
-
plane: An arbitrary plane of the form Ax + By = C. The coefficients specified are “A B C”.
-
circle: A circle is a quadratic surface of the form (x - x0)^2 + (y - y0)^2 = R^2. The coefficients specified are “x0 y0 R”.
###Cells Each cell element can have the following attributes or sub-elements:
-
id: A unique integer that can be used to identify the surface. Note: all ids must be less than 10,000.
-
universe: The id of the universe that this cell is contained in. Note: Your uppermost level universe must have "id=0".
-
fill: The id of the universe that fills this cell. Note: if a fill is specified, no material should be given.
-
material: The id of the material that this cell contains. Note: if a material is specified, no fill should be given.
-
surfaces: A list of the ids for surfaces that bound this cell, e.g. if the cell is on the negative side of surface 3 and the positive side of surface 5, the bounding surfaces would be given as “-3 5”.
###Lattices
The lattice can be used to represent repeating structures (e.g. fuel pins in an assembly) or other geometry which naturally fits into a two-dimensional structured mesh. Each cell within the lattice is filled with a specified universe. A lattice accepts the following attributes or sub-elements:
-
id: A unique integer that can be used to identify the lattice. Since lattices are represented as a type of universe within OpenMOC, this id cannot be the same as an id used for a universe containing a cell. Note: all ids must be less than 10,000.
-
dimension: Two integers representing the number of lattice cells in the x- and y- directions, respectively.
-
width: The width of the lattice cell in the x- and y- directions.
-
universes: A list of the universe numbers that fill each cell of the lattice.
##Rules Surfaces, Cells, Universes, Lattices no id above 10,000