OncoServe: Deploying Deep Learning Models for Breast Cancer Risk Assessment, and Breast Density Assessment.
-
Put all
.dcm
images inside thedataset
folder; -
Download Density and put the
oncoserve_density_0.1.0.tar
file inside thedockerimg
folder; -
If it is your first time loading the
oncoserve_density_0.1.0.tar
file, you need to do the following command:
docker load < dockerimg/oncoserve_density_0.1.0.tar
- To start, just do:
docker compose up
P.S.: note that this may take a while.
- In the end, you need to finish the full process by doing:
docker compose down
This repository shares the models described in Towards Robust Mammography-Based Models for Breast Cancer Risk and Mammographic Breast Density Assessment Using Deep Learning: Clinical Implementation as a (Flask) webserver. You can send the webserver regular HTTP requests with a list of dicoms for a given mammogram, and a set of metadata keys (like MRN or Accession), and the webserver will return the model predictions along back with the same metadata. We note that we do not support all dicom formats, we assume presentation view mammograms, and have only tested this system with Hologic mammograms.
OncoServe spins up a webserver in a docker container encapsulating all the software requirments to convert dicoms, and run the deep learning models. It imports Mirai (and OncoNet for older models) and OncoData as submodules.
The repositories perform the following functions:
- OncoData: handles conversion from dicom to png
- Mirai and OncoNet : used for model development and training.
- OncoServe: Wraps model in a webserver that allows it to return outputs in real time given an HTTP request. Used in clinical implementations.
- Docker
- 32 GB of RAM, 32GB of Disk.
-
First, download the correct docker image from the following links: Mirai, Density.
-
Pull load the docker image from dockerhub.
docker load < filename.tar
-
Start the docker container following the instructions for the specific application (listed bellow).
docker run -p 5000:5000 --shm-size 32G -e CONFIG_NAME=config.DensityConfig learn2cure/oncoserve_density:0.1.0
docker run -p 5000:5000 --shm-size 32G learn2cure/oncoserve_mirai:0.5.0
Once your webserver is setup, you can get model assessments by sending it HTTP requests.
See tests/demo.py
for a usage example in python or tests/demo.js
for a usage example in javascript. The python demo is organized as a python test case. Note, you'll need to update the paths in the setUp function in the demo to refer to real dicom paths (see comments in the file).
See the Mirai github. This will require logging into the docker container with a shell and running our batch processing scripts.
Note, batch processing is not supported under the density application.
Please email [email protected].
This tool and all associated code is provided for under MIT License.