Skip to main content

Generate simulation-ready 3D heart meshes from CT and MR images

Project description

LinFlo-Net

New to LinFlo-Net? See the Quick start guide for install and prediction in a few minutes.

Install: pip install linflonet (PyPI)

Pre-trained weights: Zenodo (DOI: 10.5281/zenodo.20802633)

A deep learning package to automatically generate simulation ready 3D meshes of the human heart from biomedical images. Link to paper.

image

For SLURM-based clusters (e.g. Berkeley Savio), see Setting up environment on Savio.

Install from PyPI

For prediction only (Python 3.10+), install from PyPI:

pip install linflonet

pytorch3d is required but not listed as a pip dependency because it must be built from source on most platforms. Install torch first, then:

pip install --no-build-isolation "git+https://github.com/facebookresearch/pytorch3d.git@stable"

Pre-trained model weights

Pre-trained PyTorch weights for inference are available on Zenodo (DOI: 10.5281/zenodo.20802633).

Download and extract the archive (~395 MB):

curl -L -o LinFlo-Net_weights.zip \
    "https://zenodo.org/records/20802633/files/LinFlo-Net_weights.zip?download=1"
unzip LinFlo-Net_weights.zip

This provides best_model.pth, the combined-4 LT+flow checkpoint (linear transform + flow deformation). Place it at model/best_model.pth. The same checkpoint is used for CT and MR inputs; set the modality at inference time with --modality ct or --modality mr.

CLI usage

The linflonet command generates heart meshes (.vtp) and segmentations for CT or MR images using the combined-4 LT+flow checkpoint.

Batch prediction (config-driven):

linflonet predict --config config/WH/ct/flow/combined-4/predict_test_meshes_ct.yml

Single image:

linflonet predict \
    --image /path/to/scan.nii.gz \
    --model model/best_model.pth \
    --modality ct \
    --output /path/to/output

Folder of images (flat folder or image/ subdirectory):

linflonet predict \
    --folder /path/to/images \
    --model model/best_model.pth \
    --modality mr \
    --output /path/to/output

Using a YAML config (see config/predict_single_ct.yml or config/WH/ct/flow/combined-4/predict_test_meshes_ct.yml):

linflonet predict --config config/predict_single_ct.yml --image /path/to/scan.nii.gz -o /path/to/output

Outputs are written to <output>/meshes/ and <output>/segmentation/.

You can also run python -m linflonet predict ... or install in editable mode from a git checkout:

pip install -e .

Setting up a local environment with pip (Python 3.12)

If you only need to run prediction (not training), you can set up a lightweight environment on Python 3.12 using requirements-py312.txt.

First, initialize the vtk_utils submodule and create a virtual environment,

git submodule update --init
python3.12 -m venv .venv
source .venv/bin/activate
pip install -r requirements-py312.txt

pytorch3d does not ship prebuilt wheels for most platforms and must be built from source after torch is installed. Its setup.py imports torch at build time, so you must disable pip's build isolation (otherwise you get ModuleNotFoundError: No module named 'torch'):

pip install --no-build-isolation "git+https://github.com/facebookresearch/pytorch3d.git@stable"

On macOS, make sure the Xcode command-line tools are installed first (xcode-select --install) so the C++ extension can compile.

Dataset Creation

We use the multi-modality whole heart segmentation challenge (MMWHS) dataset. Download and unzip the data. You should have the following folders,

  • CT : 2 folders each with 10 images and corresponding segmentations
  • MR : 1 folder with 20 images and corresponding segmentations

You can split the data into train and validation as you find appropriate. We chose to use the first 16 samples as training and the remaining 4 samples as validation. Split the data appropriately and place them in separate folders. Make sure to keep the CT and MR data separately as we will need to normalize / scale them differently. We will perform data augmentation on the training data.

Data augmentation

We will use the data augmentation procedure available in the MeshDeformNet package. Clone this package to your system and run pip install -r requirements.txt to install package dependencies. (You may want to create a virtual environment first.)

To perform augmentation, modify the command below and execute it. The script below launches 16 jobs in parallel (-np 16). You can modify that depending on the capacity of the system you are using.

mpirun -np 16 python ~/path/to/MeshDeformNet/data/data_augmentation.py \
    --im_dir /path/to/image/directory \
    --seg_dir /path/to/segmentation/directory \
    --out_dir /path/to/output/directory \
    --modality ct or mr \
    --mode train \
    --num number_of_augmentations

The output folder will contain two subfolders modality_train with the augmented images and modality_train_seg with the augmented segmentations where modality is either ct or mr.

Creating ground-truth meshes

We generate ground-truth meshes using marching cubes on the ground-truth segmentations. We can do this using workflows/prepare_data.py.

python workflows/prepare_data \
    --image /path/to/image/folder \
    --segmentation /path/to/segmentation/folder \
    --output /path/to/output/folder \
    --modality ct # can be either ct or mr
    --ext .nii.gz # input files extension

The output folder is going to have 3 subfolders : seg, vtk_image, vtk_mesh. vtk_image will be the input to our neural network, and vtk_mesh will be the corresponding ground truth meshes. From this point onward, we assume that the folder with the relevant data has the vtk_image and vtk_mesh subfolders.

Final steps

The data set is reasonably large, and we will have to load it from memory. It is useful to store the images as pytorch tensors and the meshes as pytorch3d data structures in pickled files. To do this, we first build a csv index of all the files.

python utilities/prepare_train_dataset_csv.py -f /path/to/data/folder

Make sure to provide the path to the parent directory containing vtk_image and vtk_mesh sub-directories. This will create an index.csv in the parent folder with the names of all files. Next,

python utilities/pickle_image_segmentation_mesh_dataset.py -config /path/to/config/file

Look at config/pickle_dataset.yml for an example config file. Note that seg_label in the config file follows the labelling convention of the MMWHS dataset.

The output folder will now contain .pkl files which contain the combined image, segmentations, and meshes in a dictionary. This can be used by our dataloader to load the appropriate files during training.

Training the model

Before training, make sure to activate the conda environment that we created earlier. Request a GPU session if you would like to use a GPU for training. Alternatively, submit the below commands as part of a batch job with sbatch on a SLURM system. The training workflow will save the best performing model as a checkpoint in the output directory specified in the config file.

Training Linear Transformation module

Take a look at the example config file in config/linear_transform.yml. Make a copy, and modify it appropriately.

Then run the command,

python workflows/train_linear_transform.py -config /path/to/config/file

Training the Flow Deformation module

Take a look at the example config file in config/flow_deformation.yml. Make a copy, and modify it appropriately. In particular, make sure you provide the path to the linear transformation module trained in the previous step.

Then run the command,

python workflows/train_flow_with_udf.py -config /path/to/config/file

Using trained models on new data

Download the pre-trained weights from Zenodo (see Pre-trained model weights above) and place them at model/best_model.pth. The model takes a CT or MR image and outputs a deformed heart mesh (.vtp) and a segmentation rasterized to image space.

Batch prediction:

linflonet predict --config config/WH/ct/flow/combined-4/predict_test_meshes_ct.yml

Single image:

linflonet predict \
    --image /path/to/scan.nii.gz \
    --model model/best_model.pth \
    --modality ct \
    --output /path/to/output

Folder of images (flat folder or image/ subdirectory):

linflonet predict \
    --folder /path/to/images \
    --model model/best_model.pth \
    --modality mr \
    --output /path/to/output

See the Quick start guide for full install and usage details.

Legacy prediction scripts

The repository also includes YAML-driven workflows used during development. For the combined-4 LT+flow checkpoint, the CLI replaces:

python utilities/prepare_test_data_csv.py -f data_coro -e .mha
python utilities/predict_test_meshes.py -config config/WH/ct/flow/combined-4/predict_test_meshes_ct.yml

Research-only scripts such as utilities/predict_udf_test_meshes.py remain in the repo but are not exposed via the CLI.

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

linflonet-0.4.0.tar.gz (9.7 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

linflonet-0.4.0-py3-none-any.whl (9.7 MB view details)

Uploaded Python 3

File details

Details for the file linflonet-0.4.0.tar.gz.

File metadata

  • Download URL: linflonet-0.4.0.tar.gz
  • Upload date:
  • Size: 9.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.10

File hashes

Hashes for linflonet-0.4.0.tar.gz
Algorithm Hash digest
SHA256 55e51c0bbd3e600f3753d88cb99b8573654940f1d77e49dbf0191babb47cffd1
MD5 c6f6c3932020d6c12611778850db3137
BLAKE2b-256 28e52f84df2a67f95e8cbb4f7447500e76aa953d4af7bd38f27750398b20ff3b

See more details on using hashes here.

File details

Details for the file linflonet-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: linflonet-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 9.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.10

File hashes

Hashes for linflonet-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 839fdeb6b35da22d573b11fb3a6db0fce04ffa0dbcfe8f1c19c00045b7a6b7b5
MD5 24fbd0d269c50a5eddcd40492033c11e
BLAKE2b-256 2567ecf76a8214d419311953ec21565a93658d59ad16006f8958c85181764ea5

See more details on using hashes here.

Supported by

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