-
Notifications
You must be signed in to change notification settings - Fork 117
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add project to BHS2023 website (#259)
* Create index.md * Update index.md Fill out information * Modify project summary * Add image for project page * Update image name for project page
- Loading branch information
1 parent
68be5bc
commit cb75cf3
Showing
2 changed files
with
151 additions
and
0 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
151 changes: 151 additions & 0 deletions
151
content/en/project/NODDI-for-PD-biomarkers-in-SC/index.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,151 @@ | ||
--- | ||
type: "project" # DON'T TOUCH THIS ! :) | ||
date: "2023-65-08" # Date you first upload your project. | ||
# Title of your project (we like creative title) | ||
title: Identifying Potential Biomarkers for Parkinson’s Disease Using Neurite Orientation Dispersion and Diffusion Imaging (NODDI) | ||
|
||
# List the names of the collaborators within the [ ]. If alone, simple put your name within [] | ||
names: [Samuelle St-Onge] | ||
|
||
# Your project GitHub repository URL | ||
github_repo: https://github.com/brainhack-school2023/st-onge_project/tree/main | ||
|
||
# If you are working on a project that has website, indicate the full url including "https://" below or leave it empty. | ||
website: | ||
|
||
# List +- 4 keywords that best describe your project within []. Note that the project summary also involves a number of key words. Those are listed on top of the [github repository](https://github.com/brainhack-school2020/project_template), click `manage topics`. | ||
# Please only lowercase letters | ||
tags: [Parkinson's disease, spinal cord, NODDI, diffusion MRI] | ||
|
||
# Summarize your project in < ~75 words. This description will appear at the top of your page and on the list page with other projects.. | ||
|
||
summary: "In this project, I have explored the use of NODDI, a diffusion MRI technique, to identify potential biomarkers for Parkinson’s disease using spinal cord images. The goal of this project was to use an existing Matlab toolbox to perform NODDI fitting, and then use Python to analyze the extracted NODDI metrics to identify potential differences in these metrics with Parkinson's disease progression." | ||
|
||
# If you want to add a cover image (listpage and image in the right), add it to your directory and indicate the name | ||
# below with the extension. | ||
image: "bhs2023.png" | ||
--- | ||
<!-- This is an html comment and this won't appear in the rendered page. You are now editing the "content" area, the core of your description. Everything that you can do in markdown is allowed below. We added a couple of comments to guide your through documenting your progress. --> | ||
|
||
## Project definition | ||
|
||
### Background | ||
|
||
Parkinson’s disease is a neurogenerative disease for which we currently do not have any cure. Although there are treatment options available, early diagnosis is key to be able to start the treatment early and slow down the progression of the disease. However, since there are still a lot of things we don't quite understand about Parkinson's disease, it is oftentimes difficult to diagnose at early stages. During this project, I will be exploring the use of NODDI (a diffusion MRI technique) applied to spinal cord images in the case of Parkinson's disease. More specifically, I will be applying NODDI to spinal cord images acquired from Parkison's disease patients at various stages of the disease to identify potential biomarkers for Parkinson's disease, with the ultimate goal of helping clinicians diagnose the disease at an earlier stage, thus allowing early treatment to slow the progression of the disease. In recent work, diffusion MRI has shown a potential interest for finding biomarkers in the context of neurodegenerative diseases such as Parkinson, using Neurite Orientation Dispersion and Diffusion Imaging, commonly known as NODDI. | ||
|
||
NODDI is a diffusion MRI technique which aims to extract metrics based on the morphology of neurites, which are composed of dendrites and axons. The most common metrics that can be extracted from NODDI (Mitchell et al., 2019) are : | ||
|
||
1. Orientation Dispersion Index (ODI) : Measures the variability in neurite orientation | ||
2. Neurite Density Index (NDI) : Measures the density of neurites | ||
3. Isotropic Volume Fraction (Viso) : Measures the fractional volume of extracellular fluid | ||
|
||
![image](https://github.com/brainhack-school2023/st-onge_project/assets/57685132/817b3ce2-6291-44d0-ac00-b4f3d18e0756) | ||
|
||
My project aims to use an existing open-source NODDI toolbox to perform NODDI fitting of a spinal cord diffusion MRI dataset containing both healthy subjects and subjects diagnosed with Parkinson's disease. Then, using the data analysis tools and skills I have learned during BrainHack School, I have written a Python script to analyze the extracted metrics from the NODDI model fitting, which will then help me compare the metrics with the progression of the disease and identify potential biomarkers for Parkinson's disease. | ||
|
||
#### Why NODDI for Parkinson's disease? | ||
- Literature has shown an interest in diffusion MRI to identify potential Parkinson's disease biomarkers in brain images (Zhang et al., 2012) | ||
- Links have been found between neurite morphology and other neurodegenerative diseases, such as multiple sclerosis (Zhang et al., 2012) | ||
|
||
#### Why spinal cord images for Parkinson's disease biomarkers? | ||
- Spinal cord lesions have been recorded in Parkinson's disease patients (Tredici et al., 2012) | ||
- To our knowledge, NODDI in the spinal cord for Parkinson's disease patients has not yet been studied | ||
|
||
### Tools | ||
|
||
#### For NODDI fitting : | ||
Matlab : | ||
- [NODDI Matlab Toolbox](http://mig.cs.ucl.ac.uk/index.php?n=Tutorial.NODDImatlab) (UCL Microstructure Imaging Group, 2021) | ||
- [Matlab Parallel Computing Toolbox](https://www.mathworks.com/products/parallel-computing.html) | ||
- [Matlab Optimization Toolbox](https://www.mathworks.com/products/optimization.html) | ||
|
||
#### For registration and NODDI metric extraction : | ||
- The [Spinal Cord Toolbox](https://spinalcordtoolbox.com/) (De Leener et al., 2017) | ||
|
||
#### For data analysis : | ||
Python : | ||
- [`matplotlib`](https://matplotlib.org/) | ||
- [`nibabel`](https://nipy.org/nibabel/) | ||
- [`seaborn`](https://seaborn.pydata.org/) | ||
- [`nilearn`](https://nilearn.github.io/stable/index.html) | ||
|
||
#### For version control : | ||
- Git and Github | ||
|
||
### Data | ||
|
||
For this project, I have used a spinal cord dataset from our collaborators at McGill University. This dataset contains a total of 113 subjects, from which 87 have been diagnosed with Parkinson's disease at various stages of the disease ("low", "medium" and "advanced" stages) and the remaining 26 are healthy control subjects. The dataset contains other common MRI modalities, such as T1-weigthed and T2-weighted images. However, for the scope of BrainHack School, I have decided to focus only on the diffusion images. | ||
|
||
### Deliverables | ||
|
||
![image](https://github.com/brainhack-school2023/st-onge_project/assets/57685132/ed1381bc-9cbf-4733-8fbb-7a4e13cced9b) [Matlab script to perform multi-subject NODDI fitting](https://github.com/brainhack-school2023/st-onge_project/blob/main/scripts/NODDI_multi-subject_fitting.m) using the [NODDI Matlab Toolbox](http://mig.cs.ucl.ac.uk/index.php?n=Tutorial.NODDImatlab) (UCL Microstructure Imaging Group, 2021) | ||
|
||
![image](https://github.com/brainhack-school2023/st-onge_project/assets/57685132/90f42e61-d337-4421-8e0a-9df9a31409a7) [Python script to compute average NODDI metrics](https://github.com/brainhack-school2023/st-onge_project/blob/main/scripts/average_image_metrics.py) and display average images for each subject category (control subjects, low PD, medium PD and advanced PD) | ||
|
||
![image](https://github.com/brainhack-school2023/st-onge_project/assets/57685132/fa1ff39b-cef1-4d3b-a699-55679dc7ef47) [Python script to perform data analysis](https://github.com/brainhack-school2023/st-onge_project/blob/main/scripts/data_analysis_NODDI_metrics.py), i.e. regression plots to display and compare metrics (such as ODI, NDI and Viso) with Parkinson's disease progression. | ||
|
||
## Results | ||
|
||
### Progress overview | ||
|
||
The following diagram summarizes the key stages of the methods used for my project : | ||
|
||
![image](https://github.com/brainhack-school2023/st-onge_project/assets/57685132/0583b4c0-5d8c-40b5-9adf-4d2d486674bb) | ||
|
||
#### NODDI fitting : | ||
Starting with the diffusion MRI images from the dataset, I first performed NODDI fitting using the [NODDI Matlab Toolbox](http://mig.cs.ucl.ac.uk/index.php?n=Tutorial.NODDImatlab) (UCL Microstructure Imaging Group, 2021) from UCL Microstructure Imaging Group. Using this toolbox, I wrote a [Matlab script](https://github.com/brainhack-school2023/st-onge_project/blob/main/scripts/NODDI_multi-subject_fitting.m) to be able to perform multi-subject NODDI fitting with a BIDS-compliant dataset. The NODDI Matlab Toolbox also gives the user the option of using the Matlab Parallel Computing Toolbox, which speeds up the fitting process significantly. | ||
|
||
For the inputs, the NODDI Matlab Toolbox requires diffusion MRI files (`sub-PXXX_dwi.nii`, `sub-PXXX.bvec`, `sub-PXXX.bval`). It is also possible to specify a mask, in order to restrict the fitting to a certain region of the image (for example, only the spinal cord). In this specific project, I used segmentation files that had already been performed on 42 subjects prior to BrainHack School, by a previous graduate student. Initially, my goal was to start by performing NODDI fitting and metric analysis for these 42 subjects with the segmentation files, and then go back and segment the remaining subjects and re-run the NODDI fitting and metric analysis pipeline for the whole dataset. Howerver, I did not have enough time to go back and do the segmentation during BrainHack School. For this reason, I decided to focus only on 42 of the 113 subjects in the dataset for my Brainhack School project. | ||
|
||
#### Registration to PAM50 template | ||
Following NODDI fitting, I decided to perform registration on the output metrics to be able to compute an average metric for each subject category : control, low disease, medium disease and advanced disease. | ||
To perform the registration, I used the [`Spinal Cord Toolbox (SCT)`](https://spinalcordtoolbox.com/index.html) and followed the recommended steps in the documentation. | ||
|
||
The following diagram shows a summary of the `Spinal Cord Toolbox` pipeline for registration to the [`PAM50 template`](https://spinalcordtoolbox.com/overview/concepts/pam50.html?highlight=pam50) with DWI images : | ||
|
||
![image](https://github.com/brainhack-school2023/st-onge_project/assets/57685132/fff88b6a-7c3e-430c-b4b1-76cba46fbdd2) | ||
|
||
*Detailed explanations for each of these steps can be found in the [Spinal Cord Toolbox DWI tutorial](https://spinalcordtoolbox.com/user_section/tutorials/diffusion-weighted-mri/template-registration-for-dmri.html). | ||
|
||
#### Metric extraction using the Spinal Cord Toolbox | ||
Following NODDI fitting, to extract the values of the ODI, NDI and Viso metrics (which were all in NIFTI format following the NODDI fitting process with Matlab), I used the command [`sct_extract_metric`](https://spinalcordtoolbox.com/user_section/tutorials/diffusion-weighted-mri/extracting-dti-from-specific-regions.html) from the `Spinal Cord Toolbox`. The following diagram shows a summary of the command amd the arguments that were used for my project : | ||
|
||
![image](https://github.com/brainhack-school2023/st-onge_project/assets/57685132/3a0798dc-31d0-4344-b172-0e62c97bec6d) | ||
|
||
The command `sct_extract_metric` outputs a .csv file for the metric from the file specified in the `-i` argument. For this specific project, I chose the labels 50, 51 and 52 with the `-l` argument, which correspond to the spinal cord, white matter and gray matter. I also chose to extract metrics from C2 to C5, using the `-vert` argument. | ||
|
||
### Results | ||
|
||
#### Computing average metrics | ||
|
||
Following the registration to the PAM50 template, I have written a [Python script to compute average metrics](https://github.com/brainhack-school2023/st-onge_project/blob/main/scripts/average_image_metrics.py) and display them as images. The following image shows an example of the average orientation dispersion index (ODI) for each subject category (control, low PD, medium PD and advanced PD). | ||
|
||
<p align="center"> | ||
<img src="https://github.com/brainhack-school2023/st-onge_project/assets/57685132/87377dc2-df84-4e68-99f1-dc09762d48b6"> | ||
</p> | ||
|
||
By looking at the image above, we can notice an offset between the images used to compute the average. This is most likely due to a problem with the registration step. Following BrainHack School, I would like to try the registration with different parameters to see if I can fix this offset. | ||
|
||
#### Regression plots | ||
|
||
I have also written a [Python script for data analysis](https://github.com/brainhack-school2023/st-onge_project/blob/main/scripts/data_analysis_NODDI_metrics.py), which takes the metrics from the .csv files obtained with the `sct_extract_metric` command to do regression plots. The image below shows an example of the regression plots that can be achieved with this script. | ||
|
||
<p align="center"> | ||
<img src="https://github.com/brainhack-school2023/st-onge_project/assets/57685132/7f2783f1-7038-42a0-aff7-72da5fb66a05"> | ||
</p> | ||
|
||
The plots are divided by vertebrae level (in this example, from C2 to C5) as well as by label (white matter, gray matter and spinal cord). In each plot, we can observe the metric with the progression of the disease (from control subjects to advanced Parkinson's disease subjects). | ||
|
||
In this specific project, since I have used only 42 subjects, there is not enough data to draw any conclusions, nor identify potential biomarkers for Parkinson's disease. Also, future versions of the Python script should include a regression model with p-values, to be able to perform a more rigorous statistical analysis. | ||
|
||
In future work, after having improved the python script to include p-values, I would like to perform the analysis for the entire dataset (113 subjects). By repeating the analysis with the entire dataset, I would suspect seeing an increase in ODI in the white matter and a decrease in ODI in the gray matter, since these have been linked to neurodegeneration according to literature (Zhang et al., 2012). | ||
|
||
#### Limitations and future work | ||
|
||
Following BrainHack School, I would like to pre-process the entire dataset, by also adding [motion correction using the Spinal Cord Toolbox](https://spinalcordtoolbox.com/user_section/tutorials/diffusion-weighted-mri/motion-correction-for-dmri.html). I would also like to use a larger mask to perform the NODDI fitting. As I mentionned in the "Methods" section above, in this project I used segmentation files as a mask for the NODDI fitting. However, it would be interesting to try a mask that is larger than the segmentation of the spinal cord to see if it can help reduce potential partial volume effect. Furthermore, I would like to try performing the registration to the PAM50 template prior to the NODDI fitting, to be able to extract the metric values and compute average images directly from the output metrics. | ||
|
||
Regarding the metric analysis, I would like to try the registration to the PAM50 template with different parameters to fix the offset I have with the current results. For the regression plots, it would be important to consider the age as a control variable, to avoid overestimating the effect of Parkinson's disease progression when performing the regression analysis. Finally, I would like to incorporate a regression model with p-values to perform more rirogous statistics on the different NODDI metrics. | ||
|
||
## Conclusion and acknowledgement | ||
|
||
As a new PhD student, BrainHack school was a great opportunity for me to learn about the basics of neuroscience imaging and data analysis. Although there are still some improvements to be made regarding my project, I look forward to apply the tools and skills I have learned during BrainHack School to work on improving what I have implemented so far. |