How to get a mesh from an MRI image?#
[1]:
import pyvista as pv
from polpo.preprocessing import Pipeline, RemoveIndex
from polpo.preprocessing.load import FigsharePregnancyDataLoader
from polpo.preprocessing.mesh.conversion import PvFromData
from polpo.preprocessing.mri import (
MeshExtractorFromSegmentedImage,
MriImageLoader,
SkimageMarchingCubes,
)
from polpo.preprocessing.path import FileFinder, FileRule
[KeOps] Warning : cuda was detected, but driver API could not be initialized. Switching to cpu only.
[2]:
STATIC_VIZ = True
if STATIC_VIZ:
pv.set_jupyter_backend("static")
Loading data#
Following How to visualize MRI data?, we start by getting the image data.
[3]:
SESSION_ID = 1
[4]:
folder_name = f"ses-{str(SESSION_ID).zfill(2)}"
loader = FigsharePregnancyDataLoader(
data_dir="~/.herbrain/data/pregnancy/mri",
remote_path=f"mri/{folder_name}",
)
finder = FileFinder(
rules=[
FileRule(value="BrainNormalized", func="startswith"),
FileRule(value=".nii.gz", func="endswith"),
]
)
pipe = loader + finder + MriImageLoader()
[5]:
img_fdata = pipe()
INFO: Data has already been downloaded... using cached file ('/home/luisfpereira/.herbrain/data/pregnancy/mri/ses-01').
Marching cubes#
We now use marching cubes and transform the output to pyvista.PolyData for visualization.
[6]:
mesh_from_image = Pipeline(
[
SkimageMarchingCubes(),
lambda x: list(x),
RemoveIndex(index=-1, inplace=True),
]
)
[7]:
mesh = (mesh_from_image + PvFromData())(img_fdata)
Visualization#
[8]:
pl = pv.Plotter(border=False)
pl.show_axes()
pl.add_mesh(mesh, show_edges=True)
pl.show()
data:image/s3,"s3://crabby-images/23c6b/23c6b9d88c9d02a1d0e8b2e63867498c1821cf8d" alt="../../../_images/_notebooks_how_to_mri_mri2mesh_13_0.png"
Segmented data#
Load the segmented data.
[9]:
folder_name = f"BB{str(SESSION_ID).zfill(2)}"
loader = FigsharePregnancyDataLoader(
data_dir="~/.herbrain/data/pregnancy/Segmentations",
remote_path=f"Segmentations/{folder_name}",
)
finder = FileFinder(
rules=[
FileRule(value="left", func="startswith"),
FileRule(value=".nii.gz", func="endswith"),
]
)
pipe = loader + finder + MriImageLoader()
[10]:
img_fdata = pipe()
The process changes only slightly when the data is segmented.
[11]:
mesh = (MeshExtractorFromSegmentedImage() + PvFromData())(img_fdata)
[12]:
pl = pv.Plotter(border=False)
pl.show_axes()
pl.add_mesh(mesh, show_edges=True)
pl.show()
data:image/s3,"s3://crabby-images/5c9ef/5c9ef6324603ba079f803b23fc51d1434c265679" alt="../../../_images/_notebooks_how_to_mri_mri2mesh_20_0.png"