Skip to content

Using different 2d and 3d U-Nets to segment MR brain scans.

Notifications You must be signed in to change notification settings

till2/brain_tumor_segmentation

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Brain Tumour Segmentation (BraTS) on the Basis of a
U-Net architecture

BraTS Dataset

A 3D MRT scan (background removed).
Labeled brain Edema.

How to run our code

Set up the project

  1. Download "Task01_BrainTumour.tar" under the Medical Segmentation Decathlon website and extract the tar file.
  2. Provide the following folder structure:
BT_Segmentation_Project
    |_ README.md
    |_ Code
       |_ Data_Extraction.ipynb     (this file)
       |_ ...
    |_ Task01_BrainTumour           (Dataset)
       |_ dataset.json
       |_ imagesTr                  (here are the compressed nii-files)
       |_ labelsTr
       |_ imagesTs
    |_ Weights                      (trained model weights)
  1. Change into "Code" as a working directory
  2. Run "python3 setup_project.py" in your shell, to extract the nii-files to numpy file (Attention!: bear in mind that the dataset needs 70+ GB of storage)

Additional ressources for our code

High-level code overview (Click to expand)

Code Overview

Notebooks

  • demo.ipynb:
    Here we present our model training along with evaluation metrics and animated visualizations. The majority of what we report in our paper is produced using this code.

Python-files

  • custom_losses.py:
    Contains custom programmed losses. In addition you can find the get_loss function to automatically calculate the loss for a provided loss-function.

  • data_loading.py:
    This is the dataloader. The function get_train_test_iters gives you the data iterators.

  • dataset_utils.py:
    Here we coded all functions for manipulating and processing data.

  • train.py:
    Here you can find the train_model function to train a model.

Folders

  • Optional:
    Here we stored additional experimental code that was not ultimately used in our trained models or demo.

  • Architectures:
    Here you can find all model architectures that we built.

File-structure figure (Click to expand)-

Useful links

Our executive report
Github repo
Model files

Acknowledgements

We would like to thank Prof. Dr. Chistoph Lippert, Tahir Miriyev, Noel Danz, Eshant English and Wei-Cheng Lai for sharing their experience and expertise with us. Special thanks to Noel Danz who gave insightful tips and comments to help guide the project.

Used Github-repos

About

Using different 2d and 3d U-Nets to segment MR brain scans.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 92.2%
  • Python 7.8%