Source code for geoh5py.objects.surface
# ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
# Copyright (c) 2025 Mira Geoscience Ltd. '
# '
# This file is part of geoh5py. '
# '
# geoh5py is free software: you can redistribute it and/or modify '
# it under the terms of the GNU Lesser General Public License as published by '
# the Free Software Foundation, either version 3 of the License, or '
# (at your option) any later version. '
# '
# geoh5py is distributed in the hope that it will be useful, '
# but WITHOUT ANY WARRANTY; without even the implied warranty of '
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the '
# GNU Lesser General Public License for more details. '
# '
# You should have received a copy of the GNU Lesser General Public License '
# along with geoh5py. If not, see <https://www.gnu.org/licenses/>. '
# ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
from __future__ import annotations
import uuid
import numpy as np
from .cell_object import CellObject
[docs]
class Surface(CellObject):
"""
Surface object defined by vertices and cells
"""
_TYPE_UID = uuid.UUID(
fields=(0xF26FEBA3, 0xADED, 0x494B, 0xB9, 0xE9, 0xB2BBCBE298E1)
)
_minimum_vertices = 3
[docs]
def validate_cells(self, indices: list | tuple | np.ndarray | None) -> np.ndarray:
"""
Validate or generate cells made up of triplets of vertices making
up triangles.
:param indices: Array of indices, shape(*, 3). If None provided, the
vertices are connected sequentially.
:return: Array of indices defining connecting vertices.
"""
if isinstance(indices, (tuple | list)):
indices = np.array(indices, ndmin=2)
if indices is None:
n_vert = self.vertices.shape[0]
indices = np.c_[
np.arange(0, n_vert - 2), np.arange(1, n_vert - 1), np.arange(2, n_vert)
].astype("uint32")
if not isinstance(indices, np.ndarray):
raise AttributeError(
"Attribute 'cells' must be provided as type numpy.ndarray, list or tuple."
)
if indices.ndim != 2 or indices.shape[-1] != 3:
raise ValueError("Array of 'cells' should be of shape (*, 3).")
if not np.issubdtype(indices.dtype, np.integer):
raise TypeError("Indices array must be of integer type")
return indices.astype(np.int32)