Skip to main content

PDE-G-CNN package for PyTorch

Project description

LieTorch

This project provides a python package that expands the functionality of the PyTorch framework with PDE-based group equivariant CNN operators [1].

The name

The name LieTorch is a reference to the Norwegian mathematician Sophus Lie, whose contributions to geometry are extensively used in this project. The name is pronounced /li:/ (as in Lee) and not /ˈlī/ (as in lie).

Installation

The version of LieTorch you install must match the installed PyTorch version per the following table.

PyTorch version LieTorch version
2.5 0.7
2.0 0.6
1.13 0.5
1.12 0.4

The following commands will install PyTorch and the lietorch package in a fresh conda environment.

  conda create -n <environment name>
  conda activate <environment name>

  # install PyTorch the usual way
  pip install torch torchvision torchaudio

  # or install with pip
  pip install lietorch

Make sure your Nvidia drivers are up to date!

Neural network modules

Modules are grouped according to the manifold they operate on. Most modules have a functional equivalant in the lietorch.nn.functional namespace.

Euclidean Space ℝ²

Basic operators:

Module Functional C++/CUDA backend
MorphologicalConvolutionR2 morphological_convolution_r2
FractionalDilationR2 fractional_dilation_r2
FractionalErosionR2 fractional_erosion_r2
ConvectionR2 convection_r2
DiffusionR2 diffusion_r2
LinearR2 linear_r2

Position and Orientation Space 𝕄₂

Basic operators:

Module Functional C++/CUDA backend
LiftM2Cartesian lift_m2_cartesian -
ReflectionPadM2 reflection_pad_m2 -
ConvM2Cartesian conv_m2_cartesian -
MaxProjectM2 max_project_m2 -
AnisotropicDilatedProjectM2 anisotropic_dilated_project_m2
MorphologicalConvolutionM2 morphological_convolution_m2
LinearConvolutionM2 linear_convolution_m2
ConvectionM2 convection_m2
DiffusionM2 diffusion_m2
FractionalDilationM2 fractional_dilation_m2
FractionalErosionM2 fractional_erosion_m2
LinearM2 linear_m2

High-level modules for implementing PDE-based networks:

Module Description/PDE
ConvectionDilationPdeM2 $u_t=-\mathbf{c}u + \lVert \nabla u \rVert^{2 \alpha}_{\mathcal{G}}$
ConvectionErosionPdeM2 $u_t=-\mathbf{c}u - \lVert \nabla u \rVert^{2 \alpha}_{\mathcal{G}}$
CDEPdeLayerM2 $u_t=-\mathbf{c}u + \lVert \nabla u \rVert^{2 \alpha}_{\mathcal{G}_1} - \lVert \nabla u \rVert^{2 \alpha}_{\mathcal{G}_2}$
with batch normalization and linear combinations

Loss functions

Additional loss functions.

Module Functional Description
lietorch.nn.loss.DiceLoss lietorch.nn.functional.dice_loss Binary DICE loss

Generic

The modules in the generic category do not fit into any previous category and include operators that serve as C++/CUDA implementation examples.

Module Functional C++/CUDA backend
GrayscaleDilation2D grayscale_dilation_2d
GrayscaleErosion2D grayscale_erosion_2d

Dependencies

The included experiments additionally depend on the following packages.

  • scikit-learn
  • tqdm
  • numpy
  • sty
  • mlflow
  • libtiff

Structure

  • /lietorch contains the main python package.
  • /experiments contains various experiments, including those used in publications.
  • /tests contains unit tests.
  • /backend contains the source code of the C++/CUDA backend,
  • /assets various files used in tests and documentation.

Cite

If you use this code in your own work please cite our paper:

[1] Smets, B.M.N., Portegies, J., Bekkers, E.J. et al. PDE-Based Group Equivariant Convolutional Neural Networks. J Math Imaging Vis (2022). https://doi.org/10.1007/s10851-022-01114-x

@article{smets2022pde,
  title={PDE-based Group Equivariant Convolutional Neural Networks},
  author={Smets, Bart and Portegies, Jim and Bekkers, Erik and Duits, Remco},
  journal={Journal of Mathematical Imaging and Vision},
  year={2022},
  doi={10.1007/s10851-022-01114-x},
  url={https://doi.org/10.1007/s10851-022-01114-x}
}

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

lietorch-0.7.0.tar.gz (5.3 MB view details)

Uploaded Source

Built Distribution

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

lietorch-0.7.0-py3-none-any.whl (5.4 MB view details)

Uploaded Python 3

File details

Details for the file lietorch-0.7.0.tar.gz.

File metadata

  • Download URL: lietorch-0.7.0.tar.gz
  • Upload date:
  • Size: 5.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for lietorch-0.7.0.tar.gz
Algorithm Hash digest
SHA256 dafbc7ba4635dda7cb269cdee91701e8cfce54ab5bc86db8a2ec3b8c38280201
MD5 b5549ddb2e1e79a304b656bad5bd954b
BLAKE2b-256 f8a1beeead4ee4d648fea5f19905355d6ea4bac0f32839e68db874823ee9629e

See more details on using hashes here.

File details

Details for the file lietorch-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: lietorch-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 5.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for lietorch-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 be46d3c7a0e1234aa0a2f313d0b73556fe4ad6c1215959368eeb6125c3784b78
MD5 35985e578b8348f9a7fbc6fc6e8ce7e7
BLAKE2b-256 ebba8ca66cd2a9b5e50b0431f47f2ab652fc880b7846ad249f79c2825d03d2a4

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