Cloned SEACAS for EXODUS library with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1105 lines
41 KiB

2 years ago
\chapter{Description of Data Objects}
\begin{tabular}{llll}
entity & block & set & map \\
node & & nodeset & nodemap \\
edge & edgeblock & edgeset & edgemap \\
face & faceblock & faceset & facemap \\
element & element block & elementset & elementmap \\
\end{tabular}
The data in \exo{} files can be divided into three primary categories:
initialization data, model data, and results data.
Initialization data includes sizing parameters (number of
nodes, number of elements, etc.), optional quality assurance
information (names of codes that have operated on the data),
and optional informational text.
The model is described by data which are static (do not change
through time). This data includes nodal coordinates, element
connectivity (node lists for each element), element attributes,
and node sets and side sets (used to aid in applying loading
conditions and boundary constraints).
The results are optional and include five types of variables -- nodal,
element, nodeset, sideset, and global -- each of which is stored
through time. Nodal results are output (at each time step) for all the
nodes in the model. An example of a nodal variable is displacement in
the X direction. Element, nodeset, and sideset results are output (at
each time step) for all entities (elements, nodes, sides) in one or
more entity block. For example, stress may be an element
variable. Another use of element variables is to record element status
(a binary flag indicating whether each element is "alive" or "dead")
through time. Global results are output (at each time step) for a
single element or node, or for a single property. Linear momentum of a
structure and the acceleration at a particular point are both examples
of global variables. Although these examples correspond to typical FE
applications, the data format is flexible enough to accommodate a
spectrum of uses.
A few conventions and limitations must be cited:
\begin{itemize}
\item {There are no restrictions on the frequency of results output
except that the time value associated with each successive time step
must increase monotonically.}
\item {To output results at different frequencies (i.e., variable A
at every simulation time step, variable B at every other time step)
multiple \exo{} files must be used.}
\item {There are no limits to the number of each type of results, but
once declared, the number cannot change. }
\item {If the mesh geometry changes in time (i.e., number of nodes
increases, connectivity changes), the new geometry must be output to
a new \exo{} file.}
\end{itemize}
The following sections describe the data objects that can be stored in
an \exo{} file. API functions that read / write the particular objects
are included for reference. API routines for the C binding are in
lower case. Refer to Section 4 on page 21 for a detailed description
of each API function.
\section{Global Parameters}
\api\cfuncref{ex_put_init}, \cfuncref{ex_get_init}
Every \exo{} file is initialized with the following parameters:
\begin{itemize}
\item {Title -- data file title of length}
\param{MAX_LINE_LENGTH}. Refer to discussion below for definition
of \param{MAX_LINE_LENGTH}.
\item {Number of nodes -- the total number of nodes in the model.}
\item {Problem dimensionality -- the number of spatial coordinates
per node (1, 2, or 3).}
\item {Number of elements -- the total number of elements of all
types in the file.}
\item {Number of element blocks -- within the \exo{} data model,
elements are grouped together into blocks. Refer to Section 3.8 on
page 8 for a description of element blocks. }
\item {Number of node sets -- node sets are a convenient method for
referring to groups of nodes. Refer to Section 3.9 on page 11 for a
description of node sets.}
\item {Number of side sets -- side sets are used to identify elements
(and their sides) for specific purposes. Refer to Section 3.11 on
page 12 for a description of side sets.}
\item Database version number -- the version of the data objects
stored in the file. This document describes database version is
\version{}.
\item API version number -- the version of the \exo{} library
functions which stored the data in the file. The API version can
change without changing the database version and vice versa. This
document describes API version \version{}.
\item {I/O word size -- indicates the precision of the floating point
data stored in the file. Currently, four- or eight-byte floating
point numbers are supported. It is not necessary that an application
code be written to handle the same precision as the data stored in
the file. If required, the routines in the \exo{} library perform
automatic conversion between four- and eight-byte numbers.}
\item Length of character strings -- all character data stored in an
\exo{} file is either of length \param{MAX_STR_LENGTH} or
\param{MAX_LINE_LENGTH}. These two constants are defined in the
file \file{exodusII.h}. Current values are 32 and
80, respectively.
\item Length of character lines -- see description above
for length of character strings.
\end{itemize}
\section{Quality Assurance Data}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_qa}, \cfuncref{ex_get_qa}
\end{spacing}
Quality assurance (QA) data is optional information that can be
included to indicate which application codes have operated on the data
in the file. Any number of QA records can be included, with each
record containing four character strings of length
\param{MAX_STR_LENGTH}. The four character strings are the following
(in order):
\begin{description}
\item[Code name] indicates the application code that has operated
on the \exo{} file.
\item[Code QA descriptor] provides a location for a version
identifier of the application code.
\item[Date] the date on which the application code was executed;
should be in the format 20080331.
\item[Time] the 24-hour time at which the application code
was executed; should be in the format hours:minutes:seconds,
such as 16:30:15.
\end{description}
\section{Information Data}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_info}, \cfuncref{ex_get_info}
\end{spacing}
This is for storage of optional supplementary text. Each text record
is of length \param{MAX_LINE_LENGTH}; there is no limit to the
number of text records.
\section{Nodal Coordinates}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_coord}, \cfuncref{ex_get_coord}
\end{spacing}
The nodal coordinates are the floating point spatial coordinates of
all the nodes in the model. The number of nodes and the problem
dimension define the length of this array. The node index cycles
faster than the dimension index, thus the X coordinates for all the
nodes is written before any Y coordinate data are written. Internal
node numbers (beginning with 1) are implied from a nodes's place in
the nodal coordinates record. See Section~\ref{s:nnm} for a discussion
of internal node numbers.
\subsection{Coordinate Names}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_coord_names}, \cfuncref{ex_get_coord_names}
\end{spacing}
The coordinate names are character strings of length
\param{MAX_STR_LENGTH} which name the spatial coordinates. There is
one string for each dimension in the model, thus there are one to
three strings.
\section{Node Number Map}\label{s:nnm}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_node_num_map}, \cfuncref{ex_get_node_num_map}
\end{spacing}
Within the data model, internal node IDs are indices into
the nodal coordinate array and internal element IDs are indices
into the element connectivity array. Thus, internal node and
element numbers (IDs) are contiguous (i.e., 1\ldots{number_of_nodes}
and 1\ldots{number_of_elements}, respectively). Optional
node and element number maps can be stored to relate user-defined
node and element IDs to these internal node and element numbers.
The length of these maps are {number_of_nodes} and {number_of_elements},
respectively. As an example, suppose a database contains exactly
one QUAD element with four nodes. The user desires the element
ID to be 100 and the node IDs to be 10, 20, 30, and 40 as shown
in Figure~\ref{f:UserDefinedNodeElementIds}.
\begin{figure}[htbp]
\begin{center}
\includegraphics[width=5.972in, height=2.486in]{figures/UserDefinedNodeElementIds.png}
\caption{User-defined Node and Element IDs.}\label{f:UserDefinedNodeElementIds}
\end{center}
\end{figure}
The internal data structures representing the above model
would be the following:
\begin{itemize}
\item {nodal coordinate array}{:} {(0.0, 1.0, 1.0,
0.0, 0.0, 0.0, 1.0, 1.0)}
\item {connectivity array}{: (1, 2, 3, 4)}
\item {node number map}{: (10, 20, 30, 40)}
\item {element number map}{: (100)}
\end{itemize}
Internal (contiguously numbered) node and element IDs must be used for
all data structures that contain node or element numbers (IDs),
including node set node lists, side set element lists, and element
connectivity. Additionally, to inquire the value(s) of node or element
results variables, an application code must pass the internal node or
element number for the node or element of interest.
\section{Element Number Map}\label{s:enm}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_elem_num_map}, \cfuncref{ex_get_elem_num_map}
\end{spacing}
{Refer to Section 3.5 for a discussion of the optional element
number map.}
\section{Optimized Element Order Map}\label{s:eom}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_map}, \cfuncref{ex_get_map}
\end{spacing}
The optional element order map defines the element order in which a
solver (e.g., a wavefront solver) should process the elements. For
example, the first entry is the number of the element which should be
processed first by the solver. The length of this map is the total
number of elements in the model.
\section{Element Blocks}
For efficient storage and to minimize I/O, elements are grouped into
element blocks. Within an element block, all elements are of the same
type (basic geometry and number of nodes). This definition does not
preclude multiple element blocks containing the same element type
(i.e., ``QUAD'' elements may be in more than one element block); only
that each element block may contain only one element type.
The internal number of an element numbering is defined implicitly by
the order in which it appears in the file. Elements are numbered
internally (beginning with 1) consecutively across all element
blocks. See Section~\ref{s:enm} for a discussion of internal element
numbering.
\subsection{Element Block Parameters}\label{s:ebp}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_elem_block}, \cfuncref{ex_get_elem_block}, \cfuncref{ex_get_elem_blk_ids}
\end{spacing}
The following parameters are defined for each element block:
\begin{itemize}
\item element block ID -- an arbitrary, unique, positive integer
which identifies the particular element block. This ID is used as a
``handle'' into the database that allows users to specify a group of
elements to the application code without having to know the order in
which element blocks are stored in the file.
\item element type Element type -- a character string of length
\param{MAX_STR_LENGTH} to distinguish element types. All elements
within the element block are of this type. Refer to
Table~\ref{t:element_types} on page~\pageref{t:element_types} for a
list of names that are currently accepted. It should be noted that
the \exo{} library routines do not verify element type names against
a standard list; the interpretation of the element type is left to
the application codes which read or write the data. In general, the
first three characters uniquely identify the element
type. Application codes can append characters to the element type
string (up to the maximum length allowed) to further classify the
element for specific purposes.
\item {Number of elements -- the number of elements in the
element block.}
\item {Nodes per element -- the number of nodes per element
for the element block.}
\item {Number of attributes -- the number of attributes per element
in the element block. See below for a discussion of element
attributes.}
\end{itemize}
\subsection{Element Connectivity}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_elem_conn}, \cfuncref{ex_get_elem_conn}
\end{spacing}
The element connectivity contains the list of nodes (internal node
IDs; see Section~\ref{s:enm} for a discussion of node IDs) which
define each element in the element block. The length of this list is
the product of the number of elements and the number of nodes per
element as specified in the element block parameters. The node index
cycles faster than the element index. Node ordering follows the
conventions illustrated in Figures~\ref{topology:1d}
through~\ref{topology:hex27}. The node ordering conventions follow the element topology
used in \code{PATRAN}~\cite{PATRAN}. Thus, for higher-order elements
than those illustrated, use the ordering prescribed in the
\code{PATRAN} User
Manual~\url{http://web.mscsoftware.com/training_videos/patran/reverb3/index.html#page/Finite%2520Element%2520Modeling/elem_lib_topics.16.1.html#ww33606}. For
elements of type CIRCLE or SPHERE, the topology is one node at the
center of the circle or sphere element.
\begin{figure}
\centering
\subcaptionbox{Circle\label{topology:circle}}
{\includegraphics{topology/circle.png}}
\subcaptionbox{Sphere\label{topology:sphere}}
{\includegraphics{topology/sphere.png}}
\caption{Node Ordering for Circle and Sphere Elements}\label{topology:1d}
\end{figure}
\begin{figure}
\begin{center}
\subcaptionbox{Bar2\label{topology:bar2}}
{\includegraphics[width=2.000in, height=2.000in]{topology/bar2.png}}
\subcaptionbox{Bar3\label{topology:bar3}}
{\includegraphics[width=2.000in, height=2.000in]{topology/bar3.png}}
\caption{Node Ordering for Bar/Truss/Beam Elements}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\subcaptionbox{Tri3\label{topology:tri3}}
{\includegraphics[width=2.000in, height=2.000in]{topology/tri3.png}}
\subcaptionbox{Tri4\label{topology:tri4}}
{\includegraphics[width=2.000in, height=2.000in]{topology/tri4.png}}
\subcaptionbox{Tri6\label{topology:tri6}}
{\includegraphics[width=2.000in, height=2.000in]{topology/tri6.png}}
\subcaptionbox{Tri7\label{topology:tri7}}
{\includegraphics[width=2.000in, height=2.000in]{topology/tri7.png}}
\caption{Node Ordering for Triangular Elements.}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\subcaptionbox{Quad4\label{topology:quad4}}
{\includegraphics[width=2.9in, height=2.9in]{topology/quad4.png}}
\subcaptionbox{Quad5\label{topology:quad5}}
{\includegraphics[width=2.9in, height=2.9in]{topology/quad5.png}}
\subcaptionbox{Quad8\label{topology:quad8}}
{\includegraphics[width=2.9in, height=2.9in]{topology/quad8.png}}
\subcaptionbox{Quad9\label{topology:quad9}}
{\includegraphics[width=2.9in, height=2.9in]{topology/quad9.png}}
\caption{Node Ordering for Quadrilateral Elements.}\label{topology:quad}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\subcaptionbox{Tet4\label{topology:tet04}}
{\includegraphics[width=2.9in, height=2.9in]{topology/tet04.png}}
\subcaptionbox{Tet5\label{topology:tet05}}
{\includegraphics[width=2.9in, height=2.9in]{topology/tet05.png}}
\subcaptionbox{Tet10\label{topology:tet10}}
{\includegraphics[width=2.9in, height=2.9in]{topology/tet10.png}}
\subcaptionbox{Tet11\label{topology:tet11}}
{\includegraphics[width=2.9in, height=2.9in]{topology/tet11.png}}
\caption{Node Ordering for Tetrahedral Elements.}\label{topology:tet}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\includegraphics[width=5.000in, height=5.000in]{topology/tet14.png}
\caption{Node Ordering for Tetrahedral Tet14 Element.}\label{topology:tet14}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\includegraphics[width=5.000in, height=5.000in]{topology/tet15.png}
\caption{Node Ordering for Tetrahedral Tet15 Element.}\label{topology:tet15}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\includegraphics[width=6.000in, height=2.1in]{topology/pyramid.png}
\caption{Node Ordering for Pyramid Elements (pyramid5, pyramid13, pyramid14).}\label{topology:pyramid}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\subcaptionbox{Wedge6\label{topology:wedge06}}
{\includegraphics[width=1.9in, height=1.9in]{topology/wedge06.png}}
\subcaptionbox{Wedge15\label{topology:wedge15}}
{\includegraphics[width=1.9in, height=1.9in]{topology/wedge15.png}}
\subcaptionbox{Wedge16\label{topology:wedge16}}
{\includegraphics[width=1.9in, height=1.9in]{topology/wedge16.png}}
\caption{Node Ordering for Wedge Elements.}\label{topology:wedge}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\includegraphics[width=6.000in, height=6.000in]{topology/wedge20.png}
\caption{Node Ordering for Wedge Elements (Wedge20).}\label{topology:wedge20}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\includegraphics[width=6.000in, height=6.000in]{topology/wedge21.png}
\caption{Node Ordering for Wedge Elements (Wedge21).}\label{topology:wedge21}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\subcaptionbox{Hex8\label{topology:hex8}}
{\includegraphics[width=1.9in, height=1.9in]{topology/hex08.png}}
\subcaptionbox{Hex9\label{topology:hex9}}
{\includegraphics[width=1.9in, height=1.9in]{topology/hex09.png}}
\subcaptionbox{Hex20\label{topology:hex20}}
{\includegraphics[width=1.9in, height=1.9in]{topology/hex20.png}}
\caption{Node Ordering for Hexahedral Elements.}\label{topology:hex}
\end{center}
\end{figure}
\begin{figure}
\begin{center}
\includegraphics[width=6.000in, height=6.000in]{topology/hex27.png}
\caption{Node Ordering for Hexahedral Elements (Hex27).}\label{topology:hex27}
\end{center}
\end{figure}
\subsection{Element Attributes}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_elem_attr}, \cfuncref{ex_get_elem_attr}
\end{spacing}
{Element attributes are optional floating point numbers that can be
assigned to each element. Every element in an element block must have
the same number of attributes (as specified in the element block
parameters) but the attributes may vary among elements within the
block. The length of the attributes array is thus the product of the
number of attributes per element and the number of elements in the
element block. Table~\ref{t:element_types} lists the standard
attributes for the given element types. }
\begin{table}[htbp]
\begin{center}
\begin{tabular}{|l|l|} \hline
Element Type & Attributes \\ \hline
CIRCLE & R \\ \hline
SPHERE & R \\ \hline
TRUSS & A \\ \hline
BEAM & 2D: A, I, J \\
& 3D: A, $I_1$, $I_2$, J, $V_1$, $V_2$, $V_3$ \\ \hline
TRIANGLE & \\ \hline
QUAD & \\ \hline
SHELL & T \\ \hline
TETRA & \\ \hline
PYRAMID & \\ \hline
WEDGE & \\ \hline
HEX & \\ \hline
\end{tabular}
\caption{Standard Element Types and Attributes}\label{t:element_types}
\end{center}
\end{table}
\section{Node Sets}
Node sets provide a means to reference a group of nodes with a single
ID. Node sets may be used to specify load or boundary
conditions, or to identify nodes for a special
output request. A particular node may appear in any number of node
sets, but may be in a single node set only once. (This restriction is
not checked by \exo{} routines.) Node sets may be accessed
individually (using node set parameters, node set node list, and node
set distribution factors) or in a concatenated format (described in
Section 3.10 on page 11). The node sets data are stored identically in
the data file regardless of which method (individual or concatenated)
was used to output them.
\subsection{Node Set Parameters}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_node_set_param}, \cfuncref{ex_get_node_set_param}, \cfuncref{ex_get_node_set_ids}
\api \cfuncref{ex_put_set_param}, \cfuncref{ex_get_set_param}, \cfuncref{ex_get_set_ids}
\end{spacing}
{The following parameters define each node set:}
\begin{itemize}
\item {node set ID -- a unique positive integer that identifies the
node set.}
\item {Number of nodes -- the number of nodes in the node
set.}
\item {Number of node set distribution factors -- this should be zero
if there are no distribution factors for the node set. If there are
any distribution factors, this number must equal the number of nodes
in the node set since the factors are assigned at each node. Refer to
the discussion of distribution factors below.}
\end{itemize}
\subsection{Node Set Node List}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_node_set}, \cfuncref{ex_get_node_set}
\end{spacing}
{This is an integer list of all the nodes in the node set. Internal
node IDs (see Section~\ref{s:enm}) must be used in this list.}
\subsection{Node Set Distribution Factors}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_node_set_dist_fact}, \cfuncref{ex_get_node_set_dist_fact}
\end{spacing}
{This is an optional list of floating point factors associated with
the nodes in a node set. These data may be used as multipliers on
applied loads. If distribution factors are stored, each entry in this
list is associated with the corresponding entry in the node set node
list.}
\section{Concatenated Node Sets}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_concat_node_sets}, \cfuncref{ex_get_concat_node_sets}
\end{spacing}
Concatenated node sets provide a means of writing/reading all node
sets with one function call. This is more efficient because it avoids
some I/O overhead, particularly when considering the intricacies of
the \code{NetCDF} library. (Refer to Appendix A for a discussion of
efficiency concerns.) This is accomplished with the following lists:
\begin{itemize}
\item Node sets IDs -- list (of length number of node sets)
of unique integer node set ID's. The \textit{{i}}\th{} entry in
this list specifies the ID of the \textit{{i}}\th{} node set.
\item Node sets node counts -- list (of length number of
node sets) of counts of nodes for each node set. Thus, the \textit{{i}}\th{}
entry in this list specifies the number of nodes in the \textit{{i}}\th{}
node set.
\item Node sets distribution factors counts -- list (of
length number of node sets) of counts of distribution factors
for each node set. The \textit{{i}}\th{} entry in this list specifies
the number of distribution factors in the \textit{{i}}\th{} node
set.
\item Node sets node pointers -- list (of length number
of node sets) of indices which are pointers into the node sets
node list locating the first node of each node set. The \textit{{i}}\th{}
entry in this list is an index in the node sets node list where
the first node of the \textit{{i}}\th{} node set can be located.
\item Node sets distribution factors pointers -- list (of
length number of node sets) of indices which are pointers into
the node sets distribution factors list locating the first factor
of each node set. The \textit{{i}}\th{} entry in this list is an
index in the node sets distribution factors list where the first
factor of the \textit{{i}}\th{} node set can be located.
\item Node sets node list -- concatenated integer list of the nodes
in all the node sets. Internal node IDs (see Section~\ref{s:enm})
must be used in this list. The node sets node pointers and node sets
node counts are used to find the first node and the number of nodes
in a particular node set.
\item Node sets distribution factors list -- concatenated
list of the (floating point) distribution factors in all the
node sets. The node sets distribution factors pointers and node
sets distribution factors counts are used to find the first factor
and the number of factors in a particular node set.
\end{itemize}
To clarify the use of these lists, refer to the coding examples
in Section 4.2.25 and Section 4.2.26.
\section{Side Sets}
Side sets provide a second means of applying load and boundary
conditions to a model. Unlike node sets, side sets are related to
specified sides of elements rather than simply a list of nodes. For
example, a pressure load must be associated with an element edge (in
2-d) or face (in 3-d) in order to apply it properly. Each side in a
side set is defined by an element number and a local edge (for 2-d
elements) or face (for 3-d elements) number. The local number of the
edge or face of interest must conform to the conventions as
illustrated in Figure~\ref{f:SideSetNumbering}.
\begin{figure}[htbp]
\begin{center}
\includegraphics[width=6.250in, height=8.000in]{figures/SideSetNumbering.png}
\caption{Side Set Side Numbering.}\label{f:SideSetNumbering}
\end{center}
\end{figure}
In this figure, side set side numbers are enclosed in boxes; only the
essential node numbers to describe the element topology are shown. A
side set may contain sides of differing types of elements that are
contained in different element blocks. For instance, a single side
set may contain faces of WEDGE elements, HEX elements, and TETRA
elements.
\subsection{Side Set Parameters}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_side_set_param}, \cfuncref{ex_get_side_set_param}, \cfuncref{ex_get_side_set_ids}
\end{spacing}
{The following parameters define each side set:}
\begin{itemize}
\item {side set ID -- a unique positive integer that identifies the
side set.}
\item {Number of sides -- the number of sides in the side
set.}
\item {Number of side set distribution factors -- this should be zero
if there are no distribution factors for the side set. If there are
any distribution factors, they are assigned at the nodes on the sides
of the side set. Refer to the discussion of distribution factors
below.}
\end{itemize}
\subsection{Side Set Element List}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_side_set}, \cfuncref{ex_get_side_set}
\end{spacing}
{This is an integer list of all the elements in the side set.
Internal element IDs (see Section~\ref{s:enm}) must be used
in this list.}
\subsection{Side Set Side List}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_side_set}, \cfuncref{ex_get_side_set}
\end{spacing}
{This is an integer list of all the sides in the side set.
This list contains the local edge (for 2-d elements) or face
(for 3-d elements) numbers following the conventions specified
in Figure 5.}
\subsection{Side Set Node List}
\begin{spacing}{1.5}
\api \cfuncref{ex_get_side_set_node_list}
\end{spacing}
It is important to note that the nodes on a side set are
not explicitly stored in the data file, but can be extracted
from the element numbers in the side set element list, local
side numbers in the side set side list, and the element connectivity
array. The node IDs that are output are internal node numbers
(see Section~\ref{s:nnm}). They are extracted according to
the following conventions:
\begin{enumerate}
\item {All nodes for the first side (defined by the first element
in the side set element list and the first side in the side set side
list) are output before the nodes for the second side. There is no
attempt to consolidate nodes; if a node is attached to four different
faces, then the same node number will be output four times -- once
each time the node is encountered when progressing along the side
list.}
\item {The nodes for a single face (or edge) are ordered to assist
an application code in determining an ``outward'' direction. Thus, the
node list for a face of a 3-d element proceeds around the face so that
the outward normal follows the right-hand rule. The node list for an
edge of a 2-d element proceeds such that if the right hand is placed
in the plane of the element palm down, thumb extended with the index
(and other fingers) pointing from one node to the next in the list,
the thumb points to the inside of the element. This node ordering is
detailed in Table~\ref{t:sset_node_ordering} on
page~\pageref{t:sset_node_ordering}}
\item {The nodes required for a first-order element are output
first, followed by the nodes of a higher ordered
element. Table~\ref{t:sset_node_ordering} lists the nodes for
first-order elements. Refer to the node orderings shown in
Figures~\ref{topology:1d} to ~\ref{topology:hex27} for the additional
nodes on higher-order elements. If a face has a mid-face node, it is
listed last following all mid-edge nodes. For example, the node
ordering for side~1 of the \code{hex27} element is {1,2,6,5,9,14,17,13,26}}
\end{enumerate}
\begin{table}
\begin{center}
% use packages: array
\begin{tabular}{l|c|lll}
\hline \textbf{Element Type} & \textbf{Side \#}& \textbf{Node Order} \\ \hline
QUAD & 1 & 1, 2, & 5 \\
(2D) & 2 & 2, 3, & 6 \\
& 3 & 3, 4, & 7 \\
& 4 & 4, 1, & 8 \\ \hline
SHELL & 1 & 1, 2, 3, 4, & 5, 6, 7, 8, & 9 \\
& 2 & 1, 4, 3, 2, & 8, 7, 6, 5, & 9 \\
(Edges)& 3 & 1, 2, & 5 \\
& 4 & 2, 3, & 6 \\
& 5 & 3, 4, & 7 \\
& 6 & 4, 1, & 8 \\ \hline
TRIANGLE&1 & 1, 2, & 4 \\
(2D) & 2 & 2, 3, & 5 \\
& 3 & 3, 1, & 6 \\ \hline
TRIANGLE& 1 & 1, 2, 3, & 4, 5, 6 \\
(Shell)& 2 & 1, 3, 2, & 6, 5, 4 \\
& 3 & 1, 2, & 4 \\
& 4 & 2, 3, & 5 \\
& 5 & 3, 1, & 6 \\ \hline
TETRA & 1 & 1, 2, 4, & 5, 9, 8 \\
& 2 & 2, 3, 4, & 6, 10, 9 \\
& 3 & 1, 4, 3, & 8, 10, 7 \\
& 4 & 1, 3, 2, & 7, 6, 5 \\ \hline
WEDGE & 1 & 1, 2, 5, 4, & 7, 11, 13, 10 \\
& 2 & 2, 3, 6, 5, & 8, 12, 14, 11 \\
& 3 & 1, 4, 6, 3, & 10, 15, 12, 9 \\
& 4 & 1, 3, 2, & 9, 8, 7 \\
& 5 & 4, 5, 6, & 13, 14, 15 \\ \hline
HEX & 1 & 1, 2, 6, 5, & 9, 14, 17, 13, & 26 \\
& 2 & 2, 3, 7, 6, & 10, 15, 18, 14, & 25 \\
& 3 & 3, 4, 8, 7, & 11, 16, 19, 15, & 27 \\
& 4 & 1, 5, 8, 4, & 13, 20, 16, 12, & 24 \\
& 5 & 1, 4, 3, 2, & 12, 11, 10, 9, & 22 \\
& 6 & 5, 6, 7, 8, & 17, 18, 19, 20, & 23 \\ \hline
PYRAMID&1 & 1, 2, 5, & 6, 11, 10 \\
& 2 & 2, 3, 5, & 7, 12, 11 \\
& 3 & 3, 4, 5, & 8, 13, 12 \\
& 4 & 4, 1, 5, & 9, 10, 13 \\
& 5 & 1, 4, 3, 2, & 9, 8, 7, 6
\end{tabular}
\caption{Sideset Node Ordering}\label{t:sset_node_ordering}
\end{center}
\end{table}
\subsection{Side Set Node Count List}
\begin{spacing}{1.5}
\api \cfuncref{ex_get_side_set_node_list}
\end{spacing}
The length of the side set node count list is the length of the side
set element list. For each entry in the side set element list, there
is an entry in the side set side list, designating a local side
number. The corresponding entry in the side set node count list is the
number of nodes which define the particular side. In conjunction with
the side set node list, this node count array provides an unambiguous
nodal description of the side set.
\subsection{Side Set Distribution Factors}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_side_set_dist_fact}, \cfuncref{ex_get_side_set_dist_fact}
\end{spacing}
This is an optional list of floating point factors associated with the
nodes on a side set. These data may be used for uneven application of
load or boundary conditions. Because distribution factors are assigned
at the nodes, application codes that utilize these factors must read
the side set node list. The distribution factors must be
stored/accessed in the same order as the nodes in the side set node
list; thus, the ordering conventions described above apply.
\section{Concatenated Side Sets}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_concat_side_sets}, \cfuncref{ex_get_concat_side_sets}
\end{spacing}
Concatenated side sets provide a means of writing / reading all side
sets with one function call. This is more efficient because it avoids
some I/O overhead, particularly when considering the intricacies of
the \code{NetCDF} library. This is accomplished with the following
lists:
\begin{itemize}
\item {Side sets IDs -- list (of length number of side sets) of
unique positive integer side set ID's. The} \textit{{i}}{th entry in
this list specifies the ID of the} \textit{{i}}{th side set.}
\item {Side sets side counts -- list (of length number of side sets)
of counts of sides for each side set. Thus, the} \textit{{i}}{th
entry in this list specifies the number of sides in the}
\textit{{i}}{th node set. This also defines the number of elements in
each side set.}
\item {Side sets distribution factors counts -- list (of length
number of side sets) of counts of distribution factors for each side
set. The} \textit{{i}}{th entry in this list specifies the number of
distribution factors in the} \textit{{i}}{th side set.}
\item {Side sets side pointers -- list (of length number of side
sets) of indices which are pointers into the side sets element list
(and side list) locating the first element (or side) of each side
set. The} \textit{{i}}{th entry in this list is an index in the side
sets element list (and side list) where the first element (or side)
of the} \textit{{i}}{th side set can be located.}
\item {Side sets distribution factors pointers -- list (of length
number of side sets) of indices which are pointers into the side sets
distribution factors list locating the first factor of each side
set. The} \textit{{i}}{th entry in this list is an index in the side
sets distribution factors list where the first factor of the}
\textit{{i}}{th side set can be located.}
\item {Side sets element list -- concatenated integer list of the
elements in all the side sets.} {Internal element IDs (see
Section~\ref{s:enm}) must be used in this list.} {The side sets side
pointers and side sets side counts are used to find the first element
and the number of elements in a particular side set.}
\item {Side sets side list -- concatenated integer list of the sides
in all the side sets. The side sets side pointers and side sets side
counts are used to find the first side and the number of sides in a
particular side set.}
\item {Side sets distribution factors list -- concatenated list of
the (floating point) distribution factors in all the side sets. The
side sets distribution factors pointers and side sets distribution
factors counts are used to find the first factor and the number of
factors in a particular side set.}
\end{itemize}
\subsection{Object Properties}
Certain \exo{} objects (currently element blocks, node
sets, and side sets) can be given integer properties, providing
the following capabilities:
\begin{enumerate}
\item assign a specific integer value to a named property of
an object.
\item tag objects as members of a group. For example element
blocks 1 and 3 and side sets 1 and 2 could be put in a group
named ``TOP.''
\end{enumerate}
This functionality is illustrated in Table~\ref{t:property} which
contains the property values of a sample
\exo{} file with three element blocks, one node set, and two
side sets. Note that an application code can define properties
to be valid for only specified object types. In this example,
``STEEL'' and ``COPPER'' are valid for all element blocks but are
not defined for node sets and side sets.
\begin{table}
\begin{center}
\begin{tabular}{l|cccccc} \hline
Name & EB 1 & EB 2 & EB 3 & NS 1 & SS 1 & SS 2 \\ \hline
ID & 1 & 0 & 1 & 0 & 1 & 1 \\
TOP & 1 & 1 & 0 & 1 & 1 & 0 \\
LEFT & 0 & 0 & 1 & NULL & NULL & NULL \\
STEEL & 0 & 1 & 1 & NULL & NULL & NULL \\
COPPER & 1 & 1 & 0 & NULL & NULL & NULL \\
\end{tabular}
\caption{Example Property Table.}\label{t:property}
\end{center}
\end{table}
{Interpretation of the integer values of the properties is left to the
application codes, but in general, a nonzero positive value means the
object has the named property (or is in the named group); a zero means
the object does not have the named property (or is not in the named
group). Thus, element block 1 has an ID of 10 (1 is a counter internal
to the data base; an application code accesses the element block using
the ID), node set 1 has an ID of 100, etc. The group ``TOP'' includes
element block 1, element block 3, and side sets 1 and 2.}
\subsection{Property Values}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_prop}, \cfuncref{ex_get_prop}, \cfuncref{ex_put_prop_array}, \cfuncref{ex_get_prop_array}
\end{spacing}
Valid values for the properties are positive integers and
zero. Property values are stored in arrays in the data file but can be
written / read individually given an object type (i.e., element block,
node set, or side set), object ID, and property name or as an array
given an object type and property name. If accessed as an array, the
order of the values in the array must correspond to the order in which
the element blocks, node sets, or side sets were introduced into the
file. For instance, if the parameters for element block with ID 20
were written to a file, and then parameters for element block with ID
10, followed by the parameters for element block with ID 30, the
first, second, and third elements in the property array would
correspond to element block 20, element block 10, and element block
30, respectively. This order can be determined with a call to
\cfuncref{ex_get_elem_blk_ids} which returns an array of element
block IDs in the order that the corresponding element blocks were
introduced to the data file.
\section{Results Parameters}
\api\cfuncref{ex_put_variable_param}, \cfuncref{ex_get_variable_param}
The number of each type of results variables (element, nodal,
and global) is specified only once, and cannot change through
time.
\subsection{Results Names}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_variable_names}, \cfuncref{ex_get_variable_names}
\end{spacing}
Associated with each results variable is a unique name of
length \param{MAX_STR_LENGTH}.
\section{Results Data}
An integer output time step number (beginning with 1) is used as an
index into the results variables written to or read from an \exo{}
file. It is a counter of the number of ``data planes'' that have been
written to the file. The maximum time step number (i.e., the number of
time steps that have been written) is available via a call to the
database inquire function ( See Section~\ref{s:inquire}). For each
output time step, the following information is stored.
\subsection{Time Values}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_time}, \cfuncref{ex_get_time}, \cfuncref{ex_get_all_times}
\end{spacing}
A floating point value must be stored for each time step to identify
the ``data plane.'' Typically, this is the analysis time but can be
any floating point variable that distinguishes the time steps. For
instance, for a modal analysis, the natural frequency for each mode
may be stored as a ``time value'' to discriminate the different sets
of eigen vectors. The only restriction on the time values is that they
must monotonically increase.
\subsection{Global Results}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_glob_vars}, \cfuncref{ex_get_glob_vars}, \cfuncref{ex_get_glob_var_time}
\end{spacing}
This object contains the floating point global data for the time
step. The length of the array is the number of global variables, as
specified in the results parameters.
\subsection{Nodal Results}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_nodal_var}, \cfuncref{ex_get_nodal_var}, \cfuncref{ex_get_nodal_var_time}
\end{spacing}
This object contains the floating point nodal data for the
time step. The size of the array is the number of nodes, as specified
in the global parameters, times the number of nodal variables.
\subsection{Element Results}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_elem_var}, \cfuncref{ex_get_elem_var}, \cfuncref{ex_get_elem_var_time}
\end{spacing}
Element variables are output for a given element block and a given
element variable. Thus, at each time step, up to \textit{{m}} element
variable objects (where \textit{{m}} is the product of the number of
element blocks and the number of element variables) may be
stored. However, since not all element variables must be output for
all element blocks (see the next section), \textit{{m}} is the
\textit{{maximum}} number of element variable objects. The actual
number of objects stored is the number of unique combinations of
element variable index and element block ID passed to
\cfuncref{ex_put_elem_var} or the number of non-zero entries in the
element variable truth table (if it is used). The length of each
object is the number of elements in the given element block.
\section{Element Variable Truth Table}
\begin{spacing}{1.5}
\api \cfuncref{ex_put_elem_var_tab}, \cfuncref{ex_get_elem_var_tab}
\end{spacing}
Because some element variables are not applicable (and thus not
computed by a simulation code) for all element types, the element
variable truth table is an optional mechanism for specifying whether a
particular element result is output for the elements in a particular
element block. For example, hydrostatic stress may be an output result
for the elements in element block 3, but not those in element block 6.
It is helpful to describe the element variable truth table as a
two-dimensional array, as shown in Table~\ref{t:truth}, each row of
the array is associated with an element variable; each column of the
array is associated with an element block. If a datum in the truth
table is zero $(\textrm{table}(i,j)=0)$, then no results are output
for the {i}\th{} element variable for the {j}\th{} element block. A
nonzero entry indicates that the appropriate result will be output. In
this example, element variable 1 will be stored for all element
blocks; element variable 2 will be stored for element blocks 1 and 4;
and element variable 3 will be stored for element blocks 3 and 4. The
table is stored such that the variable index cycles faster than the
block index.
\begin{table}
\begin{center}
\begin{tabular}{|l|c|c|c|c|}\hline
& Elem Block 1 & Elem Block 2 & Elem Block 3 & Elem Block 4\\ \hline\hline
Elem Var 1 & 1 & 1 & 1 & 1 \\ \hline
Elem Var 2 & 1 & 0 & 0 & 1 \\ \hline
\end{tabular}
\caption{Element Variable Truth Table}\label{t:truth}
\end{center}
\end{table}