Note
Go to the end to download the full example code. or to run this example in your browser via Binder
Glass brain plotting in nilearn (all options)¶
The first part of this example goes through different options of the
plot_glass_brain
function (including plotting
negative values).
The second part goes through same options but selected of the same glass brain function but plotting is seen with contours.
See Plotting brain images for more plotting functionalities and Section 4.3 for more details about display objects in Nilearn.
Also, see fetch_neurovault_motor_task
for details
about the plotting data and associated meta-data.
Load the data¶
We will use a motor activation contrast map distributed with Nilearn.
from nilearn import datasets
stat_img = datasets.load_sample_motor_activation_image()
# stat_img is just the name of the image file
stat_img
'/home/runner/work/nilearn/nilearn/.tox/doc/lib/python3.9/site-packages/nilearn/datasets/data/image_10426.nii.gz'
Demo glass brain plotting¶
By default, plot_glass_brain
uses a display mode
called ‘ortho’ which results in three projections. It is equivalent to
specify display_mode='ortho'
in
plot_glass_brain
. Note that depending on the
value of display_mode
, different display objects are returned. Here,
a OrthoProjector
is returned.
from nilearn.plotting import plot_glass_brain, show
# Whole brain sagittal cuts and map is thresholded at 3
plot_glass_brain(stat_img, threshold=3)
data:image/s3,"s3://crabby-images/28aba/28abaaf733c31eebfde7c03ccad74d9950ff190e" alt="plot demo glass brain extensive"
<nilearn.plotting.displays._projectors.OrthoProjector object at 0x7f6ed3564520>
The same figure, with a colorbar,
can be produced by setting colorbar=True
.
plot_glass_brain(stat_img, threshold=3, colorbar=True)
data:image/s3,"s3://crabby-images/5e8cf/5e8cfaa2ef574b8a886c3093a432d07b31ddfebe" alt="plot demo glass brain extensive"
<nilearn.plotting.displays._projectors.OrthoProjector object at 0x7f6ed3349a30>
Here, we show how to set a black background, and we only view sagittal and
axial projections by setting display_mode='xz'
, which returns a
XZProjector
.
plot_glass_brain(
stat_img,
title="plot_glass_brain",
black_bg=True,
display_mode="xz",
threshold=3,
)
data:image/s3,"s3://crabby-images/dfc8b/dfc8b34949e932caefa89847558544dcd3ece852" alt="plot demo glass brain extensive"
<nilearn.plotting.displays._projectors.XZProjector object at 0x7f6ed2fa1ac0>
We can also plot the sign of the activation by setting plot_abs=False
.
Additionally, we only visualize coronal and axial projections by setting
display_mode='yz'
which returns a
YZProjector
.
plot_glass_brain(
stat_img, threshold=0, colorbar=True, plot_abs=False, display_mode="yz"
)
data:image/s3,"s3://crabby-images/178db/178db2ce29ab6b9ee3706e87bba7834ea22f54d6" alt="plot demo glass brain extensive"
<nilearn.plotting.displays._projectors.YZProjector object at 0x7f6ed2d62880>
Setting plot_abs=True
and display_mode='yx'
(returns a
YXProjector
).
plot_glass_brain(
stat_img, threshold=3, colorbar=True, plot_abs=True, display_mode="yx"
)
data:image/s3,"s3://crabby-images/e6d05/e6d051c46b1b4949ecda9aaa39aaf3670fff208d" alt="plot demo glass brain extensive"
<nilearn.plotting.displays._projectors.YXProjector object at 0x7f6ed4e9ea00>
We can control the limits of the colormap and colorbar by setting vmin
and vmax
.
Note that we use a non-diverging colormap here
since the colorbar will not be centered around zero.
# only plot positive values
plot_glass_brain(
stat_img,
colorbar=True,
plot_abs=False,
display_mode="yz",
vmin=0,
threshold=2,
symmetric_cbar=False,
cmap="inferno",
title="only plot positive values",
)
data:image/s3,"s3://crabby-images/7c59b/7c59bec6aa6cb9f428d24df6228d0ab4a24a8bd3" alt="plot demo glass brain extensive"
<nilearn.plotting.displays._projectors.YZProjector object at 0x7f6ed3134220>
Here we set vmin
to the threshold to use the full color range instead of
losing colors due to the thresholding.
plot_glass_brain(
stat_img,
colorbar=True,
plot_abs=False,
display_mode="yz",
vmin=2,
threshold=2,
symmetric_cbar=False,
cmap="inferno",
title="vmin == threshold",
)
data:image/s3,"s3://crabby-images/f08f1/f08f1887a9d83848a00160e6a70fffb760224ce4" alt="plot demo glass brain extensive"
<nilearn.plotting.displays._projectors.YZProjector object at 0x7f6ed3074460>
Different projections for the left and right hemispheres¶
In the previous section we saw a few projection modes, which are controlled
by setting the argument display_mode
of
plot_glass_brain
. In this section, we will show
some additional possibilities. For example, setting display_mode='lzr'
enables an hemispheric sagittal view. The display object returned is then a
LZRProjector
.
plot_glass_brain(
stat_img,
title='plot_glass_brain with display_mode="lzr"',
black_bg=True,
display_mode="lzr",
threshold=3,
)
data:image/s3,"s3://crabby-images/35c4e/35c4e829309aa61de32960be06104f25e32cd7ab" alt="plot demo glass brain extensive"
<nilearn.plotting.displays._projectors.LZRProjector object at 0x7f6ed3073ca0>
display_mode='lyrz'
returns a
LYRZProjector
object.
plot_glass_brain(
stat_img,
threshold=0,
colorbar=True,
title='plot_glass_brain with display_mode="lyrz"',
plot_abs=False,
display_mode="lyrz",
)
data:image/s3,"s3://crabby-images/d621a/d621a13ab9c6d910c8f3706d09f1194bf9151d17" alt="plot demo glass brain extensive"
<nilearn.plotting.displays._projectors.LYRZProjector object at 0x7f6ed308ca30>
If you are only interested in single projections, you can set
display_mode
to
‘x’ (returns a XProjector
),
‘y’ (returns a YProjector
),
‘z’ (returns a ZProjector
),
‘l’ (returns a LProjector
), or
‘r’ (returns a RProjector
).
plot_glass_brain(
stat_img,
threshold=0,
colorbar=True,
title='display_mode="x"',
plot_abs=True,
display_mode="x",
)
data:image/s3,"s3://crabby-images/fa7d1/fa7d18c359a0841a430d4ab84550bd6dd8dd2b79" alt="plot demo glass brain extensive"
<nilearn.plotting.displays._projectors.XProjector object at 0x7f6ed2e1f880>
Contours and with fillings¶
The display objects returned by plot_glass_brain
all inherit from the OrthoProjector
and enable further customization of the figures.
In this example, we focus on using methods
add_contours
and
title
. First, we
save the display object (here a
LZRYProjector
) into a variable named
display
. Note that we set the first argument to None
since we
want an empty glass brain to plot the statistical maps with
add_contours
.
display = plot_glass_brain(None, display_mode="lzry")
# Here, we project statistical maps
display.add_contours(stat_img)
# and add a title
display.title('"stat_img" on glass brain without threshold')
data:image/s3,"s3://crabby-images/3c60b/3c60bc622ba9d720a56907ad55235c4d00ee9390" alt="plot demo glass brain extensive"
We can fill the contours by setting filled=True
. Note that we are not
specifying levels here
display = plot_glass_brain(None, display_mode="lzry")
# Here, we project statistical maps with filled=True
display.add_contours(stat_img, filled=True)
# and add a title
display.title("Same map but with fillings in the contours")
data:image/s3,"s3://crabby-images/0bead/0bead1d9dfd8e98fee6aa5912cbd745b71b8dc24" alt="plot demo glass brain extensive"
Here, we input a specific level (cut-off) in the statistical map. In other words, we are thresholding our statistical map.
We set the threshold using a parameter of method
add_contours
called
levels
which value is given as a list and we choose the color to be red.
display = plot_glass_brain(None, display_mode="lzry")
display.add_contours(stat_img, levels=[3.0], colors="r")
display.title('"stat_img" on glass brain with threshold')
data:image/s3,"s3://crabby-images/f3ed5/f3ed5095b014806bc946b22dd302e361ff90a0c1" alt="plot demo glass brain extensive"
Plotting with same demonstration but fill the contours (by setting
filled=True
).
display = plot_glass_brain(None, display_mode="lzry")
display.add_contours(stat_img, filled=True, levels=[3.0], colors="r")
display.title("Same demonstration but using fillings inside contours")
data:image/s3,"s3://crabby-images/ea20d/ea20db106511ab00060a32dff8487b138221e0fe" alt="plot demo glass brain extensive"
Plotting with black background, black_bg
should be set to True
through plot_glass_brain
.
# We can set black background using black_bg=True
display = plot_glass_brain(None, black_bg=True)
display.add_contours(stat_img, levels=[3.0], colors="g")
display.title('"stat_img" on glass brain with black background')
data:image/s3,"s3://crabby-images/55ff6/55ff60f1648b3118a30b7ac8f847348dd33c3d5f" alt="plot demo glass brain extensive"
Black background plotting with filled in contours.
display = plot_glass_brain(None, black_bg=True)
display.add_contours(stat_img, filled=True, levels=[3.0], colors="g")
display.title("Glass brain with black background and filled in contours")
data:image/s3,"s3://crabby-images/e417a/e417a7d5d598c51942b42e7824a5fe5344d46e21" alt="plot demo glass brain extensive"
Contour projections in both hemispheres¶
The key argument to vary here is display_mode
for hemispheric plotting.
Here, we set display_mode='lr'
for both hemispheric plots. Note that a
LRProjector
is returned.
display = plot_glass_brain(None, display_mode="lr")
display.add_contours(stat_img, levels=[3.0], colors="r")
display.title('"stat_img" on glass brain only\n"l" "r" hemispheres')
data:image/s3,"s3://crabby-images/d9fc4/d9fc474fcf545fb5144cc9dfc9bb111afaf4445a" alt="plot demo glass brain extensive"
Filled contours in both hemispheric plotting, by adding filled=True
.
display = plot_glass_brain(None, display_mode="lr")
display.add_contours(stat_img, filled=True, levels=[3.0], colors="r")
display.title('Filled contours on glass brain only\n"l" "r" hemispheres')
data:image/s3,"s3://crabby-images/8ea50/8ea500b2e65c75d789664638613a62657717355c" alt="plot demo glass brain extensive"
With positive and negative signs of activations with plot_abs
in
plot_glass_brain
.
By default parameter plot_abs
is True
and sign of activations
can be displayed by changing plot_abs
to False
. Note that we also
specify display_mode='lyr'
which returns a
LYRProjector
display object.
display = plot_glass_brain(None, plot_abs=False, display_mode="lyr")
display.add_contours(stat_img)
display.title("Contours with both sign of activations without threshold")
data:image/s3,"s3://crabby-images/872ad/872ad145a0f5394b6d12b595a3f7444cf65e7113" alt="plot demo glass brain extensive"
Now, adding filled=True
to get positive and negative sign activations
with fillings in the contours.
display = plot_glass_brain(None, plot_abs=False, display_mode="lyr")
display.add_contours(stat_img, filled=True)
display.title(
"Filled contours with both sign of activations without threshold"
)
data:image/s3,"s3://crabby-images/a956c/a956c9d669bf777d2148c8c36cfc4c7bf6d095a4" alt="plot demo glass brain extensive"
Displaying both signs (positive and negative) of activations with threshold
meaning thresholding by adding an argument levels
in method
add_contours
.
We give two values through the argument levels
which corresponds to the
thresholds of the contour we want to draw: One is positive and the other one
is negative. We give a list of colors
as argument to associate a
different color to each contour. Additionally, we also choose to plot
contours with thick line widths. For linewidths
, one value would be
enough so that same value is used for both contours.
import numpy as np
display = plot_glass_brain(None, plot_abs=False, display_mode="lzry")
display.add_contours(
stat_img, levels=[-2.8, 3.0], colors=["b", "r"], linewidths=4.0
)
display.title("Contours with sign of activations with threshold")
data:image/s3,"s3://crabby-images/67c8b/67c8bbc435ce2ee9c9c403ef7c14ecc7879908e6" alt="plot demo glass brain extensive"
Same display demonstration as above but adding filled=True
to get
fillings inside the contours.
Unlike in previous plot, here we specify each sign at a time. We call negative values display first followed by positive values display.
First, we fetch our display object with same parameters used as above. Then, we plot negative sign of activation with levels given as negative activation value in a list. Upper bound should be kept to -infinity. Next, using the same display object, we plot positive sign of activation.
display = plot_glass_brain(None, plot_abs=False, display_mode="lzry")
display.add_contours(stat_img, filled=True, levels=[-np.inf, -2.8], colors="b")
display.add_contours(stat_img, filled=True, levels=[3.0], colors="r")
display.title("Now same plotting but with filled contours")
# Finally, displaying them
show()
data:image/s3,"s3://crabby-images/ac575/ac575062dea2d8141f7054a67900f74f2711a304" alt="plot demo glass brain extensive"
Total running time of the script: (0 minutes 23.517 seconds)
Estimated memory usage: 114 MB