cherab.imas.ggd.UnstructGrid3D¶
-
class cherab.imas.ggd.UnstructGrid3D(vertices: ArrayLike, cells: ArrayLike, name: str =
'Cells')Source¶ Bases:
GGDGridUnstructured 3D grid object.
The grid cells are hexahedra (8-vertex cells). Vertices may be shared with neighbouring cells.
To use Raysect’s KDtree accelerator, each hexahedral cell is tetrahedralized.
- Parameters:
Methods
interpolator(grid_data[, fill_value])Return an UnstructGridFunction3D interpolator instance for the data defined on this grid.
plot_mesh([data, ax])Plot the grid geometry to a matplotlib figure.
subset(indices[, name])Create a subset UnstructGrid3D from this instance.
vector_interpolator(grid_vectors[, fill_vector])Return an
UnstructGridVectorFunction3Dinterpolator instance for the vector data defined on this grid.Attributes
Cell areas as
(num_cell,)array.Coordinate of cell centres as
(num_cell, dimension)array.Array of shape
(M, 2)mapping every grid cell index to tetrahedral IDs.Cell volume as
(num_cell,)array.Mesh cells as
(M, 8)array.Coordinate system.
Grid dimension.
Extent of the mesh.
Grid name.
Number of grid cells.
Array of shape
(5M,)mapping every tetrahedral index to a grid cell ID.Mesh tetrahedra as
(5M, 4)array.Mesh vertex coordinates as
(N, 3)array in the (X, Y, Z) space.- property vertices : ndarray[tuple[Any, ...], dtype[float64]]Source¶
Mesh vertex coordinates as
(N, 3)array in the (X, Y, Z) space.
- property tetrahedra : ndarray[tuple[Any, ...], dtype[int32]]Source¶
Mesh tetrahedra as
(5M, 4)array.
- property tetra_to_cell_map : ndarray[tuple[Any, ...], dtype[int32]]Source¶
Array of shape
(5M,)mapping every tetrahedral index to a grid cell ID.
- property cell_to_tetra_map : ndarray[tuple[Any, ...], dtype[int32]]Source¶
Array of shape
(M, 2)mapping every grid cell index to tetrahedral IDs.The first column is the index of the first tetrahedron forming the cell. The second column is the number of tetrahedra forming the cell.
>>> itet, ntet = mesh.cell_to_tetra_map[icell] >>> tet_cell = mesh.tetrahedra[itet : itet + ntet]
-
subset(indices: Sequence[SupportsIndex] | ndarray[tuple[Any, ...], dtype[integer[Any]]], name: str | None =
None) UnstructGrid3DSource¶ Create a subset UnstructGrid3D from this instance.
-
interpolator(grid_data: ndarray[tuple[Any, ...], dtype[float64]], fill_value: float =
0) UnstructGridFunction3DSource¶ Return an UnstructGridFunction3D interpolator instance for the data defined on this grid.
On the second and subsequent calls, the interpolator is created as an instance of the previously created interpolator sharing the same KDtree structure.
- Parameters:
- Returns:
UnstructGridFunction3D– Interpolator instance.- Raises:
TypeError – If the existing interpolator is not compatible with the provided grid data.
-
vector_interpolator(grid_vectors: ndarray[tuple[Any, ...], dtype[float64]], fill_vector: Vector3D =
Vector3D(0.0, 0.0, 0.0)) UnstructGridVectorFunction3DSource¶ Return an
UnstructGridVectorFunction3Dinterpolator instance for the vector data defined on this grid.On the second and subsequent calls, the interpolator is created as an instance of the previously created interpolator sharing the same KDtree structure.
- Parameters:
- Returns:
UnstructGridVectorFunction3D– Interpolator instance.- Raises:
TypeError – If the existing interpolator is not compatible with the provided grid vectors.
- property cell_area : ndarray[tuple[Any, ...], dtype[float64]]Source¶
Cell areas as
(num_cell,)array.
- property cell_centre : ndarray[tuple[Any, ...], dtype[float64]]Source¶
Coordinate of cell centres as
(num_cell, dimension)array.
- property cell_volume : ndarray[tuple[Any, ...], dtype[float64]]Source¶
Cell volume as
(num_cell,)array.
- property mesh_extent : dict[str, float]Source¶
Extent of the mesh.
A dictionary with xmin, xmax, ymin and ymax, … keys.