Note
Go to the end to download the full example code or to run this example in your browser via Binder
Seed-based connectivity on the surface#
The dataset that is a subset of the enhanced NKI Rockland sample (http://fcon_1000.projects.nitrc.org/indi/enhanced/, Nooner et al, 2012)
Resting state fMRI scans (TR=645ms) of 102 subjects were preprocessed (https://github.com/fliem/nki_nilearn) and projected onto the Freesurfer fsaverage5 template (Dale et al, 1999, Fischl et al, 1999). For this example we use the time series of a single subject’s left hemisphere.
The Destrieux parcellation (Destrieux et al, 2010) in fsaverage5 space as distributed with Freesurfer is used to select a seed region in the posterior cingulate cortex.
Functional connectivity of the seed region to all other cortical nodes in the same hemisphere is calculated using Pearson product-moment correlation coefficient.
The nilearn.plotting.plot_surf_stat_map
function is used to plot the resulting statistical map on the (inflated) pial surface.
See also for a similar example but using volumetric input data.
See Plotting brain images for more details on plotting tools.
References#
Nooner et al, (2012). The NKI-Rockland Sample: A model for accelerating the pace of discovery science in psychiatry. Frontiers in neuroscience 6, 152. URL http://dx.doi.org/10.3389/fnins.2012.00152
Dale et al, (1999). Cortical surface-based analysis.I. Segmentation and surface reconstruction. Neuroimage 9. URL http://dx.doi.org/10.1006/nimg.1998.0395
Fischl et al, (1999). Cortical surface-based analysis. II: Inflation, flattening, and a surface-based coordinate system. Neuroimage 9. http://dx.doi.org/10.1006/nimg.1998.0396
Destrieux et al, (2010). Automatic parcellation of human cortical gyri and sulci using standard anatomical nomenclature. NeuroImage, 53, 1. URL http://dx.doi.org/10.1016/j.neuroimage.2010.06.010.
Retrieving the data#
# NKI resting state data from nilearn
from nilearn import datasets
nki_dataset = datasets.fetch_surf_nki_enhanced(n_subjects=1)
# The nki dictionary contains file names for the data
# of all downloaded subjects.
print('Resting state data of the first subjects on the '
f"fsaverag5 surface left hemisphere is at: {nki_dataset['func_left'][0]}"
)
# Destrieux parcellation for left hemisphere in fsaverage5 space
destrieux_atlas = datasets.fetch_atlas_surf_destrieux()
parcellation = destrieux_atlas['map_left']
labels = destrieux_atlas['labels']
# Fsaverage5 surface template
fsaverage = datasets.fetch_surf_fsaverage()
# The fsaverage dataset contains file names pointing to
# the file locations
print('Fsaverage5 pial surface of left hemisphere is at: '
f"{fsaverage['pial_left']}")
print('Fsaverage5 flatten pial surface of left hemisphere is at: '
f"{fsaverage['flat_left']}")
print('Fsaverage5 inflated surface of left hemisphere is at: '
f"{fsaverage['infl_left']}")
print('Fsaverage5 sulcal depth map of left hemisphere is at: '
f"{fsaverage['sulc_left']}")
print('Fsaverage5 curvature map of left hemisphere is at: '
f"{fsaverage['curv_left']}")
Dataset created in /home/remi/nilearn_data/nki_enhanced_surface
Downloading data from https://www.nitrc.org/frs/download.php/8470/pheno_nki_nilearn.csv ...
...done. (1 seconds, 0 min)
Downloading data from https://www.nitrc.org/frs/download.php/8261/A00028185_rh_preprocessed_fsaverage5_fwhm6.gii ...
Downloaded 1368064 of 42412120 bytes (3.2%, 33.3s remaining)
Downloaded 2465792 of 42412120 bytes (5.8%, 34.2s remaining)
Downloaded 3530752 of 42412120 bytes (8.3%, 34.4s remaining)
Downloaded 4612096 of 42412120 bytes (10.9%, 33.8s remaining)
Downloaded 5668864 of 42412120 bytes (13.4%, 33.3s remaining)
Downloaded 6578176 of 42412120 bytes (15.5%, 33.4s remaining)
Downloaded 7602176 of 42412120 bytes (17.9%, 32.7s remaining)
Downloaded 8716288 of 42412120 bytes (20.6%, 31.5s remaining)
Downloaded 9838592 of 42412120 bytes (23.2%, 30.4s remaining)
Downloaded 10854400 of 42412120 bytes (25.6%, 29.8s remaining)
Downloaded 11460608 of 42412120 bytes (27.0%, 30.4s remaining)
Downloaded 12132352 of 42412120 bytes (28.6%, 30.6s remaining)
Downloaded 12845056 of 42412120 bytes (30.3%, 30.6s remaining)
Downloaded 13623296 of 42412120 bytes (32.1%, 30.2s remaining)
Downloaded 14458880 of 42412120 bytes (34.1%, 29.6s remaining)
Downloaded 15351808 of 42412120 bytes (36.2%, 28.7s remaining)
Downloaded 16310272 of 42412120 bytes (38.5%, 27.7s remaining)
Downloaded 17489920 of 42412120 bytes (41.2%, 26.2s remaining)
Downloaded 19038208 of 42412120 bytes (44.9%, 23.8s remaining)
Downloaded 20832256 of 42412120 bytes (49.1%, 21.2s remaining)
Downloaded 22208512 of 42412120 bytes (52.4%, 19.5s remaining)
Downloaded 23560192 of 42412120 bytes (55.6%, 18.0s remaining)
Downloaded 24903680 of 42412120 bytes (58.7%, 16.5s remaining)
Downloaded 26288128 of 42412120 bytes (62.0%, 15.0s remaining)
Downloaded 27394048 of 42412120 bytes (64.6%, 14.0s remaining)
Downloaded 28598272 of 42412120 bytes (67.4%, 12.8s remaining)
Downloaded 29696000 of 42412120 bytes (70.0%, 11.8s remaining)
Downloaded 30736384 of 42412120 bytes (72.5%, 10.8s remaining)
Downloaded 31842304 of 42412120 bytes (75.1%, 9.8s remaining)
Downloaded 32743424 of 42412120 bytes (77.2%, 9.0s remaining)
Downloaded 33759232 of 42412120 bytes (79.6%, 8.1s remaining)
Downloaded 34914304 of 42412120 bytes (82.3%, 7.0s remaining)
Downloaded 36069376 of 42412120 bytes (85.0%, 5.9s remaining)
Downloaded 37224448 of 42412120 bytes (87.8%, 4.8s remaining)
Downloaded 38379520 of 42412120 bytes (90.5%, 3.7s remaining)
Downloaded 39583744 of 42412120 bytes (93.3%, 2.6s remaining)
Downloaded 40886272 of 42412120 bytes (96.4%, 1.4s remaining)
Downloaded 42385408 of 42412120 bytes (99.9%, 0.0s remaining) ...done. (39 seconds, 0 min)
Downloading data from https://www.nitrc.org/frs/download.php/8260/A00028185_lh_preprocessed_fsaverage5_fwhm6.gii ...
Downloaded 1359872 of 42402060 bytes (3.2%, 32.3s remaining)
Downloaded 2744320 of 42402060 bytes (6.5%, 30.0s remaining)
Downloaded 4169728 of 42402060 bytes (9.8%, 28.2s remaining)
Downloaded 5398528 of 42402060 bytes (12.7%, 28.0s remaining)
Downloaded 6578176 of 42402060 bytes (15.5%, 27.7s remaining)
Downloaded 7831552 of 42402060 bytes (18.5%, 27.0s remaining)
Downloaded 9084928 of 42402060 bytes (21.4%, 26.1s remaining)
Downloaded 10330112 of 42402060 bytes (24.4%, 25.2s remaining)
Downloaded 11665408 of 42402060 bytes (27.5%, 24.0s remaining)
Downloaded 13058048 of 42402060 bytes (30.8%, 22.8s remaining)
Downloaded 14540800 of 42402060 bytes (34.3%, 21.3s remaining)
Downloaded 16039936 of 42402060 bytes (37.8%, 20.0s remaining)
Downloaded 17539072 of 42402060 bytes (41.4%, 18.7s remaining)
Downloaded 18841600 of 42402060 bytes (44.4%, 17.7s remaining)
Downloaded 20185088 of 42402060 bytes (47.6%, 16.7s remaining)
Downloaded 21372928 of 42402060 bytes (50.4%, 15.9s remaining)
Downloaded 22577152 of 42402060 bytes (53.2%, 15.1s remaining)
Downloaded 23797760 of 42402060 bytes (56.1%, 14.2s remaining)
Downloaded 25149440 of 42402060 bytes (59.3%, 13.2s remaining)
Downloaded 26509312 of 42402060 bytes (62.5%, 12.1s remaining)
Downloaded 27901952 of 42402060 bytes (65.8%, 11.0s remaining)
Downloaded 29261824 of 42402060 bytes (69.0%, 10.0s remaining)
Downloaded 30703616 of 42402060 bytes (72.4%, 8.9s remaining)
Downloaded 32243712 of 42402060 bytes (76.0%, 7.6s remaining)
Downloaded 33783808 of 42402060 bytes (79.7%, 6.4s remaining)
Downloaded 34816000 of 42402060 bytes (82.1%, 5.7s remaining)
Downloaded 35938304 of 42402060 bytes (84.8%, 4.9s remaining)
Downloaded 37101568 of 42402060 bytes (87.5%, 4.0s remaining)
Downloaded 38256640 of 42402060 bytes (90.2%, 3.2s remaining)
Downloaded 39477248 of 42402060 bytes (93.1%, 2.2s remaining)
Downloaded 40755200 of 42402060 bytes (96.1%, 1.3s remaining)
Downloaded 41549824 of 42402060 bytes (98.0%, 0.7s remaining)
Downloaded 42311680 of 42402060 bytes (99.8%, 0.1s remaining) ...done. (34 seconds, 0 min)
Resting state data of the first subjects on the fsaverag5 surface left hemisphere is at: /home/remi/nilearn_data/nki_enhanced_surface/A00028185/A00028185_left_preprocessed_fwhm6.gii
Fsaverage5 pial surface of left hemisphere is at: /home/remi/github/nilearn/env/lib/python3.11/site-packages/nilearn/datasets/data/fsaverage5/pial_left.gii.gz
Fsaverage5 flatten pial surface of left hemisphere is at: /home/remi/github/nilearn/env/lib/python3.11/site-packages/nilearn/datasets/data/fsaverage5/flat_left.gii.gz
Fsaverage5 inflated surface of left hemisphere is at: /home/remi/github/nilearn/env/lib/python3.11/site-packages/nilearn/datasets/data/fsaverage5/infl_left.gii.gz
Fsaverage5 sulcal depth map of left hemisphere is at: /home/remi/github/nilearn/env/lib/python3.11/site-packages/nilearn/datasets/data/fsaverage5/sulc_left.gii.gz
Fsaverage5 curvature map of left hemisphere is at: /home/remi/github/nilearn/env/lib/python3.11/site-packages/nilearn/datasets/data/fsaverage5/curv_left.gii.gz
Extracting the seed time series#
# Load resting state time series from nilearn
from nilearn import surface
timeseries = surface.load_surf_data(nki_dataset['func_left'][0])
# Extract seed region via label
pcc_region = b'G_cingul-Post-dorsal'
import numpy as np
pcc_labels = np.where(parcellation == labels.index(pcc_region))[0]
# Extract time series from seed region
seed_timeseries = np.mean(timeseries[pcc_labels], axis=0)
Calculating seed-based functional connectivity#
# Calculate Pearson product-moment correlation coefficient between seed
# time series and timeseries of all cortical nodes of the hemisphere
from scipy import stats
stat_map = np.zeros(timeseries.shape[0])
for i in range(timeseries.shape[0]):
stat_map[i] = stats.pearsonr(seed_timeseries, timeseries[i])[0]
# Re-mask previously masked nodes (medial wall)
stat_map[np.where(np.mean(timeseries, axis=1) == 0)] = 0
/home/remi/github/nilearn/env/lib/python3.11/site-packages/scipy/stats/_stats_py.py:4781: ConstantInputWarning:
An input array is constant; the correlation coefficient is not defined.
Display ROI on surface
# Transform ROI indices in ROI map
pcc_map = np.zeros(parcellation.shape[0], dtype=int)
pcc_map[pcc_labels] = 1
from nilearn import plotting
plotting.plot_surf_roi(
fsaverage['pial_left'],
roi_map=pcc_map,
hemi='left',
view='medial',
bg_map=fsaverage['sulc_left'],
bg_on_data=True,
title='PCC Seed'
)
<Figure size 400x400 with 1 Axes>
Using a flat mesh can be useful in order to easily locate the area of interest on the cortex. To make this plot easier to read, we use the mesh curvature as a background map.
bg_map = np.sign(surface.load_surf_data(fsaverage['curv_left']))
# np.sign yields values in [-1, 1]. We rescale the background map
# such that values are in [0.25, 0.75], resulting in a nicer looking plot.
bg_map_rescaled = (bg_map + 1) / 4 + 0.25
plotting.plot_surf_roi(
fsaverage['flat_left'],
roi_map=pcc_map,
hemi='left',
view='dorsal',
bg_map=bg_map_rescaled,
bg_on_data=True,
title='PCC Seed'
)
<Figure size 400x400 with 1 Axes>
Display unthresholded stat map with a slightly dimmed background
<Figure size 470x400 with 2 Axes>
Many different options are available for plotting, for example thresholding, or using custom colormaps
<Figure size 470x400 with 2 Axes>
Here the surface is plotted in a lateral view without a background map. To capture 3D structure without depth information, the default is to plot a half transparent surface. Note that you can also control the transparency with a background map using the alpha parameter.
plotting.plot_surf_stat_map(fsaverage['pial_left'], stat_map=stat_map,
hemi='left', view='lateral', colorbar=True,
cmap='Spectral', threshold=.5,
title='Plotting without background')
<Figure size 470x400 with 2 Axes>
The plots can be saved to file, in which case the display is closed after creating the figure
plotting.plot_surf_stat_map(fsaverage['infl_left'], stat_map=stat_map,
hemi='left', bg_map=fsaverage['sulc_left'],
bg_on_data=True, threshold=.5, colorbar=True,
output_file='plot_surf_stat_map.png')
plotting.show()
Total running time of the script: (1 minutes 32.856 seconds)
Estimated memory usage: 269 MB