Skip to main content

Deep Learning models module for Dafne

Project description

dafne-models

Repository for model generators

Important!

git-lfs is required to properly check out the model weights for the "thigh" and "leg" models.

How to use the model trainer

The model trainer is a python script that can be used to train a model on a set of images. It is based on the keras library and uses a tensorflow backend. The model architecture is 2D and is the same as the "thigh" and "leg" models, that is, a modified V-Net.

The input data is in the form of "Numpy bundle" files, which contain the image dataset with the "data" key, the resolution under the "resolution" key, in the form of a numpy vector with 2 or 3 elements corresponding to the voxel size in the three dimensions, and various binary masks in the form of 3D numpy arrays with the same dimensions as the data with "mask_", "mask_" etc. keys (where and are the names of the regions of interest, e.g. mask_tibia, mask_fibula, etc).

This numpy bundle can (and should) be saved from Dafne by selecting the "Export masks"->"Numpy bundle" option.

Once multiple such datasets are collected under the same folder, the model trainer can be used.

Usage

The recommended usage is by using the GUI for fitting, as it allows a wider range of options. Assuming you have cloned the dafne_models repository, install it locally together with its dependencies with

pip install -e .[gui]

Then, run the GUI with

python create_model_ui.py

or simply with

create_model_ui

Load the data by clicking on "Choose" next to the "Data location" field and selecting the folder containing the numpy bundles. Then, select the model name and the output folder and click on "Fit model". The model will start training. You can monitor the progress from the plots that will be displayed. On the right, one segmentation of a validation slice is displayed at the end of every epoch. The slider on the bottom chooses which validation slice is displayed. Next to it, a checkbox lets the user choose whether the training should be stopped when the validation loss starts to increase. This is useful to avoid overfitting, but the user can choose to stop it manually instead.

The model will be saved in the output folder as a keras model (.hdf5 file) and as a dafne model (.model file). A .py file is also saved to build the .model file from the .hdf5 file.

Importing a new model into Dafne

The model can be imported into Dafne by selecting "Local" as the model location in the settings, and then choosing "Import model" from the "File" menu. If ou don't see "Import model" under the "File" menu, double-check that the Model location is set to "Local".

Caveats

It is highly recommended to have a correctly configured GPU for the training. Make sure that you have tensorflow installed for the python version that you are using, and that the GPU libraries are compatible with this tensorflow version.

Command line usage

A command-line model trainer is also provided. It can be used to train a model from the command line, without the GUI. It is recommended to use the GUI instead, as it allows a wider range of options.

To train a model from the command line, run

python create_model.py <model_name> <data folder>

where <data_folder> is the folder containing the numpy bundles, and <model_name> is the name of the model to be trained. The model will be saved in the current folder.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dafne_models_torch_models-2.0a3.tar.gz (35.3 kB view details)

Uploaded Source

Built Distribution

dafne_models_torch_models-2.0a3-py3-none-any.whl (36.2 kB view details)

Uploaded Python 3

File details

Details for the file dafne_models_torch_models-2.0a3.tar.gz.

File metadata

File hashes

Hashes for dafne_models_torch_models-2.0a3.tar.gz
Algorithm Hash digest
SHA256 6041739f4ffc486b871955aa2fd6697364c54a042ed577ac0a6b6d7c579172fd
MD5 58165a56afd52e081da8d74d058ff6a5
BLAKE2b-256 f37e9023b9f5442c05230abe10c65b9a1025ae150018ebd96439f89ed2ffe05b

See more details on using hashes here.

File details

Details for the file dafne_models_torch_models-2.0a3-py3-none-any.whl.

File metadata

File hashes

Hashes for dafne_models_torch_models-2.0a3-py3-none-any.whl
Algorithm Hash digest
SHA256 378c148d3690ac9a23323dcee0e01a48d8f990440b2e5b0204e3a2af1ad9596b
MD5 fcf9dd25b60f3f2691b5424fbe1b8b75
BLAKE2b-256 3be818676adee160765c86ab3815b3ca6fb3d2580df515fec19fcfa43426e90f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page