Content from Imaging Data: Structure And Formats


Last updated on 2025-01-14 | Edit this page

Overview

Questions

  • How is imaging data represented in a computer?
  • What are some of the popular imaging formats used?
  • How do I view and navigate around an image/

Objectives

  • Describe the structure of imaging data
  • Understand the coordinate systems and mapping between voxels and real world.
  • Demonstrate how to view images, navigate through volumes and change contrast

Introduction


Any medical image consists of two parts: a header and the image itself. The header consists of metadata that describe the image. This includes the patient’s demographic information such as the patient’s name, age, gender, and date of birth. The header also gives information on the image characteristics such as image dimension and some acquisition parameters. Because of the need to store more information, medical images require specific formats (different from e.g. .jpeg or .png).

Image formats: DICOM and NIfTI

DICOM (.dcm) stands for Digital Imaging and Communications in Medicine. It is a standard, internationally accepted format to view, store, retrieve and share medical images. Clinical imaging data are typically stored and transferred in the DICOM format, so DICOM can be considered the native format in which we get imaging data from the scanner.

NIfTI (.nii, .nii.gz) format is simpler and easier to support, so has been widely adopted by scientists in the neuroimaging community. Therefore, a vital initial step in processing the data is to convert images from DICOM to NIfTI format. In this practical we will work with data that have already been converted to NIfTI, but many tools for such conversions are available (for example dcm2niix).

Discussion

If you are interested in trying out converting DICOM data to Nifti, we have some sample DICOM data for you. Please see the bonus exercise at the end of this lesson if you would like to give this a go.

Viewing image properties - fslhd and fslinfo

These tools enable various properties of an image to be viewed.

Clicking on the Applications in the upper left-hand corner and select the terminal icon. This will open a terminal window that you will use to type commands Launch terminal window

From the terminal window type:

BASH

cd ~/data/ImageDataVisualization
ls

OUTPUT

sub-OAS30015_acq-TSE_T2w.json            sub-OAS30015_T1w_brain_seg.nii.gz
sub-OAS30015_acq-TSE_T2w.nii.gz          sub-OAS30015_T1w.json
sub-OAS30015_T1w_brain_mask.nii.gz       sub-OAS30015_T1w.nii.gz
sub-OAS30015_T1w_brain_mixeltype.nii.gz  sub-OAS30015_T1w_orig.nii.gz
sub-OAS30015_T1w_brain.nii.gz            sub-OAS30015_T2star.json
sub-OAS30015_T1w_brain_pve_0.nii.gz      sub-OAS30015_T2star.nii.gz
sub-OAS30015_T1w_brain_pve_1.nii.gz      sub-OAS30015_T2w.json
sub-OAS30015_T1w_brain_pve_2.nii.gz      sub-OAS30015_T2w.nii.gz
sub-OAS30015_T1w_brain_pveseg.nii.gz

This means that we are going to be working in the ImageDataVisualization subfolder under data in your home directory (~). The ls command gives you a list of the files in this directory.

If you are in general unfamiliar with how to use the command line, then we suggest you glance over this [additional tutorial].

If you are not sure how to use a command, there are multiple ways of getting help:

  • Using the man command Just type man in front of it to get the manual entry.

    BASH

    man ls
    man find
    man more
    man less
  • Use the -h option Many commands will provide more information about how to use a command if you type -h or --help after the command. This usually produces the usage statement. Let’s take a look at what happens when we want to get more help with the dcm12niix command mentioned above to convert a DICOM file set to a Nifti.

    BASH

    dcm2niix -h

    OUTPUT

    Chris Rorden's dcm2niiX version v1.0.20240202  Clang14.0.0 x86-64 (64-bit MacOS)
    usage: dcm2niix [options] <in_folder>
     Options :
      -1..-9 : gz compression level (1=fastest..9=smallest, default 6)
      -a : adjacent DICOMs (images from same series always in same folder) for faster conversion (n/y, default n)
      -b : BIDS sidecar (y/n/o [o=only: no NIfTI], default y)
      -ba : anonymize BIDS (y/n, default y)
      -c : comment stored in NIfTI aux_file (up to 24 characters e.g. '-c VIP', empty to anonymize e.g. 0020,4000 e.g. '-c ""')
      -d : directory search depth. Convert DICOMs in sub-folders of in_folder? (0..9, default 5)
      -e : export as NRRD (y) or MGH (o) or JSON/JNIfTI (j) or BJNIfTI (b) instead of NIfTI (y/n/o/j/b, default n)
      -f : filename (%a=antenna (coil) name, %b=basename, %c=comments, %d=description, %e=echo number, %f=folder name, %g=accession number, %i=ID of patient, %j=seriesInstanceUID, %k=studyInstanceUID, %m=manufacturer, %n=name of patient, %o=mediaObjectInstanceUID, %p=protocol, %r=instance number, %s=series number, %t=time, %u=acquisition number, %v=vendor, %x=study ID; %z=sequence name; default '%i_%s_%d')
      -g : generate defaults file (y/n/o/i [o=only: reset and write defaults; i=ignore: reset defaults], default n)
      -h : show help
      -i : ignore derived, localizer and 2D images (y/n, default n)
      -l : losslessly scale 16-bit integers to use dynamic range (y/n/o [yes=scale, no=no, but uint16->int16, o=original], default o)
      -m : merge 2D slices from same series regardless of echo, exposure, etc. (n/y or 0/1/2, default 2) [no, yes, auto]
      -n : only convert this series CRC number - can be used up to 16 times (default convert all)
      -o : output directory (omit to save to input folder)
      -p : Philips precise float (not display) scaling (y/n, default y)
      -q : only search directory for DICOMs (y/l/n, default y) [y=show number of DICOMs found, l=additionally list DICOMs found, n=no]
      -r : rename instead of convert DICOMs (y/n, default n)
      -s : single file mode, do not convert other images in folder (y/n, default n)
      -u : up-to-date check
      -v : verbose (n/y or 0/1/2, default 0) [no, yes, logorrheic]
      -w : write behavior for name conflicts (0,1,2, default 2: 0=skip duplicates, 1=overwrite, 2=add suffix)
      -x : crop 3D acquisitions (y/n/i, default n, use 'i'gnore to neither crop nor rotate 3D acquistions)
      -z : gz compress images (y/o/i/n/3, default y) [y=pigz, o=optimal pigz, i=internal:miniz, n=no, 3=no,3D]
      --big-endian : byte order (y/n/o, default o) [y=big-end, n=little-end, o=optimal/native]
      --progress : Slicer format progress information (y/n, default n)
      --ignore_trigger_times : disregard values in 0018,1060 and 0020,9153
      --terse : omit filename post-fixes (can cause overwrites)
      --version : report version
      --xml : Slicer format features
     Defaults file : /Users/davecash/.dcm2nii.ini
     Examples :
      dcm2niix /Users/chris/dir
      dcm2niix -c "my comment" /Users/chris/dir
      dcm2niix -o /users/cr/outdir/ -z y ~/dicomdir
      dcm2niix -f %p_%s -b y -ba n ~/dicomdir
      dcm2niix -f mystudy%s ~/dicomdir
      dcm2niix -o "~/dir with spaces/dir" ~/dicomdir
     Example output filename: 'ID123_1_T1_mprage.nii.gz'
  • Search for help on the command online - this can be helpful if you want more information, tutorials or if for some reason the manual entry has not been installed.

Now let’s look at some of the metadata for one of these images to better understand what information they contain and how they are structured. Type the following command:

BASH

fslhd sub-OAS30015_T1w.nii.gz

OUTPUT

filename	sub-OAS30015_T1w.nii.gz

sizeof_hdr	348
data_type	INT16
dim0		3
dim1		176
dim2		256
dim3		170
dim4		1
dim5		1
dim6		1
dim7		1
vox_units	mm
time_units	s
datatype	4
nbyper		2
bitpix		16
pixdim0		1.000000
pixdim1		1.000003
pixdim2		1.000000
pixdim3		1.000000
pixdim4		2.400000
pixdim5		0.000000
pixdim6		0.000000
pixdim7		0.000000
vox_offset	352
cal_max		0.000000
cal_min		0.000000
scl_slope	1.000000
scl_inter	0.000000
phase_dim	0
freq_dim	0
slice_dim	0
slice_name	Unknown
slice_code	0
slice_start	0
slice_end	0
slice_duration	0.000000
toffset		0.000000
intent		Unknown
intent_code	0
intent_name	
intent_p1	0.000000
intent_p2	0.000000
intent_p3	0.000000
qform_name	Scanner Anat
qform_code	1
qto_xyz:1	0.999466 -0.000520 -0.032767 -73.860321
qto_xyz:2	-0.000059 0.999844 -0.017685 -88.219193
qto_xyz:3	0.032771 0.017677 0.999307 -94.454788
qto_xyz:4	0.000000 0.000000 0.000000 1.000000
qform_xorient	Left-to-Right
qform_yorient	Posterior-to-Anterior
qform_zorient	Inferior-to-Superior
sform_name	Scanner Anat
sform_code	1
sto_xyz:1	0.999466 -0.000520 -0.032767 -73.860321
sto_xyz:2	-0.000059 0.999844 -0.017685 -88.219193
sto_xyz:3	0.032771 0.017677 0.999307 -94.454788
sto_xyz:4	0.000000 0.000000 0.000000 1.000000
sform_xorient	Left-to-Right
sform_yorient	Posterior-to-Anterior
sform_zorient	Inferior-to-Superior
file_type	NIFTI-1+
file_code	1
descrip		6.0.5:9e026117
aux_file	OAS30015_MR_d2004

BASH

fslhd sub-OAS30015_T1w_brain_pve_0.nii.gz

OUTPUT

filename	sub-OAS30015_T1w_brain_pve_0.nii.gz

sizeof_hdr	348
data_type	FLOAT32
dim0		3
dim1		176
dim2		256
dim3		170
dim4		1
dim5		1
dim6		1
dim7		1
vox_units	mm
time_units	s
datatype	16
nbyper		4
bitpix		32
pixdim0		1.000000
pixdim1		1.000003
pixdim2		1.000000
pixdim3		1.000000
pixdim4		2.400000
pixdim5		0.000000
pixdim6		0.000000
pixdim7		0.000000
vox_offset	352
cal_max		0.000000
cal_min		0.000000
scl_slope	1.000000
scl_inter	0.000000
phase_dim	0
freq_dim	0
slice_dim	0
slice_name	Unknown
slice_code	0
slice_start	0
slice_end	0
slice_duration	0.000000
toffset		0.000000
intent		Unknown
intent_code	0
intent_name	
intent_p1	0.000000
intent_p2	0.000000
intent_p3	0.000000
qform_name	Scanner Anat
qform_code	1
qto_xyz:1	0.999466 -0.000520 -0.032767 -73.860321
qto_xyz:2	-0.000059 0.999844 -0.017685 -88.219193
qto_xyz:3	0.032771 0.017677 0.999307 -94.454788
qto_xyz:4	0.000000 0.000000 0.000000 1.000000
qform_xorient	Left-to-Right
qform_yorient	Posterior-to-Anterior
qform_zorient	Inferior-to-Superior
sform_name	Scanner Anat
sform_code	1
sto_xyz:1	0.999466 -0.000520 -0.032767 -73.860321
sto_xyz:2	-0.000059 0.999844 -0.017685 -88.219193
sto_xyz:3	0.032771 0.017677 0.999307 -94.454788
sto_xyz:4	0.000000 0.000000 0.000000 1.000000
sform_xorient	Left-to-Right
sform_yorient	Posterior-to-Anterior
sform_zorient	Inferior-to-Superior
file_type	NIFTI-1+
file_code	1
descrip		6.0.5:9e026117
aux_file	OAS30015_MR_d2004

Let’s look at the most important fields:

  • Data type (data_type): Note that some images (sub-OAS30015_T1w) are of integer datatype, while others (sub-OAS30015_T1w_brain_pve_0) are of floating point datatype. Integer means that the intensity values can only take on whole numbers - no fractions - raw image data is normally of this type. Floating point means that intensity values can be fractional - the result of applying most statistical processing algorithms to image data results in images of floating point type.
  • Image dimension (dim1, dim2,dim3): this is the number of voxels in the image in the x,y,z dimension. This means that we have a cube of imaging data in the file that contains dim1 columns, dim2 rows, and dim3 slices.
  • Image resolution (Voxel size) (pixdim1,pixdim2,pixdim3) : this tells us the size that each voxel represents (in mm) in the x,y,z dimension.

As an example to understand the difference between image dimension and image resolution, an MRI of a fruit fly or an elephant could contain 256 slices (same dim3 value), but one image would have to represent a much larger size in the real world than the other (different pixdim3).

  • Affine transformation (qform): this field encodes a transformation or mapping that tells us how to convert the voxel location (i,j,k) to the real-world coordinates (x,y,z) (i.e. the coordinate system of the MRI scanner in which the image was acquired). The real-world coordinate system tends to be defined according to the patient. The x-axis tends to go from patient left to patient right, the y axis tends to go from anterior to posterior, and the z-axis goes from top to bottom of the patient. This mapping is very important, as this information will be needed to correctly visualize images and also to align them later. Coordinate systems Figure from Slicer

An alternative command to fslinfo is fslhd, which displays a reduced set of properties about the images (mainly data type, dimension and resolution).

Neuroimaging data analysis


Generic blueprint of a neuroimaging study

The steps to conduct a neuroimaging study are very similar to any other scientific experiment. As we go through the workshop today, think about where a certain analysis or tool falls in this generic pipeline:

Step Aim Challenges and considerations
1. Data Acquisition Obtain good quality and consistent data Trade offs often necessary (e.g. time vs resolution). Optimize protocol for your research aim. We will use already acquired data from OASIS.
2. Data preprocessing Reduce noise and prepare data for further analysis Some steps are common across modalities (e.g. brain extraction, registration), others are modality-specific (e.g. motion correction, distortion correction). Requires careful checking.
3. Single-subject analysis Obtain measure of interest for each subject (often an image) Modality-specific. Examples of single-subject outputs are tissue-type segmentation maps, fractional anisotropy map.
4. Group-level analysis Compare single-subject results across groups Common step across modalities. Usually happens in standard space (i.e. after images from all subjects have been aligned to a reference image, called template).
5. Statistical inference Test reliability of results and generalizability to the population Common across modalities.

Neuroimaging data organization - Brain Imaging Data Structure (BIDS)

Neuroimaging experiments usually generate multiple images and non-imaging data. This can result in complicated data that can be arranged in many different ways. Despite the structure of a neuroimaging study is fairly standard, so far there is no consensus on how to organize and share data obtained in neuroimaging experiments. The Brain Imaging Data Structure (BIDS) is a framework for organizing data in a standardized way.

The main specifications regard how to structure data/metadata within a hierarchy of folders and how to name files. The data you will use in this workshop will mostly be organized according to this standard. If you are interested, you can find the details of these specifications in the BIDS starter kit.

Visualizing neuroimaging data - FSLeyes


FSLeyes (pronounced fossilize) is the FSL image viewer for 3D and 4D data. It does not perform any processing or analysis of images - that is done by separate tools. FSLeyes has lots of features to visualize data and results in a variety of useful ways, and some of these are shown in this introductory practical.

Here we provide a quick introduction to some FSLeyes features that you will be likely to use throughout the workshop, while other more specific features will be introduced at a later point. If you are already familiar with FSLeyes, feel free to skip this part and move on to another section of the workshop.

For a full overview of what FSLeyes can do, take a look at the FSLeyes user guide.

Getting started

Assuming you are still in the ~/data/ImageDataVisualization directory,

Start FSLeyes by typing in the terminal:

BASH

fsleyes &

What’s with the ampersand?

The & at the end of the line for any program means that the program you asked for (fsleyes) runs in the background in the terminal (or shell), and you can keep typing and running other commands while fsleyes continues to run. If you had not made fsleyes run in the background (i.e., if you had just typed fsleyes without the & at the end) then you would not be able to run any additional commands in that terminal until you either exited or killed fsleyes (although you could still type things, but they would not run).

In most instances, we would recommend using the & at the end of the fsleyes command

This is because fsleyes tends to be used interactively and may be open indefinitely, which means you won’t be able to run commands for a while if it is not ran in the background. For commands that run near instantaneously, there is no need to put the ampersand. In the following tutorials, we have tried to make it clear when a job should be run in the background.

Basic image viewing

FSLeyes by defaults opens in the ortho view mode. If you add image filenames on the command line (after typing fsleyes) it will load them all automatically, and you can also add many options from the command line. FSLeyes assumes that all of the images which you load share a single coordinate system, but images do not have to have the same field of view, number of voxels, or timepoints.

In FSLeyes, load in the image sub-OAS30015_T1w.nii.gz, by pressing File > Add from file and selecting the image. This image is a structural MRI T1-weighted scan.

Hold the mouse button down in one of the ortho canvases and move it around - see how various things update as you do so:

  • the other canvases update their view
  • the cursor’s position in both voxel and mm co-ordinates gets updated
  • the image intensity at the cursor is shown

You can interact with an orthographic view in a number of ways. Spend a couple of minutes trying each of these.

  • Click, or click and drag on a canvas, to change the current location.
  • Right click and drag on a canvas to draw a zoom rectangle. When you release the mouse, the canvas will zoom in to that rectangle.
  • Hold down the ⌘ key (OSX) or CTRL key (Linux), and use your mouse wheel to zoom in and out of a canvas.
  • Hold down the ⇧ key, and use your mouse wheel to change the current location along the depth axis (change the displayed slice) for that canvas.
  • You can middle-click and drag, or hold down the ALT key and drag with the left mouse button, to pan around.

The display toolbar

Display toolbar The display toolbar allows you to adjust the display properties of the currently selected image. Play around with the controls and note how the image display changes (but leave the “overlay type” as “3D/4D volume”).

The word “overlay” is interchangeable with “image”. FSLeyes uses “overlay” because it can also load some other non-image file types such as surface images.

  1. Overlay display panel: Clicking on the gear button ( gear icon ) opens a panel with more display settings.
  2. Overlay information: Clicking on the information button ( info ) opens a panel with information about the image.
  3. Overlay name: You can change the image name here (for display purpose only, it will not change the actual filename).
  4. Overlay type: FSLeyes allows some images to be displayed in different ways. This should be set to “3D/4D volume” most of the time.
  5. Opacity: Adjust the opacity (transparency) here.
  6. Brightness/contrast: Quickly adjust the image brightness and contrast here.
  7. Display range: Use these fields for fine-grained control over how the image data is coloured, instead of using the brightness and contrast sliders.
  8. Colour map: Choose from several different colour maps.
  9. Enable -ve colour map: If you are viewing an image that has both positive and negative values, this button allows you to enable a colour map that is used for the negative values.
  10. -ve colour map: Choose a colour map for negative values here.

If FSLeyes does not have enough room to display a toolbar in full, it will display left and right arrows ( left ), ( right ) on each side of the toolbar - you can click on these arrows to navigate back and forth through the toolbar.

The ortho toolbar

Ortho toolbar

The ortho toolbar allows you to adjust and control the ortho view. Play with the controls, and try to figure out what each of them do.

  1. View settings panel spanner icon : Clicking on the spanner button opens panel with advanced ortho view settings.
  2. Screenshot screenshot icon : Clicking on the camera button will allow you to save the current scene, in this ortho view, to an image file.
  3. Toggle canvases sagittal icon , coronal icon , axial icon : These three buttons allow you to toggle each of the three canvases on the ortho view.
  4. Canvas layout horizontal icon , vertical icon , grid icon : These three buttons allow you to choose between laying out the canvases horizontally (horizontal icon ), vertically (vertical icon ), or in a grid (grid icon ).
  5. Movie mode movie icon : This button enables movie mode - if you load a 4D image, and turn on movie mode, the image will be “played” as a movie (the view will loop through each of the 3D images in the 4D volume).
  6. Toggle cursor/labels add icon : This button allows you to toggle the anatomical labels and location cursor on and off.
  7. Reset zoom add icon : This button resets the zoom level to 100% on all three canvases.
  8. Zoom slider: Change the zoom level on all three canvases with this slider.

Multiple views: lightbox

Open a lightbox view using View > Lightbox View. If you drag the mouse around in the viewer you can see that the cursor position is linked in the two views of the data (the ortho and the lightbox views). This is particularly useful when you have several images loaded in at the same time (you can view each in a separate view window and move around all of them simultaneously). Lightbox toolbar

The lightbox view has a slightly different toolbar to the ortho toolbar.

  1. View settings panel spanner icon : Clicking on the spanner button opens a panel with advanced lightbox view settings.
  2. Screenshot screenshot icon : Clicking on the camera button will allow you to save the current scene, in this lightbox view, to an image file.
  3. Z axis sagittal icon , coronal icon , axial icon : These three buttons allow you to choose which slice plane to display in the lightbox view.
  4. Movie mode movie icon : This button enables movie mode.
  5. Slice range: These sliders allow you to control the beginning and end points of the slices that are displayed.
  6. Zoom: This slicer allows you to control how many slices are displayed on the lightbox view.
  7. Slice spacing: This slider allows you to control the spacing between consecutive slices.

Unlinking cursors

You can “unlink” the cursor position between the two views (it is linked by default). Go into one of the views, e.g., the lightbox view, and press the spanner button ( spanner icon ). This will open the lightbox view settings panel. Turn off the Link Location option, and close the view settings panel. You will now find that this view (the lightbox view) is no longer linked to the “global” cursor position, and you can move the cursor independently (in this view) from where it is in the other views.

Close the lightbox view for now (click on the small red circle or X at the very top of the view).

Viewing multiple images


Now load in a second image (sub-OAS30015_T1w_brain_pve_0.nii.gz) using File > Add from file. This image is a tissue segmentation image of the cerebrospinal fluid. In the bottom-left panel is a list of loaded images - the overlay list. Overlay list

The overlay list shows the images which are currently loaded into FSLeyes. When you select an image in this list, it becomes the currently selected image - in FSLeyes, you can only select one image at a time.

You can use the controls on the display toolbar to adjust the display properties of the currently selected image. Select the image you just loaded (sub-OAS30015_T1w_brain_pve_0.nii.gz), and use the display toolbar to change its colour map to Red-yellow.

The overlay list allows you to do the following:

  • Change the currently selected overlay, by clicking on the overlay name.
  • Identify the currently selected overlay (highlighted in blue).
  • Add/remove overlays with the + and - buttons.
  • Change the overlay display order with the ▲ and ▼ buttons.
  • Show/hide each overlay with the eye button ( eye icon ), or by double clicking on the overlay name.
  • Link overlay display properties with the chainlink button ( chain icon ).
  • Save an overlay if it has been edited, with the floppy disk button ( disk icon ).
  • Left-click and hold the mouse button down on the overlay name to view the overlay source (e.g. its location in the file system).

Image information


In the bottom right corner of the FSLeyes window you will find the location panel, which contains information about the current cursor location, and image data values at that location. Location panel

The controls on the left show the cursor location in world coordinates (millimetres). This coordinate system will change depending upon whether your image is in native subject space (scanner anatomical coordinates), standard template coordinates (e.g. MNI152), or some other coordinate space.

The controls in the middle show the cursor location in voxel coordinates, relative to the currently selected image. If the currently selected image is 4D (e.g. a time series image), the bottom control displays the currently selected volume (e.g. time point).

The area on the right displays the intensity value and voxel location at the current cursor location for all loaded images. Note that if you have images with different resolutions loaded, the voxel location will be different for each of them.

Viewing Atlases


It is often useful to look at images in standard space. This means that images are aligned (registered) to a reference template so that each coordinate corresponds to the same point in the brain in all images. This allows to perform group level analyses.

Let’s have a look at one of the most used templates, the MNI152.

  • Unload all the images from fsleyes clicking on the minus (-) icon in the Overlay list panel (or open a new instance if you closed it before), press File > Add standard and select the image MNI152_T1_1mm.

    As you can see it looks very similar to the T1w image we looked at earlier. This is basically an average T1w.

    Because we are in standard space, we can turn on the atlas tools with Settings > Ortho View 1 > Atlases.

  • Now as you click around in the image you can see reporting of the probability of being in different brain structures. You might want to resize the different FSLeyes panels to increase the size of the Atlas information space (in general you do this by dragging around the edges of the different FSLeyes panels).

    The atlas panel is organized into three main sections - Atlas information, Atlas search, and Atlas management. These sections are accessed by clicking on the tabs at the top of the panel. We will only cover the first two sections in this introductory practical.

Atlas information

The Atlas information tab displays information about the current display location, relative to one or more atlases: Atlas information panel The list on the left allows you to select the atlases that you wish to query - click the check boxes to the left of an atlas to toggle information on and off for that atlas. The Harvard-Oxford cortical and sub-cortical structural atlases are both selected by default. These are formed by averaging careful hand segmentations of structural images of many separate individuals.

The panel on the right displays information about the current display location from each selected atlas. For probabilistic atlases, the region(s) corresponding to the display location are listed, along with their probabilities. For discrete atlases, the region at the current location is listed.

You may click on the Show/Hide links alongside each atlas and region name to toggle corresponding atlas images on and off.

The Atlas search tab allows you to browse through the atlases, and search for specific regions. Atlas search panel

The list on the left displays all available atlases - the checkbox to the left of each atlas toggles an image for that atlas on and off.

When you select an atlas in this list, all of the regions in that atlas are listed in the area to the right. Again, the checkbox to the left of each region name toggles an image for that region on and off. The + button next to each region moves the display location to the (approximate) centre of that region.

The search field at the top of the region list allows you to filter the regions that are displayed. Atlas region search

When you type some characters into the search field, the region list will be filtered, so that only those regions with a name that contains the characters you entered are displayed. The atlas list on the left will also be updated so that any atlases which contain regions matching the search term are highlighted in bold.

Challenge

Use the atlas search feature to locate the thalamus (left or right).

Here are the screenshots you should see: Left Thalamus

Right Thalamus

For more information about the atlases available please refer to the FSL Wiki.

Quit FSLeyes when you have finished looking at the atlases.

BONUS EXERCISE: Viewing different imaging modalities

So far we have seen examples of MRI T1-weighted scans (T1w). In research as well as in clinical setting, we acquire multiple imaging modalities from the same individual to look at different brain characteristics. Even if we acquire all the modalities in the same session, the images may differ in orientation and resolution.

BASH

cd ~/data/ExtraStructuralMRI
ls

Let’s take two imaging modalities from a different participant: sub-OAS30003_T1w.nii.gz and sub-OAS30003_FLAIR.nii.gz

  • Do they have the same dimension?
  • Do they have the same resolution?

Now let’s have a look at them in FSLeyes:

BASH

fsleyes sub-OAS30003_T1w.nii.gz sub-OAS30003_FLAIR.nii.gz &

Change the intensity range for both images to be between 0 and 1000. Show/hide images with the eye button ( eye icon ), or by double clicking on the image name in the overlay list.

  • Do they have the same orientation?
  • Which brain characteristics are more visible in the T1w and which are more visible on FLAIR?
  • Use fslhd to get information on dimension and voxel size.
  • Look at the location panel to help with information about orientation

Do the T1 and the FLAIR have the same dimension?

No-Using fslhd, we can see that the dimensions (dim1, dim2, and dim3) of the T1 are 176 x 240 x 161 and the dimensions of the FLAIR image are 256 x 256 x 35.

Do the T1 and the FLAIR have the same resolution?

No-From the same fslhd commands, the resolution can be found in the fields pixdim1, pixdim2, and pixdim3. For the T1 the resolution is 1.20 x 1.05 x 1.05 mm. For the FLAIR it is 0.859 x 0.859 x 5.00mm

Do the T1 and the FLAIR have the same orientation?

No In the bottom right panel you should see the warning: “Images have different orientations/fields of view”

What brain characteristics are more visible in the T1w and which are more visible on FLAIR?

On T1w, grey and white matter are more easily distinguishable. On FLAIR, brain lesions – white matter hyperintensities – are more clearly visible

BONUS EXERCISE: DICOM to NIfTI

As discussed earlier, if you have received medical imaging data from a hosptial it is likely in DICOM format. However, most of the software you are likely to use wants medical images in a more manageable format, typically NIfTI images. There are many ways to convert between the two, but probably the most widely used is dcm2niix).

You can find the sample data in ~/data/ImageDataVisualization/DICOM. Let’s first change into this directory

BASH

cd ~/data/ImageDataVisualization/DICOM

If you list the contents, you will see a single folder called Subject01

Let’s first make a directory for the Nifti output

BASH

mkdir Nifti
  1. How do we know how to use this command?
  2. Construct a command to convert the images and put them in the directory data/ImageDataVisualization/DICOM/Subject01/Nifti
  3. Figure out what option to use to store a compressed gzipped-version of the NIfTI file.
  4. Try out some different options to make the name easier to manage.
  5. Look at the converted NIfTI images in fsleyes. What modalities are they?

We covered how to get help for a command in an earlier section.

  1. To get help, we use the -h option:

    BASH

    dcm2niix -h
  2. The simplest command to do this is

    BASH

    dcm2niix -o Nifti Subject01
  3. To zip the file, we use the -z function:

    BASH

    dcm2niix -z y -o Nifti Subject01
  4. To change the naming structure, we use the -f function. How you name them tends to be your personal choice, and many people choose to use the BIDS standard for naming the data.

    BASH

    dcm2niix -f %i_%s_%d -z y -o Nifti Subject01

In the next episode on structural MRI, we will learn how to align (register) the two images together to be able to look at the same point in the brain in both images.

Additional material


For a more extensive tutorial on FSLeyes features, please refer to the FSL course - FSLeyes practical

FSLeyes manual: https://open.win.ox.ac.uk/pages/fsl/fsleyes/fsleyes/userdoc/index.html

References


Key Points

  • Images are sheets or cubes of numbers.
  • Medical image data is typically stored in DICOM or Nifti format. They include a header that contains information on the patient and/or the image characteristics.
  • An affine transformation maps the voxel location to real-world coordinates.
  • Medical image viewers allow to navigate an image, adjust contrast, and localise brain regions with respect to an atlas.

Content from Structural MRI: Bias Correction, Segmentation and Image Registration


Last updated on 2025-01-14 | Edit this page

Overview

Questions

  • How do I process and quantify structural MRI scans?
  • How do I register MRI with other modalities?
  • How do I get key metrics out?

Objectives

  • Perform basic pre-processing steps, such as bias correction and tissue segmentation
  • Assess some common imaging artefacts in the sturctura MRI
  • Discover how to align and quantify neuroimaging data at regional level

Introduction


In this section, you will be learning how to process and quantify structural MRI scans. T1-weighted structural MRI scans are the “workhorse” scan of dementia research. They provide high-resolution, detailed pictures of a patient’s anatomy, allowing researchers to visualize where atrophy caused by Alzheimer’s disease or other dementias is occurring. In addition, it provides anatomical reference to other imaging modalities, such as functional MRI and positron emission tomography (PET), that provide lower-resolution maps of brain function and pathology, so that regional quantification of key areas can be assessed in these scans.

We will be using two widely used software packages: SPM and FSL. These packages provide analysis and visualization functionality of structural and functional neuroimaging data, and they can be used in both cross-sectional and longitudinal studies. The subsequent outputs from these pipelines can be used in the quantification of other imaging modalities.

After the course, you will be able to perform basic measurements relevant to dementia research from structural MRI brain scans.

We will use the SPM and FSL tools to perform:

  • image visualization of analysis outputs,
  • intensity inhomogeneity correction,
  • structural MRI segmentation,
  • quantification of volumetric outputs, and
  • registration to a standard space atlas.

Opening up an image


We are going to be working in the StructuralMRI subfolder under data in your home directory.From the previous lesson, you learned how to view and navigate images.

Clicking on the Applications in the upper left-hand corner and select the terminal icon. This will open a terminal window that you will use to type commands Launch the terminal

To get started, open up FSLeyes from the terminal window

BASH

fsleyes & 

Now we choose the file sub-OAS_30003_T1w.nii by going to the File menu and choosing the Add Image command Add fileChoose File

Exercise 1

Close fsleyes and then re-open the viewer. This time use the other image in the folder sub-OAS30217_T1w.nii.

What differences do you notice?

Run Bias Correction and Tissue Segmentation


Small variations in the magnetic field can result in changes in the image intensity that vary slowly spatially. These variations are not due to anatomical differences. We can visually identify this image inhomogeneity in the white matter, where voxels in one part of the brain might be so affected by it that they have similar intensity values as grey matter voxels in other brain regions. However, the intensities in the white matter voxels should be more or less uniform throughout the brain. Any remaining inhomogeneity in the image can significantly influence the results of automated image processing techniques, so we need to correct for these effects. The process that removes this image inhomogeneity is typically referred to as bias correction.

The next step is to reliably identify what type of tissue each voxel contains. While the resolution of structural MRI is quite high (typically around 1 mm), there is still the likelihood that a voxel will contain more than one tissue in it. The process of tissue segmentation looks at the voxel intensity, compares it to its neighbours and prior information about what tissues we would expect to have in that voxel and assigns a probability that the voxel contains that tissue. It typically generates n different volumes, where n is the number of tissue types you want to use to classify the brain. We typically focus on three tissue probability maps in particular:

  • Grey matter (GM),
  • White matter (WM), and
  • Cerebrospinal fluid (CSF)

SPM performs the bias correction and tissue segmentation steps simultaneously. Follow the steps below to obtain bias-corrected images and tissue probability maps.

Bias Correction and Segmenation Steps

  1. Launch SPM

    BASH

    spm pet &
    Launch SPM
  2. SPM will then create a number of windows. You want to look at the Main Menu Window that has all of the buttons. SPM windows

  3. From main menu, select the Segment button. This will launch a window known as the batch editor, where you can adjust settings on the pipeline to be run. SPM Batch editor

  4. Edit the options for segmentation:

    1. Under Data->Channels->Volume, click on “Specify…”. Specify volumes
    2. In the dialog box that opens up, please navigate to the folder data and then StructuralMRI. Then select the first image sub-OAS30003_T1w.nii. Once you click on it, you will notice the file move down to the bottom of the box which represents the list of selected files. Choose T1 image
    3. Click the Done button
    4. Back in the batch editor, under Data->Save Bias Corrected, please choose “Save Field and Corrected” Choose bias correction option
    5. Under the Tissues section, please make sure that the first three tissue types, which represent GM, WM, and CSF, have the native tissue subfield set to native, while the final three tissue types (4-6), which represent non-brain structures, have the native tissue subfield set to None. Native segmentation
  5. Click the green run button to start! It should take about 5-10 minutes. You will see a lot of other things happening in other windows. The terminal will say Done - Segment when it has finished.

When you are using these workflows for your actual research, we highly recommend that you save the SPM pipelines so that you could run them again on the exact same data with the exact same settings. You can do that by selecting Save batch from the File menu. This will save the batch, or pipeline, as a file with a .mat extension. You can load this file back in by selecting the Load batch from the File menu and selecting the file you save.

Quality check


The quality check is an important part of any analysis. We are going to visualize the outputs from SPM Segment and make sure that the bias correction and segmentation have worked.

Bias correction

  1. Open up the original image sub-OAS30003_T1w.nii using FSLeyes

    BASH

    fsleyes sub-OAS30003_T1w.nii &
  2. Change the image lookup table to NIH [Brain colors] FSL eyes with NIH colormap

  3. Then change the image minimum to 40 and the maximum to 600. This means that all intensities 40 and below will map to the first color in the lookup table, and all voxels 600 and above will map to the last color. The white matter should be yellow to red. Change min and max intensity

  4. Next add the bias corrected image, which is called msub-OAS30003_T1w.nii. Change the lookup table to NIH as you did in Step 2. Change the minimum to 40 and maximum intensity to 500 similar to what you did in Step 2 and 3. Bias in image using NIH map

When you add this image, it will overlay on top of the original image. Think of this new image a completely opaque, so that you no longer see the original one. If you want to see the original one, then you need to either turn it off using the eye icon ( eye icon ) right by the file, or you need to turn the opacity (slider near the top of the screen which is marked opacity.)

Exercise 2

Use the eye icon in the overlay list right next to the file msub-OAS30003_T1w.nii and turn this image off and on many times. This will allow you to compare with the original image.

What do you notice about the image in the white matter area when comparing the bias correct and original image?

Tissue segmentation

Now that we are happy with the bias correction, lets look at the tissue segmentation.

  1. Use the icon to turn off the original image. Select the bias corrected image and make sure the colormap is back to the first option “Greyscale” Bias correted image in greyscale
  2. Now add the grey matter probability image c1sub-OAS30003_T1w.nii.
  3. Choose the probability map and set the lookup table to Red. Change the minimum intensity to 0.2 and the maximum intensity to 0.9. This will eliminate some noise from very low probability voxels.
  4. Use the opacity slider to make the grey matter probability map transparent. Looking at grey matter image
  5. Look around the image, zoom in places, and try turning the grey matter probability map off and on. The goal is to make sure the grey matter probability map is not:
    1. Missing any grey matter
    2. Not including other tissue (WM, CSF, non-brain tissue that has a similar intensity to GM)

Exercise 3

Now do the same steps with the white matter image c2sub-OAS30003_T1w.nii and the cerebrospinal fluid image c3sub-OAS30003_T1w.nii. Choose different color colormaps.

Do these images look like they have identified the white matter and CSF in the T1 weighted image correctly?

You should have an output that looks something like this. Tissue segmentation check

Obtaining volume


One thing that we are often interested in is to obtain the actual volume of grey matter, or a particular brain region. There are helpful utilities in FSL to extract the volume from the tissue probability maps. First we will change our working directory to the Structural MRI folder:

BASH

cd ~/data/StructuralMRI

Then we will run this command to get the total grey matter volume:

BASH

fslstats c1sub-OAS30003_T1w.nii -V

OUTPUT

719954 961026.312500

This will produce two numbers. The first number is the number of voxels in the grey matter. These voxels as discussed earlier have physical dimensions indicating how the volume that each individual voxel represents. So the second value indicates the total volume of the grey matter (usually represented in units of cubic millimeters, 1\(ml\) = 1000\(mm^3\)).

Coregistration to standard space


MRI scans can be acquired in any orientation. Even when we think we are getting a sagittal or coronal acquisition, the patient may end up in the scanner at a slant. This makes it difficult to identify key anatomical landmarks. We may also want to compare common anatomical structures across a whole sample of subjects. The main solution to this is to use image registration to orient our images and align them with a standard anatomical coordinate system. In this case, we will be aligning our data to the Montreal Neurological Institute MNI152 atlas. We are not looking to perform an exact voxel to voxel match between our image and the atlas. Instead, we just want to align the images such that the orientation and the relative size are aligned.

Skull stripping

Before we can perform the registration, we will use the tissue probability maps to skull strip the image. Skull stripping removes the non-brain tissue (scalp, dura, neck, eyes, etc) from the image. Before we run the commands, let’s first check what working directory we are in by using the command pwd:

BASH

pwd

OUTPUT

/home/as2-streaming-user/data/StructuralMRI

If you have a different output from the above, then run the following command:

BASH

cd ~/data/StructuralMRI

First we will use the FSL utility fslmaths to create a brain mask by using the tissue probability maps from SPM. fslmaths is a great swiss-army knife utility to do lots of helpful little image processing bits.

BASH

fslmaths c1sub-OAS30003_T1w.nii -add c2sub-OAS30003_T1w.nii -add c3sub-OAS30003_T1w.nii -thr 0.5 -bin sub-OAS30003_T1w_brain_mask.nii

Let’s break this command down a little bit:

  • First, we state the command we want to run fslmaths
  • We then specify our input image, the GM map c1sub-OAS30003_T1w.nii
  • We then specify the first operation -add
  • We then specify what we want to add to our input image. In this case, it is the WM map c2sub-OAS30003_T1w.nii. The resulting image would contain the probability that a voxel is either GM or WM.
  • We then specify that we want to add another image, and this time it is the CSF map. This image now holds the probability that a voxel is GM, WM, or CSF, which are the three main tissue types in the brain that we want to process.
  • We will then threshold this image at 0.5 using the -thr 0.5 option. This says to only keep voxels who have a probability of 0.5 or greater. All other voxels are set to 0.
  • Our final operation is to binarize the image. Any values that are not zero are set to one. This creates a mask which says whether the voxel is inside (1) or outside (0) of the brain.
  • Finally, we save our results into the new image file sub-OAS30003_T1w_brain_mask.nii

Now that we have created a mask, we are going to remove all the information outside of the mask using the following command:

BASH

fslmaths msub-OAS30003_T1w.nii -mas sub-OAS30003_T1w_brain_mask.nii.gz msub-OAS30003_T1w_brain.nii

This command masks our bias corrected image with the brain mask and makes a new file which has the name msub-OAS30003_T1w_brain.nii. Take a look at the image in fsleyes. Skull stripped image

We will then use the FSL registration program FLIRT to align our image to the standard space MNI152. Please follow the steps below:

  1. On the terminal window, please type in the following command Flirt
  2. This will open a dialog box. We will change the following settings:
    1. For reference image, click on the folder icon and choose the image MNI152_T1_1mm_brain
    2. For the input image, please select the mask we created above msub-OAS30003_T1w_brain.nii
    3. For the output image, please type in a new name msub-OAS30003_T1w_brain_MNI.nii The final command setup should look like the screenshot below. FLIRT window

If your window looks like this, then click the Go button at the bottom, in the terminal, you will see the command line program that would run what you have set up in the dialog box. If you were to select that command and run it in the terminal it would do the same thing.

Quality check

Let’s open fsleyes and open the output from the co-registration msub-OAS30003_T1w_brain_MNI.nii. T1w in MNI space

Now click on the Add Standard function. This is where fsleyes keeps all of the standard atlases and templates so that you can quickly access them. Add standard function

Select the MNI152_T1_1mm_brain from this list of files. Choose MNI image

We can now check if our image is registered by flicking back and forth between the MNI image and our image.

Stretch exercises


If you have completed all of the above and want to keep working on more structural imaging data, please try the exercises below.

BONUS Exercise 1

Extract the volumes from the WM and CSF probability maps for sub-OAS30003_T1w.nii.

What are the three tissue volumes?

BASH

# This is the same command as above to get the GM volume out
fslstats c1sub-OAS30003_T1w.nii -V
# Now for the WM volume
fslstats c1sub-OAS30003_T1w.nii -V
# Finally, for the CSF volume
fslstats c1sub-OAS30003_T1w.nii -V

OUTPUT

719954 961026.312500
462937 617948.687500
599177 799807.750000

BONUS Exercise 2

The volumes that come out of fslstats assume that each voxel is completely full of GM, even though for some voxels the probability may be very small. That can lead to inaccuracies, so there are a couple of ways we can more accurately measure from tissue probability maps.

Before we start, let’s make sure we are in the right working directory by using the cd command.

BASH

cd ~/data/StructuralMRI

The first approach is to only count voxels with a majority of GM. So we will threshold by the value of 0.5 before calculating our volume.

BASH

fslstats c1sub-OAS30003_T1w.nii -l 0.5 -V

OUTPUT

465968 621994.569978

The second approach is to get the mean and volume of the all the non-zero voxels.

BASH

fslstats c1sub-OAS30003_T1w.nii -M -V

OUTPUT

0.641076 719954 961026.312500

This will produce three numbers:

  1. The mean of the non-zero voxels
  2. The number of voxels greater than zero.
  3. The volume of the voxels greater than zero.

If you multiply (1) by (3), this would be what we call the probabilistic volume of the GM and it accurately accounts the amount of GM in each voxel, which should give you a volume of around 616,090.

How do these volumes compare with the original volume you obtained?

BONUS Exercise 3

Let’s take a look at our other image sub-OAS30217_T1w.nii. Perform the same steps as you did for the first image:

  • Segmentation
  • Skull Stripping
  • Co-registration to standard space Run the same skull stripping and registration as you have done before. Now open up both standard space images in fsleyes

What do you observe about the images?

BONUS Exercise 4

Let’s now try to co-register two imaging modalities from one participant (within-subject registration)

BASH

cd ~/data/ExtraStructuralMRI
ls

At the end of the previous session on data visualization, you looked at a T1-weighted scan and a FLAIR scan from the same participant (sub-OAS30003_T1w.nii.gz and sub-OAS30003_FLAIR.nii.gz, load them again in FSLeyes if you need a refresh). As you will have noticed, they have different dimensions, resolution and orientation, so if we want to look at the same point in the brain in both images we need to align them.

First, we need to choose which image we want to keep unchanged (reference) and which one we want to align to the reference (input). Let’s assume we want to register the FLAIR image to the T1. We have already prepared a skull-stripped version of the images for you so they are ready to be aligned with FLIRT.

The way to do this is very similar to what you did before to co-register a T1 to standard space. Please follow the steps below:

  1. On the terminal window, type Flirt
  2. This will open the dialog box you used before. The new settings are:
    1. For reference image, delete the text in the box and type ~/data/ExtraStructuralMRI, then click on the folder icon and choose the image sub-OAS30003_T1w_brain.nii.gz
    2. Change the Model/DOF (input to ref) to Rigid Body (6 parameter model)
    3. For the input image, click on the folder icon and choose the image sub-OAS30003_FLAIR_brain.nii.gz
    4. For the output image, please type in a new name sub-OAS30003_FLAIR_to_T1w.nii.gz

The final command setup should look like the screenshot below: Coregistration of T1 and FLAIR

If your window looks like this, then click the Go button at the bottom, in the terminal, you will see the command line program that would run what you have set up in the dialog box. If you were to select that command and run it in the terminal it would do the same thing.

Once done, open the result in FSLeyes:

BASH

fsleyes sub-OAS30003_T1w_brain.nii.gz sub-OAS30003_FLAIR_to_T1w.nii.gz &

We can now check if our image is registered by flicking back and forth between the T1 image and the FLAIR registered image.

Can you think of why the registered FLAIR image appears blurred in the sagittal and coronal plane?

Now try to do the opposite: co-register the T1 to the FLAIR.

What differences do you notice with respect to the previous case (FLAIR co-registered to T1)?

Can you think of different cases where you would want to use T1 or FLAIR as your reference?

Key Points

  • Structural MRI provides high-resolution anatomic information for neuroimaging analysis
  • Bias correction removes image inhomogeneities
  • Tissue segmentation identifies key tissue types (grey matter, white matter, cerebrospinal fluid) from T1 weighted images
  • Co-registration of MRI to other modalities can be used to analyse these images at a regional level.

Content from Processing and analysing PET brain images


Last updated on 2025-01-14 | Edit this page

Overview

Questions

  • What does positron emission tomography measure?
  • What are some common processing steps used for PET quantification?
  • How can I extract key measurements of tracer binding from dynamic PET data?

Objectives

  • Understand the basic structure of 4D PET data and key variables needed for quantification.
  • Explain the differences between static and dynamic acquisitions, and what information can be derived from them.
  • Perform the basic processing steps involved in PET image quantification and analysis.

Introduction


This tutorial is an introduction to working with PET data in the context of AD neuroimaging. Due to the limited time, we will not have time to fully recreate a typical image processing pipeline for PET data, but have included enough steps that you’ll be able to perform the minimum steps needed to generate a parametric SUVR image. The provided dataset includes T1-weighted MRI, [18F]MK-6240 tau PET and [11C]PiB amyloid PET scans for a single subject at a single timepoint. For ease, the T1-weighted image was already rigidly aligned and resliced to a 1mm isotropic image in MNI152 space. The provided PET scans were acquired using different protocols to demonstrate two common ways that PET data can be acquired. The tutorial will explain the differences between these types of acquisitions and what information can be derived from them.

Background: PET data, image processing, and quantification

PET data are collected on the scanner typically in list mode. This is quite literally a logged record of every event the scanner detects, but this type of data is not all that useful for interpretation. Viewing the images requires that the list mode data be reconstructed. The provided images have already been reconstructed with the widely-used Ordered Subset Expectation Maximization (OSEM) algorithm with common corrections (scatter, dead time, decay, etc.) already applied during the reconstruction. Notably, no smoothing was applied during the PET reconstruction.

Gaining familiarity with 4D PET data


Prepare working directory

  1. Open a new terminal window and navigate to the directory with the unprocessed PET NIfTI images and data /home/as2-streaming-user/data/PET_Imaging.

  2. Use ls to view the contents of this directory

  3. Use cd to change your working directory to the following location:

    BASH

    cd /home/as2-streaming-user/data/PETImaging/UnprocessedData

View PET metadata

View the information in the .json file for MK-6240 and PiB images by opening the .json files for the MK-6240 and PiB images. For example, type the following into the terminal:

BASH

gedit sub001_pib.json

Open up multiple terminal windows to view the .json file contents side-by-side.

  • Note that the Time section differs with regard to the scant start and injection start times. Namely, the MK-6240 scan starts 70 minutes after tracer injection, whereas the PiB image starts at the same time as the tracer injection. The latter acuisition protocol is often referred to as a full dynamic acquisition and enables us to calculate more accurate measurements like distribution volume ratio (DVR) and often additional parameters from the time-series data (e.g., \(R_1\) relative perfusion). If we had arterial data available, we could also use the full dynamic scan to perform kinetic modeling.

  • Also note the framing sequences differs between the two tracers. MK-6240 is using consecutive 5-minute frames whereas PiB starts with 2-minute frames for the first 10 minutes and then 5-minute frames thereafter.

  • For both images, the decay correction factors correspond to the scan start time (indicated by “START” in the DecayCorrected field). This may or may not have consequences for how we quantify the image. For example, if we wanted to calculate the standard uptake value \(SUV = C(t) / InjectedDose * BodyMass\),

    we would need to decay correct the MK-6240 scan data to tracer injection but this is not needed to calculate SUV for the PiB scan because the scan started with tracer injection.

Now close the .json files in gedit.

View 4D PET data

  1. Make sure you are in the right working directory

    BASH

    cd /home/as2-streaming-user/data/PET_Imaging/UnprocessedData
  2. Open sub001_pib.nii using FSLeyes

    BASH

    fsleyes -ms sub001_pib.nii &

    THe -ms option provides better viewing of 4D image data on this VM. You should add this whenever working with dynamic PET data, DWI or fMRI data.

  3. Set the minimum threshold to 0 and the maximum threshold to 30,000 Bq/mL

  4. You are currently viewing individual PET frames that have not been denoised in any way. Notice the high noise level in the individual PET frames. This is why we often apply some type of denoising algorithm to the PET data before processing and quantification.

  5. Use your cursor to scroll around the image and observe the values in voxels in the brain. These values are activity concentrations given in \(Bq/mL\), where Bq (Becquerel) is the SI unit for radioactivity and is expressed as a rate (counts per second). In PET, the noise in the image is proportional to the inverse of the square root of the counts. Thus, the more counts detected, the less noisy the image will appear.

  6. Use the Volume field to advance through the PET frames from the first frame (index = 0) to the last frame (index = 16). Moving higher in volume indices is moving forward in time, like a 3D movie, as the tracer distributes throughout the brain over time. Note how the distribution of the tracer changes from the first frame to the last frame. The tracer distribution in early frames of this acquisition largely reflects the tracer perfusing the brain tissue whereas later frames largely reflect a combination of free tracer and specific and non-specific tracer binding. You may need to adjust the upper window level to a lower value to more clearly visualize the later PET frames. You’ll also likely notice that the later frames are noisier than the beginning frames, again, this has to do with counting statistics and the reduced counts detected over time due to radioactive decay and lower tracer concentration in the brain at later timepoints.

  7. Close the 4D PET image in FSL by selecting the image in the Overlay list at the bottom of the page and clicking Overlay -> Remove from the menu at the top of the page.

Creating a SUM PET image


We’ll create two different SUM images from the PiB scan; one for early- and one for late-frame data to visualize the differences in tracer distribution between these timepoints more easily. The early frame data will SUM 0-20 minutes post-injection whereas the late frame will SUM 50-70 minutes post-injection. We’ll do the late-frame image first and then the early-frame image. You can reference the FrameTimeStart and FrameTimeEnd fields in the .json file to determine which frames correspond to 0-20 min and 50-70 min postinjection.

Using ImCalc to Sum Frames

  1. Open SPM12 by typing spm pet & in the command line.

  2. Select the ImCalc module. SPM ImCalc module

  3. For each variable in the GUI, you will need to specify values using the Specify button. Use the values specified below for each variable listed.

    • Input Images – here we want to specify the input images that we are going to use to perform the image calculation. The order that the images are specified will determine the order they are referred to in the expression field below (e.g., the first image is i1, the second image is i2, etc.,) However, SPM will only load one frame at a time for 4D data, so each frame needs to be specified individually using the Frames field. The frame number is then delineated by the filename followed by a comma and the frame number. Note that SPM uses index 1 for the first frame, which corresponds to index 0 in FSL.

    • Enter the frame number corresponding to the frame that spans 50-55 min post-injection (frame number 14) and hit enter. Click on the sub001_pib.nii,14 file to add this to the list. Choose Frame 14

    • Enter the next framenumber and similarly add it to the list. Repeat until you’ve added the last four frames of the PiB image corresponding to 50-70 min post-injection (frames 14, 15, 16, and 17). Note the order you input the images corresponds to i1, i2, … in the Expression field later. Once you’ve selected the last four frames click Done to finalize the selection. Choose all

    • Output Filename – enter text sub001_pib_SUM50-70min.nii ImCalc output

    • Output Directory – specify the output directory for the file. If you leave this blank, SPM will output the file in the present working directory (i.e., the directory that SPM was launched from in the command line)

    • Expression – because the frames are all 5 minutes long at this part of the sequence, we can simply take the average to sum the last 20 minutes of counts.

      Enter the expression

      MATLAB

      (i1 + i2 + i3 +i4)/4

      Note that taking the average of these frames is equivalent to summing all of the detected counts across the frames and dividing by the total amount of time that has passed during those frames (i.e., 20 min). ImCalc expression

    • Data Matrix, Masking, Interpolation can all use default values

    • Data Type – specify FLOAT32 Choose float image

  4. Verify ImCalc inputs and then run the batch by pressing the green play button at the top of the batch editor. This should create a new NIfTI file with the late-frame summed data.

  5. Open the 50-70 min SUM image in FSLeyes and note the difference in noise properties vs. those you observed in a single frame. (note: you will likely need to use different thresholding to see the image; e.g., 0-20,000 Bq/mL) The SNR has improved because we are now viewing an image with more total counts. Notice that you can now more clearly see some contrast between the precuneus and the adjacent occipital cortex in the sagittal plane just to the left or right of mid-sagittal. You can similarly see differences in intensity between much of the cortex and the cerebellar GM, a common reference region used for amyloid PET as it typically has negligible specific binding in the cerebellum.

    Discussion

    Do you think this person is amyloid positive or negative?

  6. Repeat the above steps to generate the SUM image for the early frame data. Make sure to remove the previous volumes before adding the new volume in the Input Images. You will need to use the first seven frames corresponding to the first 20 min of data. Note that the frames are not all the same duration and a straight average is no longer equivalent to summing all of the counts and dividing by the total time. How can we use a weighted average to account for the differences in frame durations between the first five and last two frames of the first 20 minutes?

    MATLAB

    (i1*2 + i2*2 + i3*2 + i4*2 +i5*2 + i6*5 + i7*5) / 20
  7. Name this file sub001_pib_SUM0-20min.nii

  8. Open the 0-20 min SUM image in FSLeyes and compare to the 50-70 min SUM image. Note the differences in GM/WM contrast between the images and the differences in noise properties. You will likely have to change the max intensity settings in both images to be able to observe the differences in contrast.

  9. Close the SPM batch editor

Image Smoothing


As you can see from viewing the unsmoothed images, they are still quite noisy, particularly at the voxel level. In this section we’ll use a simple Gaussian smoothing kernel to reduce the voxel-level noise. We are really trading voxel variance for co-variance between voxels. This means that the activity concentration in any particular voxel will have lower variance, but will be more influenced by neighboring voxels. Thus, we are degrading the spatial resolution of the image slightly to improve the noise characteristics. The size of the Gaussian smoothing kernel is typically specified as the full-width of the kernel at half the maximum value of the kernel.

Apply smoothing to SUM images

  1. Click on the Smooth button to launch the Smooth module in SPM and use the following inputs:
    • Image to Smooth - Specify the two SUM images (you can do both at the same time)
    • FWHM – 4 4 4 (this specified an isotropic 4 mm full-width half Gaussian smoothing kernel)
    • Data Type – Same
    • Implicit Mask – No
    • Filename prefix – ‘s’ (this prepends an “s” onto the filename to indicate the newly created image was smoothed)
  2. Press the green play button to run the smoothing module.
  3. Close the SPM batch editor.
  4. View the resultant smoothed images in FSL (the ones with an ‘s’ prefix in the filename). Note the reduction in voxel-level noise but also the slight reduction in spatial resolution.

Intermodal Registration


While we can quantify PET images without anatomical data like T1-weighted MRI, we can gain considerable regional detail if we align our PET images to an anatomical reference. This section will use SPM12’s Coregister module to register the PET data to a T1-weighted MRI. We’ll first view the problem in FSL to demonstrate why we need to register the images and then perform the co-registration to align the PET data to the T1-w MRI.

View images in FSL

  1. Open the rsub001_t1mri.nii and in FSL. Use the down arrow next to the Overlay list to move the T1 to the bottom of the list. Select the T1 and set the window min and max to 0 and 1,400, respectively.
  2. Select the smoothed 50-70 min SUM PIB image in the viewer and adjust the min and max window level to 0 and 30,000 respectively. Select the Hot [Brain colours] colormap for the PET image. Reduce the Opacity slider down until you can see both the MRI in the background and the PET image in the foreground.
  3. Notice that the images are not aligned. Thus, we cannot yet use the structural MRI to extract regional PET data. We first need to register the PET image to the MRI.

Coregister PET to T1-weighted MRI.

Caution: SPM will overwrite the transformation matrix in the Source Image and Other Image! As such, we will first create a safe copy of our SUM and 4D images before running the Coregistration module).

  1. Create copies of the smoothed late-frame SUM image and the 4D pib image.
    1. In the terminal, create a new directory called “safe” in your working directory.

      BASH

      mkdir safe
    2. Copy the ssub001_pib_SUM50-70min.nii and sub001_pib.nii images to the safe directory using the cp command in the terminal.

      BASH

      cp ssub001_pib_SUM50-70min.nii safe/ssub001_pib_SUM50-70min.nii
  2. Open the Coregistration module by selecting Coregister (Est & Res) from the Spatial pre- processing drop down. This function will estimate the parameters needed to align the source image to the reference image, write those transformations to the NIfTI headers for those files and will create new images with the image matrices resliced to align voxel- to-voxel with the reference image.
    • Select rsub001_t1mri.nii for the reference image.
    • Select the smoothed 50-70 SUM image for the source image. ssub001_pib_SUM50-70min.nii
    • Optional: if you’d like to also apply this registration to the 4D data, Select the 4D data for Other Images. You will need to enter each volume in the 4D image to apply the transformation matrix to each frame in the time series, or you can specify a subset of the frames to create a 4D image with just some frames included.
    • We will use default values for Estimation Options
    • In the Reslice Options Set Interpolation to “Trilinear” and masking to “Mask Images”
  3. Press the green play button to register the PET data to MRI.

Review registration results

  1. In FSL, remove all of the loaded images using the Overlay>Remove All command.
  2. Open the T1-weighted MRI and the resliced registered SUM PET image rssub001_pib_SUM50-70min.nii in FSLeyes.
  3. Select the SUM image. Select the Hot [Brain colours] colormap for the SUM PET image and set the min to 0 and max to 25,000.
  4. Use the opacity slider to make the SUM PET image ~50% translucent.
  5. Scroll around in the image to view the registered SUM PET image overlayed on the T1-weighted MRI. Notice the PET image now aligns with the MRI. Also note the elevated binding in the precuneus, cingulate cortex, and frontal, parietal and temporal cortices.
  6. Also observe the registration accuracy by looking at features common to (i.e., mutual information) both T1-weighted MRI and PiB PET. For example, elevated non-specific PiB binding can be observed in the cerebellar peduncles (white matter) and a lack of tracer uptake is observed in the CSF filled spaces like the lateral ventricles which are also low intensity on the T1-w MRI.
  7. Compare the image headers for the SUM image in the safe directory with the SUM image with the same name that was used as the source image for registration. You can show the header info in the terminal using fslhd or select Setting>Ortho View1>Overlay Information in FSLeyes. Notice that the sform matrix parameters have changed to reflect the spatial transformation needed to align the PET image to the T1-weighted MRI. This allows a viewer to show the PET image aligned to the T1-w image in world coordinates without having to alter the image matrix.
  8. Now compare the image headers for the resliced SUM image rssub001_pib_SUM50-70min.nii with the T1-weighted MRI. The matrix size and sform matrix should be identical. This is because SPM resliced the PET image matrix such that the image matrix itself now aligns with the T1-weighted MRI, and thus no transformation in the header is needed to align the images in the viewer.

Create a standard uptake value ratio (SUVR) image


In this section, we will use the registered sum image and the T1-weighted MRI to create a cerebellum GM ROI and generate a parametric SUVR image. We’ll do all of these steps using FSL commands and functions. We’ll first create a hand-drawn ROI in the inferior cerebellum based on the MRI, and then use this mask to intensity normalize the SUM PET image and create our SUVR image. Note that we are specifically using the 50-70 min SUM image to generate the SUVR image as this is the timepoint wherein PiB has reached a pseudo “steady state” wherein binding estimates are more stable.

Create a hand-drawn cerebellum GM ROI

  1. In fsleyes, turn off the PET overlay.
  2. Turn on Edit mode by selecting Tools -> Edit Mode
  3. In the image viewer, navigate to the inferior portion of the cerebellar GM (~Z voxel location 30). You should be 1-2 axial planes below the inferior GM/WM boundary in the cerebellum.
  4. Select the T1-w MRI in the Overlay list and click the icon on the left side of the viewer that looks like a sheet of paper to create a 3D mask using the T1-w image as a reference.
  5. Rename the mask rsub001_cblm_mask using the text box on the top-left side of FSLeyes
  6. Using the pencil and fill tools, hand draw circles in the left and right inferior cerebellum on the transaxial plane. Use the fill tool to fill in the inner part of the circle. Ensure the Fill value is set to 1. Using a Selection size of 3 voxels or greater will help draw the ROI more easily. When you’re done drawing your ROI, click the select tool to enable you to scroll around the image viewer.
  7. Select the mask image and save the image (Overlay -> Save) as a new NIfTI file named rsub001_cblm_mask.nii.

Create the SUVR Image with the inferior cerebellum reference region

  1. For the expression, we want to divide the SUM 50-70 min pib image by the mean intensity in the cerebellum ROI that we just generated by hand. To accomplish this, we will divide the entire SUM pet image by the mean of the SUM PET image in all voxels where the cerebellum mask =1. We’ll do this in two steps using FSL.

  2. In the command line, extract the mean activity concentration in the cerebellum mask using fslstats

    BASH

    fslstats rssub001_pib_SUM50-70min.nii -k rsub001_cblm_mask.nii -M

    OUTPUT

    # The value you get from this command will be slightly different
    # from what is below. Use this value for the {ROI mean} in the nex command.
    5795.161909
  3. Create the SUVR image by dividing the SUM 50-70min image by the mean activity concentration output by fslstats

    BASH

    fslmaths rssub001_pib_SUM50-70min.nii -div {ROI mean} rssub001_pib_SUVR50-70min.nii

    In this command replace {ROI mean} with the value that you got in the fslstats command.

View the SUVR image overlayed on the T1-w MRI

  1. Open the T1-weighted MRI (if not already opened) and the newly created pib SUVR image rssub001_pib_SUVR50-70min.nii in FSLeyes.
  2. For the SUVR image, set the colormap to Hot [Brain colours], set the min and max intensity window to 0 and 3, and set the opacity to ~50%.
  3. Notice the values within the image have been rescaled and should be roughly between 0 and 3 SUVR. For interpretation, values ~>1 (plus some noise) in the gray matter indicate specific tracer binding to beta-amyloid plaques.

Discussion

  • Which regions do you suspect have amyloid plaques?
  • Which regions have the highest density of amyloid plaques?

Stretch Exercises


If you have time, please try the following challenge to test your knowledge.

SUVR versus DVR images

We have pre-processed the PiB image using a different image pipeline that outputs distribution volume ratio (DVR) images instead of SUVR. These are located in the folder ~/data/PETImaging/ProcessedPiBDVR in the file cghrsub001_pib_DVRlga.nii Compare the DVR image with the SUVR image you created in the tutorial.

How are the images similar and how are they different?

Pay close attention to the display settings for the window and colormap.

Or try using the & command to put these commands in the background!

Create a Tau PET SUVR image

You have created a SUVR image for PiB, which used a dynamic acquisition wherein the scan started at the same time as tracer injection. Now see if you can repeat the relevant steps above to create a SUVR image for the MK-6240 scan.

You’ll need to look at the .json file for the TAU PET NIfTI file - this will contain key information around timing and framing so that you can determine which frames to SUM to generate the SUVR image. The most commonly used MK-6240 SUVR windows are 70-90 min or 90-110 min post-injection. For most tau tracers, the inferior cerebellum is a valid reference region. If you run out of time and would like to view an MK-6240 SUVR image, you can view the images in ~/data/PETImaging/ProcessedTutorial, which have been pre-processed.

Additional steps


In the tutorial above, some steps that would typically be included in PET processing were omitted to enable enough time to get through the tutorial and create an SUVR image during the workshop. For example, we did not include interframe alignment and did not perform any smoothing or denoising on the 4D PET data. We have included additional steps below and have also included some preprocessed PiB data using a DVR pipeline that you can compare with your SUVR image.

Interframe realignment

Interframe realignment is often included in processing 4D PET data to correct for motion between frames in a dynamic acquisition. It’s important to note that this process will not correct for motion that happens within a PET frame and will also not correct for misalignment of the emission scan and attenuation map used during the reconstruction. As such, correcting for interframe motion does not entirely account for motion that occurs during a PET scan. In cases with large amounts of motion, the reconstructed data may need to throw out bad frames or may simply be unusable. There are some approaches to correct for motion on the scanner and prior to/during reconstruction, but this is beyond the scope of this tutorial. We will use the 4D PiB data and SPM12 to perform interframe realignment, but will modify our approach to account for differences in PET frame duration and noise.

  1. View the problem
    1. In the previous tutorial, we created SUM images of the first and last 20 minutes of the PiB acquisition. Load these images in FSLeyes. Recall that you’ll need to use the 50-70 SUM image in the /safe directory that did not have the coregistration transformation matrix written to the NIfTI header. If you have not completed the tutorial, you can load the following images that have been previously processed:
      • /home/as2-streaming-user/data/PET_Imaging/ProcessedTutorial/ssub001_pib_SUM0-20min.nii
      • /home/as2-streaming-user/data/PET_Imaging/ProcessedTutorial/safe/ssub001_pib_SUM50-70min.nii
    2. Set the threshold for the min and max window to 0 to 35,000 for the 0-20 min SUM image and 0 to 20,000 for the 50-70 min SUM image.
    3. Toggle the top image on and off using the eye icon in the Overlay list. Notice the slight rotation of the head in the sagittal plane between the early and late frames. This is due to participant motion during the scan acquisition and what we are going to attempt to correct using interframe realignment.
    4. Close FSLeyes.
  2. Launch SPM if not already opened
  3. Smooth all frames of the 4D data – smoothing prior to realignment will improve the registration by reducing voxel-level noise.
    1. Select the Smooth module from SPM
    2. Add all frames for the 4D PiB image sub001_pib.nii to the Images to smooth
    3. Set the FWHM to an isotropic 4 mm kernel (4 4 4).
    4. Set the datatype to FLOAT32
    5. Press the green play button to execute the smoothing operation
    6. Close the smooth module in SPM
    7. View the smoothed 4D PiB image in FSLeyes.
  4. SUM PET frames across the 4D acquisition
    1. For interframe realignment, we typically create an average image of the entire 4D time series to use as a reference image to align each frame. Because the PiB framing sequence has different frame durations, we cannot simply average the frames as we would in fMRI, but instead need to create a SUM image of the entire 70-minute acquisition using a weighted average.

    2. Open the ImCalc module in SPM.

    3. Specify all frames of the smoothed 4D PiB image (ssub001_pib.nii) as Input Images. Be sure to maintain the frame order on the file input.

    4. Name the output file ssub001_pib_SUM0-70min.nii

    5. For the expression, specify an equation for a frame duration-weighted average of all frames. Recall that the frame durations are stored in the .json file.

      MATLAB

      (i1*2 +i3*2 +i4*2 +i5*2 +i6*5 +i7*5 +i8*5 +i9*5 +i10*5 +i11*5 +i12*5 +i13*5 +i14*5 +i15*5 +i16*5 +i17*5)/70
    6. Use FLOAT32 for the Data Type

    7. Run the module using the green play arrow.

    8. Close the SPM ImCalc module.

  5. Perform Interframe alignment using SPM12 realign
    1. Open the Realign: Estimate and Reslice module in SPM12
    2. Select data and click Specify
    3. Select Session and click Specify
      1. Here we will use the SUM0-70 min image as the reference for realignment. This is done by selecting this file first in the session file input list.
      2. Select the SUM 0-70 min PiB image, and then specify the entire smoothed 4D time series by input each of the 17 frames.
      3. Use default settings for all parameters except the following
        • Estimation Options-Smoothing (FWHM): 7
        • Estimation Options-Interpolation: Trilinear
        • Reslice Options-Resliced Images: Images 2..n
        • Reslice Options-Interpolation: Trilinear
      4. Run the module by clicking the green play icon
    4. Once the process has completed, the SPM graphics window will output the translation and rotation parameters used to correct for motion in each frame. Note these are small changes typically <1-2 mm translation and <2 degrees rotation.
    5. Close the SPM realign module
    6. View the resultant 4D image in FSLeyes (rssub001_pib.nii) using a display min and max of 0 to 30,000. Navigate in the viewer to view the sagittal plane just off mid-sagittal. Place your crosshairs at the most inferior part of the orbitofrontal cortex and advance through the PET frames. How did the realignment perform? Are you still seeing rotation in the sagittal plane between early and late frames?
    7. Now change the max window to 100 to saturate the image and view the outline of the head. Scroll through the frames to look for any head motion across the frames. To see the difference before and after realignment, load the smoothed 4D image, saturate the image to view the head motion between frames.

Appendices 1: Filenames and descriptions


Filenames and Descriptions

Unprocessed files (/home/as2-streaming-user/data/PET_Imaging/UnprocessedData/):

  • rsub001_t1mri.nii – T1-weighted MRI NIfTI image
  • sub001_mk6240.nii – 4D [18F]MK-6240 PET NIfTI image
  • sub001_pib.nii – 4D [11C]PiB PET NIfTI image
  • sub001_mk6240.json – metadata for MK-6240 PET scan
  • sub001_pib.json – metadata for PiB PET scan

Processed files in order of tutorial creation (/home/as2-streaming-user/data/PET_Imaging/ProcessedTutorial/):

  • PiB SUVR tutorial
    • sub001_pib_SUM50-70min.nii – PiB PET summed from 50-70 min post-injection
    • sub001_pib_SUM0-20min.nii – PiB PET summed from 0-20 min post-injection
    • ssub001_pib_SUM50-70min.nii – SUM50-70 min PiB image smoothed by 4mm kernel
    • ssub001_pib_SUM0-20min.nii – SUM0-20 min PiB image smoothed by 4mm kernel
    • rssub001_pib_SUM50-70min.nii – smoothed SUM50-70 min PiB image registered and resliced to T1-weighted MRI
    • rsub001_cblm_mask.nii.gz – mask image of hand-drawn cerebellum ROI
    • rssub001_pib_SUVR50-70min.nii – PiB SUVR image registered to T1-weighted MRI
  • MK-6240 SUVR tutorial
    • sub001_mk6240_SUM70-90min.nii – PiB PET summed from 70-90 min post-injection
    • ssub001_mk6240_SUM70-90min.nii – SUM70-90 min MK-6240 image smoothed by 4mm kernel
    • rssub001_mk6240_SUM70-90min.nii – smoothed SUM70-90 min MK-6240 image registered and resliced to T1-weighted MRI
    • rssub001_mk6240_SUVR70-90min.nii.gz – MK-6240 SUVR image registered to T1-weighted MRI

Processed PiB DVR in order of creation (/home/as2-streaming-user/data/PET_Imaging/ProcessedPiBDVR/):

  • ssub001_pib.nii – smoothed 4D PiB time series
  • sub001_pib_SUM0-70min.nii – PiB SUM 0-70 min
  • rsub001_pib.nii – realigned 4D PiB time series
  • hrsub001_pib.nii – realigned 4D PiB time series with HYPR denoising applied
  • hrsub001_pib_SUM0-20min.nii – denoised PiB SUM 0-20 min used for source image in SPM coregistration to T1-weighted MRI
  • cghrsub001_pib_SUM0-20min.nii – denoised PiB SUM 0-20 min image coregistered and resliced to T1-weighted MRI
  • cghrsub001_pib.nii - denoised 4D PiB image coregistered and resliced to T1-weighted MRI
  • cghrsub001_pib_DVRlga.nii – PiB DVR parametric image coregistered to T1-weighted MRI (Logan graphical analysis, \(t^*\)=35 min, \(k_2’\)=0.149 \(min^{-1}\), cerebellum mask reference region)
  • See the file descriptions earlier in the appendix for remaining descriptions of images in this directory

PiB DVR Pipeline


Smooth 4D data (3 mm) -> SUM 0-70 min for realignment reference -> Interframe Realignment -> HYPR Denoising -> SUM 0-20 min for coregistration source image -> Coregister to MRI -> Extract cerebellum GM reference region time-activity curve -> Generate parametric DVR image

Key Points

  • PET Images are reconstructed from listmode data.
  • The most commonly used PET tracers are sensitive to amyloid plaques and neurofibrillary tau tangles.
  • Full dynamic scans are acquired from the time of injection, while static scans are acquired a fixed interval after injection when the tracer has or is approaching equilibrium
  • Summing individual frames together reduces the level of noise
  • SUVR images represent the relative uptake in each voxel to a reference region, where there is likely no specific binding

Content from Diffusion-weighted imaging (DWI)


Last updated on 2025-01-14 | Edit this page

Overview

Questions

  • What does diffusion weighted imaging measure?
  • What processing steps are needed when working with diffusion weigthed imaging data?
  • What types of analyses are used with diffusion imaging in dementia resaerch?

Objectives

  • Understand the processing steps in diffusion-weighted MRI scans
  • Perform basic analyses on white matter microstructure.

Introduction


We will use the FSL diffusion toolbox to perform the processing steps that are core to most diffusion weighted imaging analyses:

  • image visualization of raw data and analysis outputs,
  • eddy correction,
  • generation of diffusion tensor metrics brain maps,
  • tract-based spatial statistics,
  • you can also stretch your knowledge and familiarize yourself with loops to run these commands on multiple subjects, all shown at the end of this tutorial

We are going to be working in the DiffusionMRI subfolder under data in your home directory, ~/data/DiffusionMRI.

Looking at the raw data


From the previous lessons, you learned how to view and navigate images, let’s first look at the raw data, which can all be found under ~/data/DiffusionMRI/sourcedata.

To go to this directory using the terminal, use the command cd to change directory.

BASH

cd  ~/data/DiffusionMRI/sourcedata

Let’s inspect what each participant’s dwi directory should contain:

BASH

ls sub-OAS30001/dwi

or

BASH

ls sub-OAS*/dwi

The * will match any following text, which here will list the contents of any directory starting with “sub-OAS”.

Each directory should contain 4 files:

  • one .bval text file
  • one .bvec text file
  • one .json text file
  • one nifti (.nii.gz) image file

All files are required for processing DWI data except the .json file. The .json file is specific to the BIDS data organization, and is a useful way to access data description. More and more software are also relying on data organized according to the BIDS structure.

Let’s look at those files:

BASH

# Change directory to go in one participant's folder
cd sub-OAS30001/dwi

## Image file
fsleyes -ms sub-OAS30001_dwi.nii.gz &
 
## Text files
cat sub-OAS30001_dwi.bval
cat sub-OAS30001_dwi.bvec
example of bval and bvec file
  • The nifti file is a 4D file of all the directions acquired.
  • The .bval file refers to the b-value applied to each image.
  • The .bvec file refers to the vector applied to each image, with the coordinates in x, y and z.

Challenge

Use the “movie” option in fsleyes to look at all frames of the nifti file. How can you know how many directions it contains?

Refer to the Getting started session for more details!

There is 1 b0 image and 64 gradient images! You can check for the maximum number as you move through the “Volume” box as shown below.

FSLeyes of B0 image

Data preprocessing


We are now ready to start data pre-processing, which we will do using the FSL Diffusion Toolbox. Most of the steps and explanation below are adapted from the excellent tutorial provided FSL, please refer to it for more details: https://open.win.ox.ac.uk/pages/fslcourse/practicals/fdt1/index.html

All the steps below will be done on one subject only, but if you wish to loop the different steps across multiple participants, refer to the section Stretch your knowledge at the end.

1. Creating a brain mask from the b0 images

We often use the b0 images (there is only 1 b0 image in this dataset) to create a brain mask that is needed in future steps. First select the b0 image, extract the brain only and binarize it to make a mask.

  • Extract the b0 image only with select_dwi_vols or fslroi

    BASH

    # Usage: fslroi <input> <output> <tmin> <tsize>
    
    fslroi sub-OAS30001_dwi.nii.gz sub-OAS30001_b0.nii.gz 0 1
  • Brain extraction and binarization with bet

    BASH

    # Usage: bet <input> <output> [options] 
    # the -m option will automatically create a binarized mask after brain extraction
    
    bet sub-OAS30001_b0.nii.gz sub-OAS30001_b0_bet -m
  • Load the mask you just created to make sure it is adequate!

    BASH

    fsleyes sub-OAS30001_b0_bet_mask.nii.gz &

2. Correcting for susceptibility-induced distortions

Some parts of the brain can appear distorted depending on their magnetic properties. One common way to correct the distortions with DWI data is by acquiring a b0 image acquired with a different phase-encoding, and merging the two types of images running TOPUP.

In this dataset we don’t have the data required for TOPUP so we will skip this step.

Note however that you should run it if your data allows.

3. Correcting for eddy currents and movement

Eddy is a tool to correct for eddy current-induced distortions and movement on the image. Eddy currents arise from electric current due to strong and fast changing gradients. Eddy also does outlier detection and will replace signal loss by non-parametric predictions.

We need to create 2 files to be able to run eddy:

  • an index file corresponding to the directions with the same phase encoding
  • a file with some acquisition parameters

Run the following lines to create the index file. Since all images are obtained with the same phase encoding, it will just be a vector with values of 1 of the same length of the bval file.

BASH

## The command wc (wordcount) will check the length of the bval file and we will use this output to create the index file we need.
wc -w sub-OAS30001_dwi.bval
indx="" 
for ((i=1; i<=65; i+=1)); do indx="$indx 1"; done 
echo $indx > index.txt

OUTPUT

1 1 1 1 1 1 ... 1
The index file is a series of 1 repeated 65 times

The acquisition parameter file is a vector containing the phase encoding and the total read out time, which can all be found in the .json file. Do cat sub-OAS30001_dwi.json and see if you can find the following information.

  • TotalReadoutTime: 0.0451246
  • PhaseEncodingDirection: j- : This corresponds to the AP direction and is coded as -1 for the acquisition parameter file.

You can also try cat sub-OAS30001_dwi.json | grep 'Total' to directly find the entry you need!

The acquisition parameter file first includes the phase encoding, with the first 3 numbers corresponding to the x, y, and z directions. Here we are acquiring along the y direction (being -1), and x and z being 0. The last number is the total read out time.

To create it you can do:

BASH

printf "0 -1 0 0.0451246" > acqparams.txt

We are ready to run eddy! Please refer to https://fsl.fmrib.ox.ac.uk/fsl/fslwiki/eddy for all the details

However, eddy takes a long time to run (about 40 minutes either on the VM or on a MacBook Pro), so we’ve run it for a few subjects already. The outputs can be found in ~/data/DiffusionMRI/processed_sourcedata.

As eddy creates a lot of output files, it can be good practice to create a separate directory to store the outputs so we keep things more organized, as done in the processed_sourcedata directory. For example, if you type ls ~/data/DiffusionMRI/processed_sourcedata/sub-OAS30001/eddy/ you will see all the eddy outputs for this given participant.

Eddy also takes a lot of input arguments, as depicted below
eddy
Image adapted from https://open.win.ox.ac.uk/pages/fslcourse/practicals/fdt1/index.html

If you want to try to run it on one participant, you can try the following command.

BASH

eddy --imain=sub-OAS30001_dwi.nii.gz --mask=sub-OAS30001_b0_bet_mask.nii.gz --acqp=acqparams.txt --index=index.txt --bvecs=sub-OAS30001_dwi.bvec --bvals=sub-OAS30001_dwi.bval --out=../eddy/eddy_corrected

To be able to run the next step, we will copy the eddy-corrected DWI scan for one subject into our working directory. Make sure you are in this directory: ~/data/DiffusionMRI/sourcedata/sub-OAS30001/dwi (you can use the command pwd to print your working directory and know where you are), and then type this command:

BASH

cp ~/data/DiffusionMRI/processed_sourcedata/sub-OAS30001/eddy/sub-OAS30001_eddy_corrected.nii.gz .

Now let’s compare the raw DWI scan vs. after eddy correction. You can load the two images (sub-OAS30001_dwi.nii.gz and sub-OAS30001_eddy_corrected.nii.gz) with fsleyes. On this participant with high quality images, the differences are not really noticeable, but remember the example from the webinar on data where there was signal loss and big differences were evident.

** It’s always important to inspect images after preprocessing steps! Many software (including FSL) have automated QC frameworks available to help go through all the outputs. You can find more information on eddyQC from the FSL documentation if you want to try it

4. Generating DTI outputs

We can now fit the diffusion tensor model to the preprocessed data. This will generate all the standard DTI outputs, like fractional anisotropy (FA), mean diffusivity (MD), radial diffusivity (RD) and axial diffusivity (AD), along with eigenvectors.

As this will also generate many outputs, to keep things organized let’s create a directory for storing the outputs.

The command is dtifit, and uses the eddy-corrected data as input. All the inputs required are detailed in the command usage.

BASH

#Usage: Compulsory arguments (You MUST set one or more of):
#	-k,--data	dti data file
# -o,--out	Output basename
# -m,--mask	Bet binary mask file
# -r,--bvecs	b vectors file
# -b,--bvals	b values file

dtifit --data=sub-OAS30001_eddy_corrected.nii.gz --mask=sub-OAS30001_b0_bet_mask.nii.gz --bvecs=sub-OAS30001_dwi.bvec --bvals=sub-OAS30001_dwi.bval --out=../dwi/sub-OAS30001_

Many files have been created, let’s look at the ones most commonly used, i.e. FA, MD and V1.
V1 is the principal eigenvector and corresponds to the direction along the principal diffusion direction and allows us to visualize the underlying orientation of white matter fibers.

V1 should open as an RGB map where the colors represent directions:
* Red= left - right axis
* Green= anterior - posterior axis
* Blue= superior - inferior axis

You can also change the overlay type and visualize the image as lines with ‘3-direction vector image (Line)’ in the top left corner, which will show the vector field.

Example of the V1 file in RGB:
example_RGB_V1

We have now completed the basic steps required for all diffusion data! Those allow to continue with further processing (e.g. tractography) or to continue with group-level analyses, which require processing a few subjects.

In the next section, you have a few options to go further:

  • There is some example of code to perform the same steps as we did above, this time looping across subjects.
  • A common analyses is Tract-Based Spatial Statistics (TBSS), which allows for voxel-wise analyses on a skeletonized white matter template. We provided the command lines below to do such analyses. Some steps can take some time to run, and thus we provided the outputs in ~/data/DiffusionMRI/tbss if you want to examine the different steps and the final outputs.

Stretch your knowledge


Do you want to process multiple subjects?

An easy way to do this is through multiple bash loops, introduced this morning. You will have examples below of loops for the different steps we did above if you want to try it.

Make sure you are in the following directory: ~/data/DiffusionMRI/sourcedata

BASH

# Extract the b0 image
for x in sub-OAS30*; do echo $x; fslroi $x/dwi/*_dwi.nii.gz $x/dwi/${x}_b0.nii.gz 0 1; done

#Create the brain mask from the b0 image
for x in sub-OAS30*; do echo $x; bet $x/dwi/*_b0.nii.gz $x/dwi/${x}_b0_bet -m; done

# Run eddy - Don't try this on multiple subjects; it will take too long to run!
for x in sub-OAS30*; do echo $x; eddy --imain=$x/dwi/${x}_dwi.nii.gz --mask=$x/dwi/${x}_b0_bet_mask.nii.gz --acqp=acqparams.txt --index=index.txt --bvecs=$x/dwi/${x}_dwi.bvec --bvals=$x/dwi/${x}_dwi.bval --out=$x/dwi/${x}_eddy_corrected; done

# Run dtifit
for x in sub-OAS30*; do echo $x; dtifit --data=$x/dwi/${x}_eddy_corrected.nii.gz --mask=$x/dwi/${x}_b0_bet_mask.nii.gz --bvecs=$x/dwi/${x}_dwi.bvec --bvals=$x/dwi/${x}_dwi.bval --out=$x/dwi/${x} ; done

Note that all processed data can be found in ~/data/DiffusionMRI/processed_sourcedata if you want to access it

Do you want to investigate microstructure differences between groups?

Let’s investigate FA differences between 4 Controls and 4 AD subjects using TBSS. This involves a few easy steps, which are outline below, but please refer to the original description of TBSS for all details.

It can take some time to run, so we placed all outputs in ~/data/DiffusionMRI/tbss if you want to explore the outputs from each step.

If you want to try it on your own, you can follow these steps:

  1. Create a new directory for TBSS and copy all FA maps in it

    BASH

    mkdir tbss_tutorial
    cp ~/data/DiffusionMRI/processed_sourcedata/sub-OAS30*/dti/*FA.nii.gz tbss_tutorial/

    You can run slicesdir *.nii.gz and open the resulting web page report; this is a quick way to check your images.

    Run all the next commands directly from the tbss_tutorial directory you created.

  2. Quick preprocessing of the data

    BASH

    tbss_1_preproc *.nii.gz
  3. Register all FA maps to standard space

    BASH

    tbss_2_reg -T
  4. Apply transformation to all images and create mean FA skeleton

    BASH

    tbss_3_postreg -S

    You can load the 4D file created all_FA with the overlay mean_FA_skeleton on top to verify that all images are aligned correctly.

  5. threshold FA skeleton
    This last step is to threshold the FA skeleton that was created, inspect it before and adapt accordingly (here we used the recommended 0.2 threshold)

    BASH

    tbss_4_prestats 0.2

We are now ready to do the statistical comparisons!

Statistical comparisons between two groups

We will use the tool randomise, for which we need to create two text files: design.mat and design.con. Design.mat specifies which groups the participants belong to and other covariates of interest. Design.con specifies the contrasts we want to perform for our statistical analyses.

You need to make sure of the order of your FA images to create the design matrix files, which is the alphabetical order. In this example, we will compare Controls vs. AD patients. The diagnosis for each participant is as follows:
sub-OAS30001 : Control
sub-OAS30003 : Control
sub-OAS30006 : Control
sub-OAS30024 : AD
sub-OAS30025 : Control
sub-OAS30128 : AD
sub-OAS30217 : AD
sub-OAS30262 : AD

We want to perform 2-sample t-test. We can create the files we need easily with:

BASH

# Move to the stats directory
design_ttest2 design 4 4

Since the order of our participants do not perfectly follow the Diagnosis categories, make sure you fix the design.mat accordingly if you used the automated command. The final one should be:
1 0
1 0
1 0
0 1
1 0
0 1
0 1
0 1

For the design.con, the first contrast ‘1 -1’ will give results where CU > AD and the second contrast ‘-1 1’ will give results where the CU < AD. Remember: we are looking at differences in FA, so we expect smaller FA values in AD than Controls. It would be the opposite if we were looking at differences in MD.

We are ready do run the command randomise to compare groups. There are a lot of options you can choose to generate your results, with different thresholding options. Please refer to the full description of the command

BASH

#Usage: randomise -i <input> -o <output> -d <design.mat> -t <design.con> [options]

# Since we have only a few subjects we can apply a less stringent threshold, setting a cluster-based threshold at t= 1.5
randomise -i all_FA_skeletonised -o tbss -m mean_FA_skeleton_mask -d design.mat -t design.con -c 1.5

# Here is the example to apply the preferred method of TFCE (threshold free cluster enhancement; option T2)
randomise -i all_FA_skeletonised -o tbss -m mean_FA_skeleton_mask -d design.mat -t design.con -n 100 --T2 -V

We generated outputs using the two methods (cluster based threshold of TFCE), which you can access under ~/data/DiffusionMRI/tbss/stats. You have:
* unthresholded t-statistical maps, tbss_tstat1 and tbss_tstat2, where 1 and 2 refer to the different contrasts
* p-values maps corrected for multiple comparisons (either tbss_clustere_corrp_tstatX or tbss_tfce_corrp_tstatX)
Note that the p-values maps are outputted as 1-p for convenience of display (so that higher values are more significant). You can threshold those from 0.95 to 1.

Here is one example of how you can overlay different outputs images to visualize results.

BASH

fsleyes -std1mm mean_FA_skeleton -cm green -dr .3 .7 tbss_tstat1 -cm red-yellow -dr 1.5 3 & tbss_clustere_corrp_tstat1 -cm blue-lightblue -dr 0.90 1

This will display the standard MNI brain, the average FA skeleton used for TBSS, the t-map for contrast 1 and the p-value maps after cluster-based thresholding. Note that I am thresholding the latter from 0.90 to 1 since we have weak results in this example; this will show voxels where CU have greater FA than AD patients from p=0.10.

Try the same thing with the other contrast to confirm if results are as expected.

Key Points

  • Diffusion imaging is used to obtain measurements of tissue microstructure
  • DWI consists of a 4D volume, and files describing the vectors and b-values that each volume is encoding
  • The common core processing steps are: brain masking, susceptibility correction, eddy/motion correction, and modelling (tensor fitting, NODDI, etc)

Content from Functional Magnetic Resonance Imaging (fMRI)


Last updated on 2025-01-14 | Edit this page

Overview

Questions

  • What generates the signal that fMRI is measuring?
  • What preprocessing steps are needed before analysing fMRI data?
  • What type of analysis can I perform on pre-processed fMRI data?

Objectives

  • Explain main sources of variability in BOLD signal and how to handle them
  • Demonstrate basic pre-processing steps commonly used in fMRI
  • Get to know what type of information we can obtain from pre-processed data (e.g. resting state networks)

Introduction


Functional Magnetic Resonance Imaging (fMRI) is a technique that captures a “movie” of brain activation over a certain period of time. fMRI sequences are time series (4D acquisitions) of 3D brain volumes. fMRI measures the blood-oxygen-level-dependent (BOLD) signal, an indirect measure of regional brain metabolism.

Raw resting-state functional MRI images are prone to several artifacts and variability sources. For this reason, before performing our statistical analysis, we need to apply a series of procedures that aim at removing the sources of signal that we are not interested in, to clean the ones we want to study. All these procedures together are called pre-processing. This document will guide you through the basic steps that are usually taken in the rs-fMRI pre-processing phase.

Pre-processing Software


To date, a large amount of pre-processing software packages are available and can be freely used. In this course, we will use FSL to perform pre-processing steps directly from the command line.

Data


In this tutorial, we are going to use data from one participant of the OASIS study. Data can be found in the folder oasis/fMRI_tutorial_orig First, let’s go into the directory where the functional data are!

BASH

cd   ~/data/FunctionalMRI 

Now go into the subject folder and list the content to have an idea of what data we are going to use.

BASH

cd sub-OAS30015

ls 

As you can see, for fMRI processing we need high-resolution structural data (T1w in the subfolder called anat) and fMRI files, in the func subfolder.

Overview


Modern fMRI pre-processing pipelines include a variety of processes that can, or cannot, be performed depending on the acquired data quality, and study design. Today, we will have a look at some of these pre-processing steps that are most commonly used. Typical pre-processing steps include:

  • EPI Distortion Correction
  • Motion Correction
  • Standard Space Mapping
  • Spatial Smoothing
  • Temporal Filtering
  • Denoising

Hands-on


Structural Processing

Given the low spatial resolution and SNR of fMRI images, some registration steps in functional processing involve the use of previously computed transformation during the T1w processing. Important steps to have performed are:

In this course, these steps have already been performed for you as they can take quite some time. Please don’t run these commands!

  • Brain extraction with BET

    BASH

    bet sub-OAS30015_T1w.nii.gz sub-OAS30015_T1w_bet -f 0.4
  • Tissue Segmentation with FAST

    BASH

    fast -n 3 -b -o sub-OAS30015_T1w_bet_FAST sub-OAS30015_T1w_bet.nii.gz
  • Linear and Non linear T1w to MNI Standard Space Mapping

    BASH

    flirt -in sub-OAS30015_T1w_bet.nii.gz  -ref /usr/local/fsl/data/standard/MNI152_T1_2mm_brain -out highres2standard -omat highres2standard.mat -cost corratio -dof 12 -searchrx -90 90 -searchry -90 90 -searchrz -90 90 -interp trilinear
    
    fnirt --iout=highres2standard_head --in=sub-OAS30015_T1w.nii.gz --aff=highres2standard.mat --cout=highres2standard_warp  --jout=highres2highres_jac --config=T1_2_MNI152_2mm --ref=/usr/local/fsl/data/standard/MNI152_T1_2mm --refmask=/usr/local/fsl/data/standard/MNI152_T1_2mm_brain_mask.nii.gz --warpres=10,10,10

The results from these commands can be found in the /anat folder within the subject directory

Look at the raw data!

To have an idea of how the raw data looks before any pre-processing is performed, let us visually review the images. To do so, fsleyes is a great toolbox that can be used by typing on the command line:

BASH

fsleyes -ms func/sub-OAS30015_task-rest_run-01_bold.nii.gz &

The -ms option is helpful as it makes viewing using the movie mode much better.

As mentioned in the imaging data section, the & at the end of the command allows us to keep working on the command line while having a graphical application (such as fsleyes) opened. Helpful options for reviewing fMRI data in fsleyes are the movie option ( movie ) and the timeseries option (-> view -> timeseries or keyboard shortcut ⌘-3). Check them out!

EPI Distortion Correction

Some parts of the brain can appear distorted depending on their magnetic properties. One common way to correct the distortions with fMRI data is by acquiring one volume with an opposite phase-encoding direction, and merging the two types of images running TOPUP. In this dataset we don’t have the data required for TOPUP so we will skip this step. Note however that you should run it if your data allows.

Preliminary steps

For some registrations steps we will need only one volume from our fMRI timeseries. Run the following code to cut 1 volume in the middle of the functional file:

BASH

fslroi func/sub-OAS30015_task-rest_run-01_bold.nii.gz func/sub-OAS30015_task-rest_run-01_bold_1volume  80 1

Motion Correction

A big issue in raw rs-fMRI scans is the fact that participants usually tend to move during the length of the scanning session, therefore producing artifacts in the images. Head motion results in lower quality (more blurry) images, as well as creating spurious correlations between voxels in the brain. Rs-fMRI pre-processing takes care of the motion during the scan by realigning each volume within a scan to a reference volume. The reference volume is usually the first or the middle volume of the whole sequence.

To perform motion correction with fsl we use the mcflirt command:

BASH

mcflirt -in  func/sub-OAS30015_task-rest_run-01_bold.nii.gz -out func/mc_sub-OAS30015_task-rest_run-01_bold

To keep track of what we are doing, it is good to add a prefix to the output describing the preprocessing steps run on it. So in this case we add mc_ (motion corrected) to our original functional file.

we can now have a look at original and motion corrected image by typing

BASH

fsleyes func/sub-OAS30015_task-rest_run-01_bold.nii.gz func/mc_sub-OAS30015_task-rest_run-01_bold &

In fsleyes we can use the options in the lower left panel to hide or move images up. Can you guess which are the spots of the images that differ most between the two scans?

Standard Space Mapping

Brain shape and size strongly vary across different individuals. However, to perform group level analysis, voxels between different brains need to correspond. This can be achieved by registering or normalizing rs-fMRI scans in native-space to a standard template. This processing step is actually made of three different steps.

  1. Compute the registration of the subject T1w scan to MNI space:

    This has been previously run using flirt and fnirt (see above). The output transformation matrix is stored in the anat subfolder and called highres2standard_warp.mat

  2. Register the fMRI to the T1w file

    With the following function we compute the transformation matrix needed to bring the fMRI file to the T1w space

    BASH

    epi_reg --epi=func/sub-OAS30015_task-rest_run-01_bold_1volume.nii.gz --t1=anat/sub-OAS30015_T1w.nii.gz --t1brain=anat/sub-OAS30015_T1w_bet.nii.gz --out=func/func2highres
  3. Combine fMRI2T1w and T12MNI transformation, and apply in one go to our timeseries

    BASH

    # concatenate T12standard and fMRI2T1w affine transform
    convert_xfm -omat func/func2standard  -concat anat/highres2standard.mat func/func2highres.mat  
    
    # concatenate T12standard non-linear and fMRI2T1w affine transform
    convertwarp --ref=$FSLDIR/data/standard/MNI152_T1_2mm_brain --premat=func/func2highres.mat --warp1=anat/highres2standard_warp --out=func/func2standard_warp 
    
    applywarp --ref=$FSLDIR/data/standard/MNI152_T1_2mm_brain --in=func/mc_sub-OAS30015_task-rest_run-01_bold.nii.gz  --out=func/MNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz  --warp=func/func2standard_warp

The output of these functions is stored in func/MNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz . This is our fMRI scan in MNI space. You can check this by typing

BASH

# check characteristics (dimensions) of the MNI functional file 
fslinfo func/MNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz  

# check characteristics (dimensions) of the native-space functional file 
fslinfo func/sub-OAS30015_task-rest_run-01_bold.nii.gz 

Let’s also have a look at the MNI file!

BASH

fsleyes func/MNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz &

Spatial Smoothing

With spatial smoothing, we are referring to the process of averaging the data points (voxels) with their neighbors. The downside of smoothing is that we lose spatial specificity (resolution). However, this process has the effect of a low-pass filter, removing high frequency and enhancing low frequency. Moreover, spatial correlations within the data are more pronounced and activation can be more easily detected.

In other words: Smoothing fMRI data increases signal-to-noise ratio.

The standard procedure for spatial smoothing is applying a gaussian function of a specific width, called the gaussian kernel. The size of the gaussian kernel determines how much the data is smoothed and is expressed as the Full Width at Half Maximum (FWHM). Example of full-with at half maximum

There is no standard value for smoothing fMRI data, FWHM usually varies from 2mm to 8mm. A good compromise is to use a FWHM of 4. This can be applied with fslmaths :

BASH

fslmaths func/MNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz -s 4 func/sMNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz

By changing the “-s” option we can change the FWHM, increasing or decreasing the smoothing. Try it out and check the results with fsleyes!

Temporal Filtering

Rs-fMRI timeseries are also characterized by non-interesting low-frequency drift due to physiological (e.g. respiration) or physical (scanner-related) noise. For this reason, we usually apply an high-pass filter that eliminates signal variations due to low-frequency. To do so, a voxel timeseries can be represented in the frequency domain, and low frequency can be set to 0.

BASH

fslmaths func/sMNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz -bptf 45.45 1 func/hpsMNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz

Resting state Networks and Noise Components

Once the data is processed we can try to run an independent component analysis (ICA) on the fMRI timeseries. ICA is usually performed for two reasons: 1. Identify resting state networks, i.e. groups of areas that covary (work) together. This step is often done at the group level. 2. Identify further sources of noise from the data, and further remove them (this is called denoising).

ICA can be run using the melodic command from FSL.

BASH

melodic -i func/hpsMNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz -o func/ICA -m /usr/local/fsl/data/standard/MNI152_T1_2mm_brain_mask.nii.gz

The -m option specifies a mask that we want to run the analysis in. In this case we use a standard brain mask provided by FSL but you could also create your own mask using the structural segmentation.

Melodic will create a directory called “ICA” in our func folder

Open the melodic_IC.nii.gz file in the output folder using fsleyes, threshold the values to 3 (this value is commonly used as a threshold for this task).

Now chose a nice colormap (usually red) and overlay this to a standard brain template (-> File -> Add Standard).

Can you recognize some of the canonical resting-state networks?

Output components from FSL Melodic

Do you see some components that you think might be linked to artefacts?

You can clean the original signal by writing them down and running:

BASH

fslregfilt -i func/sMNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz -o func/denosised_sMNI_mc_sub-OAS30015_task-rest_run-01_bold.nii.gz -d func/ICA/melodic_mix -f " 1,2,3"

with the -f option you can specify the components number that you want to clean from the signal.

Conclusion


You should now be able to fully process one fMRI scan yourself! As you know, we usually work with a bunch of data and want to automatize the pre-processing for all the scans, so that we can run it in one go.

Also following the other sections of this course, try to put all these commands in a for loop and use variables to run commands on your files.

If you want to discover some type of analysis that you can do on the processed data, check out some of these websites:

Ciao!

Key Points

  • fMRI measures small signal fluctations associated with oxyhaemoglobin in the blood resulting from brain activation
  • Images can either be acquired during a task or with no task involved (resting state)
  • Key preprocessing steps include: EPI distortion correction, brain masking, smoothing, and temporal fitering
  • Network components extracted from techniques like Melodic can show key network components, but also potentially components that represent noise.

Content from Extra: Using the Command Line


Last updated on 2025-01-14 | Edit this page

Overview

Questions

  • What is the command line interface?
  • Why is it helpful in neuroimaging analysis?
  • What are some common commands that I need to know?

Objectives

  • Discover how to interact with files and directories on the command line
  • Identify benefits that the command line can provide in processing image data.

Introduction: Why use the command line?


In order to get started with neuroimaging analysis, it is really helpful to first understand how to interact with a computer on the command line called the shell. At first look, it’s pretty bare bones and minimalist. How can this simple way of interacting with a computer be so useful?

Picture of the command line

Nowadays, we usually interact with a computer using a Graphical User Interface or a GUI. These include programs like Word, Chrome, iTunes which allow you to interact using your mouse to press buttons, select options, move sliders, change values, etc. It provides a simple, intuitive way for us to access the essential functionality that we need from these programs. Some neuroimaging analysis software does comes with a GUI, like this one from the Statistical Parametric Mapping (SPM) toolbox, a popular MATLAB based package.

Example of the SPM GUI

Benefits of the command line

While GUIs are often the best way to interact with your computer, using the command line for neuroimaging analysis is tremendously powerful for many reasons:

  1. Automation GUIs typically will wait until you tell them what to do. When you go home at night, it won’t do anything because it has no instructions! You can setup the command line to automate some tasks so that it works late in the night while you are sleeping.
  2. Scalability Working with a GUI often means a lot of mouse moves and clicks. For a small handful of imaging sessions, this is a fine way to work, but what if your research project has hundreds of datasets to process. It’s far more likely that an error could occur or a dataset is missed. While you go through the lessons in this workshop, count the number of mouse clicks it takes you to do a task and think about how that would scale to your project. When you run on the command line it has all of the information it needs, so no interaction is needed, saving a lot of your time.
  3. Control With GUIs, you have access to the functionality that the GUI provides you. However, hidden from the GUI may be more advanced options that you need for your research. For the sake of more software that is often more user-friendly for the majority of tasks you are looking to do, the GUI can sometimes be restritie. With the command line, you should have access to more, if not all, of the functionality that the software provides, and thus more control over how the task is run. It may take some investigation on your part, though.
  4. Interoperability You may find that you want to take results from one program and feed them into another and then another. With GUI’s this often means saving or exporting the results, then opening up the other program and importing them. The command line often allows you the means to piece these steps together in one set of instructions.

Getting started


In this section, we are going to go through some basic steps of working with the command line. Make sure you are able to connect to your working environment by following the directions in the Setup section of this website. As a reminder, you should have a desktop on your virtual machine that looks something like this: Screenshot of the VM desktop Click on the Applications icon in the top left of the window, and you should see a taskbar pop out on the left-hand side. One of the icons is a black box with a white border. This icon will launch the Terminal and give you access to the command line. Launching a terminal


The terminal should produce a window with a white background and black text. This is the shell. We will enter some commands and see what responses that the computer provdes. Picture of an open terminal

  1. The first thing we are going to do is figure out our present location in the file system of the computer. We do that using the command pwd which stands for present working directory. Type it in the command line and see what the response is:

    BASH

    pwd

    OUTPUT

    /home/as2-streaming-user

    This directory is also known as your home directory

  2. Next we are going to see what items are contained in this directory. To do that, simply type ls and it should show you all the files.

    BASH

    ls

    OUTPUT

    Background.png  data  MyFiles  test

    You will notice that some of the entries are different colors. The colors indicate whether the entries are files or directories. They also can indicate if these files or directories have special properties.

  3. If we want more information about these files and directories, then we can use the same command with a command line option -l to tell the computer to list the files in a long format

    BASH

    ls -l

    OUTPUT

    total 60
    -rw-r--r-- 1 as2-streaming-user as2-streaming-user 57734 Jun 28  2023 Background.png
    drwxrwxrwx 8 as2-streaming-user as2-streaming-user   142 Jun 22  2023 data
    drwxr-xr-x 2 as2-streaming-user as2-streaming-user    46 Jul  8 22:31 MyFiles
    drwxr-xr-x 2 as2-streaming-user as2-streaming-user     6 Jun 16  2023 test

    This now gives a lot more information, with the letters before the file telling us about who owns the file (3rd and 4th column), what permissions they have to read, write or run (execute) the file (first column),and when it was modified (6th column).

    If you want to list the contents of a different directory, just put it after the ls -l

    BASH

    ls -l data

    OUTPUT

    total 8
    drwxr-xr-x 6 as2-streaming-user as2-streaming-user   84 Jun 16  2023 DiffusionMRI
    drwxr-xr-x 2 as2-streaming-user as2-streaming-user 4096 Jul  4  2023 ExtraStructuralMRI
    drwxr-xr-x 3 as2-streaming-user as2-streaming-user   26 Jun 27  2023 FunctionalMRI
    drwxr-xr-x 2 as2-streaming-user as2-streaming-user 4096 Jun 16  2023 ImageDataVisualization
    drwxr-xr-x 5 as2-streaming-user as2-streaming-user   77 Jul  7  2023 PETImaging
    drwxr-xr-x 2 as2-streaming-user as2-streaming-user  120 Jun 27  2023 StructuralMRI
  4. The data directory is a sub-directory within your home directory where you will be storing your work. So let us move into that directory using the cd or change directory command:

    cd data

    Now type the command pwd again. Has the result changed?

    What happens when we list the contents of this directory?

    BASH

    ls -l

    You should get the same result as when you ran ls -l data from your home directory.

  5. Inside the data directory, let’s create a new directory that we will call mywork. We do that using a command called mkdir,

    BASH

    mkdir mywork

    Challenge

    Run the ls command again to see how the contents have now changed to show your new directory.

Absolute versus Relative Paths

Locations in the file system, whether they are files or directories, are known as paths. Paths can be referred to in absolute terms (like a postal address or latitude and longitude) or relative terms (like directions to your work from home). In some cases it is more convenient to use absolute paths, and in others, relative paths are nicer. Absolute paths always begin with a / character. From your home directory, the following two commands do the exact same thing.

BASH

# Using an absolute path - this will work anywhere
ls /home/as2-streaming-user/data

OUTPUT

DiffusionMRI        FunctionalMRI           mywork      StructuralMRI
ExtraStructuralMRI  ImageDataVisualization  PETImaging

BASH

# Using a relative path - this will only work if you are in the 
# directory where data is located
ls data

OUTPUT

DiffusionMRI        FunctionalMRI           mywork      StructuralMRI
ExtraStructuralMRI  ImageDataVisualization  PETImaging

Helpful hints

  • Feeling lost? You can always get back to your home directory simply by typing cd without any arguments or by using the tilde symbol, which is the shortcut for home.

    BASH

    cd
    cd ~
  • Help me! If you want to know more about a command, just type man in front of it to get the manual entry.

    BASH

    man ls
    man find
    man more
    man less
  • Previous commands If you want to see a list of commands that you have run, you can type in the history command. You can also scroll through previous commands by tapping the up and down arrow keys and then hit Return when you found the command you want to run again.

Processing files


In this section, we will go over how to copy and view the contents of the files. There is some helpful information about one of the images in our Structural MRI lesson that we want to look at in more detail.

  1. Let’s copy it over from the directory it is currently located into our new mywork directory. We do this using the cp or copy command. We first specify the source, or the file/directory that we want to copy (data/StructuralMRI/sub-OAS30003_T1w.json), and then we specify the destination path where we want to make the copy (data/mywork). Before we do this command, let’s make sure we are back in the home directory first

    BASH

    # Go back to the home directory
    cd
    # Copy the file.
    cp data/StructuralMRI/sub-OAS30003_T1w.json data/mywork
  2. Now let us confirm that the copy of the file is where we expect it to be:

    BASH

    ls data/mywork/

    OUTPUT

    sub-OAS30003_T1w.json
  3. Finally, let’s look at the contents of the file. We can do that with the command cat which concatenates and prints files.

    BASH

    cat data/mywork/sub-OAS_30003_T1w.json 

Using cat on a large text file can end up looking impressive as text swarms all over your terminal, but it can be hard to examine the file…

OUTPUT

{
    "Modality": "MR",
    "MagneticFieldStrength": 3,
    "Manufacturer": "Siemens",
    "ManufacturersModelName": "Biograph_mMR",
    "DeviceSerialNumber": "51010",
    "PatientPosition": "HFS",
    "SoftwareVersions": "syngo_MR_B18P",
    "MRAcquisitionType": "3D",
    "SeriesDescription": "MPRAGE_GRAPPA2",
    "ScanningSequence": "GR_IR",
    "SequenceVariant": "SP_MP",
    "ScanOptions": "IR",
    "SequenceName": "_tfl3d1_ns",
    "ImageType": [
        "ORIGINAL",
        "PRIMARY",
        "M",
        "ND",
        "NORM"
    ],
    "AcquisitionTime": "11:53:18.945000",
    "AcquisitionNumber": 1,
    "SliceThickness": 1.2,
    "SAR": 0.0397884,
    "EchoTime": 0.00295,
    "RepetitionTime": 2.3,
    "InversionTime": 0.9,
    "FlipAngle": 9,
    "PartialFourier": 1,
    "BaseResolution": 256,
    "ShimSetting": [
        -6853,
        14225,
        -5859,
        -89,
        -201,
        157,
        585,
        -236
    ],
    "TxRefAmp": 307.072,
    "PhaseResolution": 1,
    "ReceiveCoilName": "HeadNeck_MRPET",
    "PulseSequenceDetails": "%SiemensSeq%_tfl",
    "PercentPhaseFOV": 93.75,
    "PhaseEncodingSteps": 239,
    "AcquisitionMatrixPE": 240,
    "ReconMatrixPE": 256,
    "ParallelReductionFactorInPlane": 2,
    "PixelBandwidth": 238,
    "DwellTime": 8.2e-06,
    "ImageOrientationPatientDICOM": [
        0,
        1,
        0,
        0,
        0,
        -1
    ],
    "InPlanePhaseEncodingDirectionDICOM": "ROW",
    "ConversionSoftware": "dcm2niix",
    "ConversionSoftwareVersion": "v1.0.20171017 GCC4.4.7"

If we want to have a bit more control over how we view larger files, then we can use either the more or less command. This allows you to scroll through the file a line or page at a time, go back, search the text, etc.

BASH

more data/mywork/sub-OAS_30003_T1w.json 
  1. We no longer need that file anymore (remember it is just a copy), so we can remove files by using the rm command, but BE CAREFUL and check the command twice before executing the command, as this cannot be undone! Watch out for any spaces or any special characters like the * and ? as they mean something special in the shell, and including them in a remove command may remove more files than you intended.

    BASH

    rm data/mywork/sub-OAS_30003_T1w.json 

Further reading


If you want to find out more how to use the command line, please check out the following helpful resources:

Stretch exercises


As you get more comfortable, you can start to do powerful things with the command line.

Variables

Sometimes we want to store some information for future use. We can do that with a variable. A variable has a name and a value. A variable in the shell can hold a number, a single character, a word, sentence or a list of things. You assign a value to a variable with a simple statement var=value where you replace var with the name that you want to call the variable and replace value with the value you want to store. Once the variable has been assigned, you can access the value within the variable by putting a $ in front of the variable name

BASH

image="T1"
echo "My favorite images are $image scans."

OUTPUT

My favorite images are T1 scans.

See how it replaces $image with T1. Let’s do it again and assign a new value to image.

BASH

image="DTI"
echo "My favorite images are $image scans."

OUTPUT

My favorite images are DTI scans.

Looping

Variables are really helpful when we want to set up a loop. Let’s say we have images from 100 different subjects who are in our study, and we want to make sure that we process each of the images in the exact same way. You could type the commands out 100 times, where in each set of commands, you change the name of the image files. As you could imagine, that would be really boring, and there is definitely more risk of an error being introduced. A loop is a solution to this and makes your command writing much simpler. It is simply an instruction to the shell that says run the same command a bunch of times.

BASH

for name in David Ludovica Tobey Alexa Luigi
do
    echo "Hey ${name}, I need help!"
done

OUTPUT

Hey David, I need help!
Hey Ludovica, I need help!
Hey Tobey, I need help!
Hey Alexa, I need help!
Hey Luigi, I need help!

Here, the loop is setup with a for command, with the format for (var) in (list) where (var) is the variable name, and its value will change with each iteration of the loop and (list) holds the list of entries that you want to loop over. The for loop will determine how many entries are in the list. At each iteration, it will place the next value of the list in to the variable (in our example name) and execute the commands that are inside the keywords do (start the loop) and done (end the loop).

Redirection

Quite often, when you execute a command on the shell, it prints out information on the screen that is useful to store for later. You can store them in the file using redirection. The > says redirects the output from the screen to another location, such as a file, overwriting the current contents. The >> does the same thing but it just appends the contents at the end. This loop just prints the number and its square on the screen.

BASH

for i in 1 2 3 4 5 6 7 8 9 10
do 
    let j=i*i
    echo $i $j
done

OUTPUT

1 1
2 4
3 9
4 16
5 25
6 36
7 49
8 64
9 81
10 100

This loop does the same thing but saves it to a text file called squares.txt

BASH

for i in 1 2 3 4 5 6 7 8 9 10
do 
    let j=i*i
    echo $i $j >> squares.txt
done

Now if we show the contents of squares.txt, we see it has the same information.

BASH

cat squares.txt

OUTPUT

1 1
2 4
3 9
4 16
5 25
6 36
7 49
8 64
9 81
10 100

Redirection can also be used for getting input using the < character. This finds the line where 64 is the answer.

BASH

grep 64 < squares.txt

OUTPUT

8 64

Finally you can redirect output from one command into input of another command using the pipe character, |. In this case we are directing the output from the echo command from the screen to the input of the calculator command bc.

BASH

echo "242*242" | bc

OUTPUT

58564

Command line cheatsheet


Command Name Function Example Usage
man Manual HELP! man cd
pwd Print working directory Where am I? pwd
mkdir Make directory Create a new directory mkdir dir1
cd Change directory Go to the following location cd dir1
ls List Shows what is inside a directory ls dir1
cp Copy Copies a source file to a new destination cp src dest
mv Move Moves a source file to a new destination mv source destination
rm Remove Deletes a file or a directory rm dir1/bad_file
cat Concatenate Prints out the contents of a file cat results.txt
more more Prints out the contents of a file. Better for large files to scroll more results.txt
nano, emacs, gedit Text editor Programs that edit plain text files (no formatting) emacs dir1/inputs.txt nano dir1/inputs.txt

Key Points

  • The command line interface is a low-level way of interacting with your computer
  • It provides more control, more reliability, and more scalability than manually interacting with a graphical user interface.
  • Paths can be specified in two ways: an absolute path and a relative path. The absolute path remains the same regardless of the current location, where the relative path will change.
  • Help can be found by typing the man command