Note
Click here to download the full example code
Plot Freesurfer Normalization¶
This example shows how PySurfer can be used to examine the quality of Freesurfer’s curvature-driven normalization to a common template.
We are going to plot the contour of the subject’s curvature estimate after
transforming that map into the common space (this step is performed outside
of PySurfer using the Freesurfer program mri_surf2surf
).
With a perfect transformation, the contour lines should follow the light/dark gray boundary on the fsaverage surface. Large deviations may reflect problems with the underlying data that you should investigate.
Out:
/home/larsoner/python/PySurfer/examples/plot_freesurfer_normalization.py:30: DeprecationWarning: get_data() is deprecated in favor of get_fdata(), which has a more predictable return type. To obtain get_data() behavior going forward, use numpy.asanyarray(img.dataobj).
* deprecated from version: 3.0
* Will raise <class 'nibabel.deprecator.ExpiredDeprecationError'> as of version: 5.0
curv_bin = (curv.get_data() > 0).squeeze()
/home/larsoner/python/PySurfer/examples/plot_freesurfer_normalization.py:30: DeprecationWarning: get_data() is deprecated in favor of get_fdata(), which has a more predictable return type. To obtain get_data() behavior going forward, use numpy.asanyarray(img.dataobj).
* deprecated from version: 3.0
* Will raise <class 'nibabel.deprecator.ExpiredDeprecationError'> as of version: 5.0
curv_bin = (curv.get_data() > 0).squeeze()
((0.0, 0.0, 432.1112365722656, array([-0.59938049, 0. , 0. ])), 90.00000000000001)
import nibabel as nib
from surfer import Brain
print(__doc__)
brain = Brain("fsaverage", "both", "inflated")
for hemi in ["lh", "rh"]:
# This file was created with mri_surf2surf
curv = nib.load("example_data/%s.curv.fsaverage.mgz" % hemi)
# Binarize the curvature at 0
curv_bin = (curv.get_data() > 0).squeeze()
# Add the data as a contour overlay, but turn off the colorbar
brain.add_contour_overlay(curv_bin, min=0, max=1.5, n_contours=2,
line_width=3, hemi=hemi)
brain.contour_list[-1]["colorbar"].visible = False
brain.show_view("dorsal")
Total running time of the script: ( 0 minutes 1.323 seconds)