Skip to content
/ mrnet Public
forked from ahmedbesbes/mrnet

Building an ACL tear detector to spot knee injuries from MRIs with PyTorch (MRNet)

License

Notifications You must be signed in to change notification settings

therc01/mrnet

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MIT contributions welcome Twitter Stars

Deep learning in medical imaging: How to automate the detection of knee injuries in MRI exams ?

This repository contains an implementation of a convolutional neural network that classifies specific knee injuries from MRI exams.

It also contains the matieral of a series of posts I wrote on my blog.

Dataset: MRNet

The data comes from Stanford ML Group research lab. It consits of 1,370 knee MRI exams performed at Stanford University Medical Center to study the presence of Anterior Cruciate Ligament (ACL) tears.

For more information about the ACL tear problem and the MRNet data please refer to my blog post where you can investigate the data and build the following data visualization in jupyter notebook:

To learn more about the data and how to realize this visualization widget, read my first post.

Code structure:

This charts summarizes the architecture of the project:

For more details about the code, please refer to my second blog post .

How to use the code:

If you want to retrain the network on your own you have to ask for the data from Stanford via this link.

Once you download the data, create a data folder and place it at the root of the project. You should have two folders inside: train and valid as well as a bunch of csv files.

To run the script you can execute it with the following arguments:

parser = argparse.ArgumentParser()
    parser.add_argument('-t', '--task', type=str, required=True,
                        choices=['abnormal', 'acl', 'meniscus'])
    parser.add_argument('-p', '--plane', type=str, required=True,
                        choices=['sagittal', 'coronal', 'axial'])
    parser.add_argument('--prefix_name', type=str, required=True)
    parser.add_argument('--augment', type=int, choices=[0, 1], default=1)
    parser.add_argument('--lr_scheduler', type=str,
                        default='plateau', choices=['plateau', 'step'])
    parser.add_argument('--gamma', type=float, default=0.5)
    parser.add_argument('--epochs', type=int, default=50)
    parser.add_argument('--lr', type=float, default=1e-5)
    parser.add_argument('--flush_history', type=int, choices=[0, 1], default=0)
    parser.add_argument('--save_model', type=int, choices=[0, 1], default=1)
    parser.add_argument('--patience', type=int, default=5)
    parser.add_argument('--log_every', type=int, default=100)

example to train a model to detect acl tears on the sagittal plane for a 20 epochs:

python train.py -t acl -p sagittal --prefix_name demo --epochs=20

--prefix_name is a required parameter with an argument.

Note: Before running the script, add the following (empty) folders at the root of the project:

  • models
  • logs

Results:

I trained an ACL tear classifier on a sagittal plane and got the following AUC scores:

  • on train: 0.8669
  • on validation: 0.8850

Logs on Tensorboard:

Contributions - PR are welcome:

If you feel that some functionalities or improvements could be added to the project, don't hesitate to submit a pull request.

About

Building an ACL tear detector to spot knee injuries from MRIs with PyTorch (MRNet)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%