|
# Brain Imaging Generation with Latent Diffusion Models |
|
|
|
### **Authors** |
|
|
|
Walter H. L. Pinaya, Petru-Daniel Tudosiu, Jessica Dafflon, Pedro F Da Costa, Virginia Fernandez, Parashkev Nachev, |
|
Sebastien Ourselin, and M. Jorge Cardoso |
|
|
|
### **Tags** |
|
Synthetic data, Latent Diffusion Model, Generative model, Brain Imaging |
|
|
|
## **Model Description** |
|
This model is trained using the Latent Diffusion Model architecture [1] and is used for the synthesis of conditioned 3D |
|
brain MRI data. The model is divided into two parts: an autoencoder with a KL-regularisation model that compresses data |
|
into a latent space and a diffusion model that learns to generate conditioned synthetic latent representations. This |
|
model is conditioned on age, sex, the volume of ventricular cerebrospinal fluid, and brain volume normalised for head size. |
|
|
|
 <br> |
|
<p align="center"> |
|
Figure 1 - Synthetic image from the model. </p> |
|
|
|
|
|
## **Data** |
|
The model was trained on brain data from 31,740 participants from the UK Biobank [2]. We used high-resolution 3D T1w MRI with voxel size of 1mm3, resulting in volumes with 160 x 224 x 160 voxels |
|
|
|
#### **Preprocessing** |
|
We used UniRes [3] to perform a rigid body registration to a common MNI space for image pre-processing. The voxel intensity was normalised to be between [0, 1]. |
|
|
|
## **Performance** |
|
This model achieves the following results on UK Biobank: an FID of 0.0076, an MS-SSIM of 0.6555, and a 4-G-R-SSIM of 0.3883. |
|
|
|
Please, check Table 1 of the original paper for more details regarding evaluation results. |
|
|
|
|
|
## **commands example** |
|
|
|
Execute sampling: |
|
|
|
```shell |
|
python -m monai.bundle run --config_file configs/inference.json --gender 1.0 --age 0.7 --ventricular_vol 0.7 --brain_vol 0.5 |
|
``` |
|
|
|
All conditioning are expected to have values between 0 and 1 |
|
|
|
## Using a new version of the model |
|
|
|
If you want to use the checkpoints from a newly fine-tuned model, you need to set parameter load_old to 0 when you run inference, |
|
to avoid the function load_old_state_dict being called instead of load_state_dict to be called, currently default, as it is |
|
required to load the checkpoint from the original GenerativeModels repository. |
|
|
|
```shell |
|
python -m monai.bundle run --config_file configs/inference.json --gender 1.0 --age 0.7 --ventricular_vol 0.7 --brain_vol 0.5 --load_old 0 |
|
``` |
|
|
|
## **Citation Info** |
|
|
|
```bibtex |
|
@inproceedings{pinaya2022brain, |
|
title={Brain imaging generation with latent diffusion models}, |
|
author={Pinaya, Walter HL and Tudosiu, Petru-Daniel and Dafflon, Jessica and Da Costa, Pedro F and Fernandez, Virginia and Nachev, Parashkev and Ourselin, Sebastien and Cardoso, M Jorge}, |
|
booktitle={MICCAI Workshop on Deep Generative Models}, |
|
pages={117--126}, |
|
year={2022}, |
|
organization={Springer} |
|
} |
|
``` |
|
|
|
## **References** |
|
|
|
Example: |
|
|
|
[1] Pinaya, Walter HL, et al. "Brain imaging generation with latent diffusion models." MICCAI Workshop on Deep Generative Models. Springer, Cham, 2022. |
|
|
|
[2] Sudlow, Cathie, et al. "UK biobank: an open access resource for identifying the causes of a wide range of complex diseases of middle and old age." PLoS medicine 12.3 (2015): e1001779. |
|
|
|
[3] Brudfors, Mikael, et al. "MRI super-resolution using multi-channel total variation." Annual Conference on Medical Image Understanding and Analysis. Springer, Cham, 2018. |
|
|