This repository extends the popular nnUNet framework with methods that allow for safer on-the-wild use. This includes functionality for continual learning and out-of-distribution detection. With only one line of code, you can now train a model sequentially with different datasets.
You can monitor the performance throughout the training process, as illustrated below for the task of hippocampus segmentation, and output continual learning metrics such as backward and forward transfer.
The supported nnUNet version is specified in the requirements.txt file. Please note that, at times, files are replicated from this version and adapted as needed. If you wish to use a newer nnUNet version, please make sure that all adapted files are consistent with that version. For the current continual_learning
branch, this does not apply, ie. no files are replicated.
This branch currently includes the following methods for Continual Learning:
- Sequential Training
- Rehearsal Training
- Riemannian Walk
- Elastic Weight Consolidation
- Learning Without Forgetting
- Modeling the Background
- Pseudo-labeling and LOcal Pod
All other methods have been used for experiments and are not further discussed since the name should be self explanatory, for instance:
- Elastic Weight Consolidation only applied on LayerNorm layers of the Vision Transformer (ewc_ln)
- Elastic Weight Consolidation only applied on nnU-Net layers (ewc_unet)
- Elastic Weight Consolidation only applied on Vision Transformer layers (ewc_vit)
- Sequential Training while freezing all parameters except the LayerNorm parameters from the Vision Transformer after the successfull training of the first task (frozen_nonln)
- Sequential Training while freezing all parameters from the Vision Transformer after the successfull training of the first task (frozen_vit)
- Sequential Training while freezing all parameters from the nnU-Net after the successfull training of the first task (frozen_unet)
Note that all those just described trainers are not further described in the documentations. Further, all those trainers can only be used with the Generic_ViT_UNet architecture instead of the classic Generic_UNet architecture, so the --use_vit
and all corresponding ViT related arguments have to be set or the training will fail.
For instructions on how to run these please see here.
The simplest way to install all dependencies is by using Anaconda:
- Create a Python 3.9 environment as
conda create -n <your_conda_env> python=3.9
and activate it asconda activate <your_conda_env>
. - Install CUDA and PyTorch through conda with the command specified by PyTorch. The command for Linux was at the time
conda install pytorch torchvision cudatoolkit=11.3 -c pytorch
. At least PyTorch version 1.6 is required, and the code was last tested with version 1.9. Pytorch and TorchVision versions can be specified during the installation asconda install pytorch==<X.X.X> torchvision==<X.X.X> cudatoolkit=<X.X> -c pytorch
. Note that the cudatoolkit version should be of the same major version as the CUDA version installed on the machine, e.g. when using CUDA 11.x one should install a cudatoolkit 11.x version, but not a cudatoolkit 10.x version. - Navigate to the project root (where
setup.py
lives). - Execute
pip install -r requirements.txt
to install all required packages. With this step, the original nnUNet will be installed as well, so all commands described there will work. Please note that the nnUNet commit to install is specified in requirements.txt, the code may not work for other versions of the nnUNet. - Set your paths as described here. You should set these paths.
- Execute
pytest
to ensure that everything is working. All tests should work, however multiple tests specifically use at least one GPU. Please refer to this file for more information.
Following environment variables must be set for all Lifelong-nnUNet branches:
- nnUNet_raw_data_base
- nnUNet_preprocessed
- RESULTS_FOLDER
- EVALUATION_FOLDER
Refer to this file for a description of how to set these.
In our preprint Lifelong nnUNet: a framework for standardized medical continual learning, we summarize benchmark results for three medical imaging use cases: segmentation of the prostate and hippocampus on MRIs and of pulmonary embolism in chest CTs.
In certain cases you may wish to change the meaning of certain labels or merge different labels in order to harmonize label structures between datasets. Please refer to this file for instructions on how to do this.
If you are using Lifelong-nnUNet for your article, please cite the following paper:
@article{gonzalez2023lifelong,
title={Lifelong nnU-Net: a framework for standardized medical continual learning},
author={Gonz{\'a}lez, Camila and Ranem, Amin and Pinto dos Santos, Daniel and Othman, Ahmed and Mukhopadhyay, Anirban},
journal={Scientific Reports},
volume={13},
number={1},
pages={9381},
year={2023},
publisher={Nature Publishing Group UK London}
}