Note
Go to the end to download the full example code.
Torso#
Repair the torso mesh where it was extracted and subtle holes along complex parts of the mesh
# sphinx_gallery_thumbnail_number = 2
import pyvista as pv
from pyvista import examples
import pymeshfix as mf
mesh = examples.download_torso()
print(mesh)
PolyData (0x7fed9c753160)
N Cells: 12448
N Points: 12015
N Strips: 0
X Bounds: -1.680e+02, 1.720e+02
Y Bounds: -1.624e+02, 1.320e+02
Z Bounds: -6.442e+02, 9.083e+01
N Arrays: 0
cpos = [(-1053.0, -1251.0, 83.0), (2.0, -15.0, -276.0), (0.12, 0.18, 1)]
mesh.plot(color=True, show_edges=True, cpos=cpos)
data:image/s3,"s3://crabby-images/520b9/520b9ba96c206e26a810d7b32f51a5dfb0afc8dc" alt="torso"
Apply a triangle filter to ensure the mesh is simply polyhedral
meshfix = mf.MeshFix(mesh.triangulate())
holes = meshfix.extract_holes()
Outline the holes in the mesh
p = pv.Plotter()
p.add_mesh(mesh)
p.add_mesh(holes, color="r", line_width=8)
p.enable_eye_dome_lighting() # helps with depth perception
p.camera_position = cpos
p.show()
data:image/s3,"s3://crabby-images/bcdcc/bcdcc457b8588e6481f6a2fff7ac7e41a9e958dc" alt="torso"
Emphasize the hole near the ear - this needs to be repaired so that the mesh is absolutely water tight.
cpos_ear = [(180.0, -206.0, 17.0), (107.0, -122.9, -11.9), (-0.13, 0.22, 0.96)]
p = pv.Plotter()
p.add_mesh(mesh)
p.add_mesh(holes, color="r", line_width=8)
p.enable_eye_dome_lighting() # helps with depth perception
p.camera_position = cpos_ear
p.show()
data:image/s3,"s3://crabby-images/3e8f0/3e8f014fbeb987aa325af678f5166efd9ed8de7a" alt="torso"
Perform the mesh repair
meshfix.repair(verbose=True)
Removed 6 small components
Patching holes...
Patched 5 holes
Fixing degeneracies and intersections
Show the repaired mesh
meshfix.mesh.plot(cpos=cpos, eye_dome_lighting=True)
data:image/s3,"s3://crabby-images/f0438/f04380c574bc0eceb72ebac9f07cafc1167e72e2" alt="torso"
Total running time of the script: (0 minutes 2.366 seconds)