2.3.3.3.59. NXcg_primitive¶
Status:
base class (contribution), extends NXobject
Description:
Computational geometry description of a set of primitives in Euclidean space. ...
Computational geometry description of a set of primitives in Euclidean space.
Primitives must neither be degenerated nor self-intersect. Individual primitives can differ in their properties (e.g. size, shape, rotation).
Symbols:
The symbols used in the schema to specify e.g. dimensions of arrays.
d: The dimensionality of the embedding space.
c: The cardinality of the set, i.e. the number of members.
- Groups cited:
Structure:
depends_on: (optional) NX_CHAR
Reference to an instance of :ref:`NXcoordinate_system` in which these primitiv ...
Reference to an instance of NXcoordinate_system in which these primitives are defined.
dimensionality: (optional) NX_POSINT {units=NX_UNITLESS}
The dimensionality of the primitive set with value up to d. ...
The dimensionality of the primitive set with value up to d.
Any of these values:
1
|2
|3
cardinality: (optional) NX_POSINT {units=NX_UNITLESS}
The cardinality of the primitive set. Value should be equal to c.
identifier_offset: (optional) NX_INT {units=NX_UNITLESS}
Integer offset whereby the identifier of the first member ...
Integer offset whereby the identifier of the first member of the set differs from zero.
Identifiers can be defined either implicitly or explicitly. For implicit indexing identifiers are defined on the interval \([identifier\_offset, identifier\_offset + c - 1]\).
Therefore, implicit identifier are completely defined by the value of identifier_offset and cardinality. For example if identifier run from -2 to 3 the value for identifier_offset is -2.
For explicit indexing the field identifier has to be used. Fortran-/Matlab- and C-/Python-style indexing have specific implicit identifier conventions where identifier_offset is 1 and 0 respectively.
identifier: (optional) NX_INT (Rank: 1, Dimensions: [c])
Identifier of each member for explicit indexing.
center: (optional) NX_NUMBER (Rank: 2, Dimensions: [c, d]) {units=NX_ANY}
The center of each primitive
is_center_of_mass: (optional) NX_BOOLEAN (Rank: 1, Dimensions: [c])
True if the center is a center of mass.
shape: (optional) NX_NUMBER (Rank: 2, Dimensions: [c, d]) {units=NX_LENGTH}
Shape of each primitive
length: (optional) NX_NUMBER (Rank: 1, Dimensions: [c]) {units=NX_LENGTH}
Length of each primitive ...
Length of each primitive
Often the term is associated with the assumption that one edge is parallel to an axis of the coordinate system.
width: (optional) NX_NUMBER (Rank: 1, Dimensions: [c]) {units=NX_LENGTH}
Width of each primitive ...
Width of each primitive
Often the term is associated with the assumption that one edge is parallel to an axis of the coordinate system.
height: (optional) NX_NUMBER (Rank: 1, Dimensions: [c]) {units=NX_LENGTH}
Height of each primitive ...
Height of each primitive
Often the term is associated with the assumption that one edge is parallel to an axis of the coordinate system.
is_closed: (optional) NX_BOOLEAN (Rank: 1, Dimensions: [c])
True if primitive is closed such that it has properties like area or volume.
volume: (optional) NX_NUMBER (Rank: 1, Dimensions: [c]) {units=NX_ANY}
Volume of each primitive. ...
Volume of each primitive.
Set to NaN if does not apply for primitives for which is_closed is False. Volume is an N-D concept for values of dimensionality larger than 1, Area is an alias for the two-dimensional case.
area: (optional) NX_NUMBER (Rank: 1, Dimensions: [c]) {units=NX_AREA}
Alias for surface_area of each primitive. ...
Alias for surface_area of each primitive.
Set to NaN if does not apply for primitives for which is_closed is False.
orientation: (optional) NX_NUMBER (Rank: 2, Dimensions: [c, d]) {units=NX_DIMENSIONLESS}
Direction unit vector which points along the ...
Direction unit vector which points along the longest principal axis of each primitive.
Use the depends_on attribute to specify in which coordinate system these direction unit vectors are defined.
is_mesh: (optional) NX_BOOLEAN
Do the primitives define a mesh.
is_triangle_mesh: (optional) NX_BOOLEAN
Do the primitives define a triangle mesh or not.
is_surface_mesh: (optional) NX_BOOLEAN
Do the primitives discretize the surface of an object or not.
is_geodesic_mesh: (optional) NX_BOOLEAN
Do the primitives define a geodesic mesh or not. ...
Do the primitives define a geodesic mesh or not.
A geodesic surface mesh is a triangulated surface mesh with metadata which can be used as an approximation to describe the surface of a sphere. Triangulation of spheres are commonly used in Materials Science for quantifying texture of materials, i.e. the relative rotation of crystals to sample directions.
For additional details or an introduction into the topic of geodesic meshes see (from which specifically the section on subdivision schemes is relevant).
Earth scientists have specific demands and different views about what should be included in such a base class, given that nested geodesic meshes are a key component of climate modelling software. For now we propose to use this base class as a container for organizing data related to geodesic meshes.
Specifically an instance of this base class should detail the rule set how e.g. a geodesic (surface) mesh was instantiated as there are many possibilities to do so.
description: (optional) NX_CHAR
Possibility to store details such as when primitives form a (specific) type ...
Possibility to store details such as when primitives form a (specific) type of mesh such as geodesic meshes.
vertex_normal: (optional) NXcg_unit_normal
edge_normal: (optional) NXcg_unit_normal
face_normal: (optional) NXcg_unit_normal
Hypertext Anchors¶
List of hypertext anchors for all groups, fields, attributes, and links defined in this class.