サーフェスメッシュをボクセル化する

サーフェスメッシュをボクセル化する#

閉じたサーフェスまたはボリュームメッシュのボクセルモデル(レゴのように)を作成します.

この例はまた,境界 pyvista.PolyData 表面からの陰的距離を計算する方法を示す.

from __future__ import annotations

import numpy as np

import pyvista as pv

from pyvista import examples

# Load a surface to voxelize
surface = examples.download_foot_bones()
surface
PolyDataInformation
N Cells4204
N Points2154
N Strips0
X Bounds-5.633e+00, 5.633e+00
Y Bounds-1.860e+00, 1.860e+00
Z Bounds-2.125e+00, 2.126e+00
N Arrays0


cpos = [
    (7.656346967151718, -9.802071079151158, -11.021236183314311),
    (0.2224512272564101, -0.4594554282112895, 0.5549738359311297),
    (-0.6279216753504941, -0.7513057097368635, 0.20311105371647392),
]

surface.plot(cpos=cpos, opacity=0.75)
voxelize

境界面のボクセルモデルを作成する

voxels = surface.voxelize()

p = pv.Plotter()
p.add_mesh(voxels, color=True, show_edges=True, opacity=0.5)
p.add_mesh(surface, color='lightblue', opacity=0.5)
p.show(cpos=cpos)
voxelize

モデリング用のグリッドを作成する場合に備えて,新しいボクセルモデルにスカラーフィールドを追加することもできます.ここでは,ボーン密度のスカラーフィールドを追加します.

voxels['density'] = np.full(voxels.n_cells, 3.65)  # g/cc
voxels
HeaderData Arrays
UnstructuredGridInformation
N Cells10478
N Points15818
X Bounds-5.633e+00, 5.633e+00
Y Bounds-1.860e+00, 1.860e+00
Z Bounds-2.125e+00, 2.126e+00
N Arrays1
NameFieldTypeN CompMinMax
densityCellsfloat6413.650e+003.650e+00


voxels.plot(scalars='density', cpos=cpos)
voxelize

一定のスカラーフィールドは退屈なので,バウンディングサーフェスからの距離によって変化するスカラーフィールドを追加して少しおしゃれにしましょう.

HeaderData Arrays
UnstructuredGridInformation
N Cells10478
N Points15818
X Bounds-5.633e+00, 5.633e+00
Y Bounds-1.860e+00, 1.860e+00
Z Bounds-2.125e+00, 2.126e+00
N Arrays2
NameFieldTypeN CompMinMax
implicit_distancePointsfloat641-6.912e-013.280e-01
densityCellsfloat6413.650e+003.650e+00


contours = voxels.contour(6, scalars='implicit_distance')

p = pv.Plotter()
p.add_mesh(voxels, opacity=0.25, scalars='implicit_distance')
p.add_mesh(contours, opacity=0.5, scalars='implicit_distance')
p.show(cpos=cpos)
voxelize

Tags: filter

Total running time of the script: (0 minutes 1.795 seconds)

Sphinx-Galleryによるギャラリー