Skip to main content

A python package that knows how to do various tricky computations related to Lie groups and manifolds (mainly the sphere S2 and rotation group SO3).

Project description

This package is a fork of the original!

Original can be found at: https://github.com/AMLab-Amsterdam/lie_learn

lie_learn is a python package that knows how to do various tricky computations related to Lie groups and manifolds (mainly the sphere S2 and rotation group SO3). This package was written to support various machine learning projects, such as Harmonic Exponential Families [2], (continuous) Group Equivariant Networks [3], Steerable CNNs [4] and Spherical CNNs [5].

This code was developed using an extremely agile, move-fast-and-break-things, extreme-programming software development workflow, and was extensively tested using the print command. Most of the code was written in the 72 hours preceding conference deadlines. In other words, this code is a bit of a mess, but we're releasing it anyway because it could be useful to others.

What this code can do

  • Reparamterize rotations, e.g. matrix to Euler angles to quaternions, etc. (see groups & spaces modules)
  • Compute the Wigner-d and Wigner-D matrices (the irreducible representations of SO(3)), and spherical harmonics, using the method developed by Pinchon & Hoggan [1] (see pinchon_hoggan_dense.py). This is a very fast and stable method, but requires a fairly large "J matrix", which we have precomputed up to order 278 using a Maple script. The code will automatically download it from Google Drive during installation. Note: There are many normalization and phase conventions for both the real and complex versions of the D-matrices and spherical harmonics, and the code can convert between a lot of them (irrep_bases.pyx).
  • Compute generalized / non-commutative FFTs for the sphere S2, rotation group SO3, and special Euclidean group SE2 (see spectral module).
  • Fit Harmonic Exponential Families on the sphere (probability module; not sure code is still working)

Installation

lie_learn can be installed from pypi using:

pip install lie_learn

Although cython is not a necessary dependency, if you have cython installed, cython will write new versions of the *.c files before compiling them into *.so during installation. To use lie_learn, you will need a c compiler which is available to python setuptools.

Feedback

For questions and comments, feel free to contact Taco Cohen (http://ta.co.nl).

References

[1] Pinchon, D., & Hoggan, P. E. (2007). Rotation matrices for real spherical harmonics: general rotations of atomic orbitals in space-fixed axes. Journal of Physics A: Mathematical and Theoretical, 40(7), 1597–1610.

[2] Cohen, T. S., & Welling, M. (2015). Harmonic Exponential Families on Manifolds. In Proceedings of the 32nd International Conference on Machine Learning (ICML) (pp. 1757–1765).

[3] Cohen, T. S., & Welling, M. (2016). Group equivariant convolutional networks. In Proceedings of The 33rd International Conference on Machine Learning (ICML) (Vol. 48, pp. 2990–2999).

[4] Cohen, T. S., & Welling, M. (2017). Steerable CNNs. In ICLR.

[5] T.S. Cohen, M. Geiger, J. Koehler, M. Welling (2017). Convolutional Networks for Spherical Signals. In ICML Workshop on Principled Approaches to Deep Learning.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

lie_learn_escience-0.0.2-cp312-cp312-win_amd64.whl (15.1 MB view hashes)

Uploaded CPython 3.12 Windows x86-64

lie_learn_escience-0.0.2-cp312-cp312-win32.whl (15.1 MB view hashes)

Uploaded CPython 3.12 Windows x86

lie_learn_escience-0.0.2-cp312-cp312-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl (16.6 MB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.5+ x86-64

lie_learn_escience-0.0.2-cp312-cp312-macosx_11_0_arm64.whl (15.1 MB view hashes)

Uploaded CPython 3.12 macOS 11.0+ ARM64

lie_learn_escience-0.0.2-cp312-cp312-macosx_10_9_x86_64.whl (15.1 MB view hashes)

Uploaded CPython 3.12 macOS 10.9+ x86-64

lie_learn_escience-0.0.2-cp311-cp311-win_amd64.whl (15.1 MB view hashes)

Uploaded CPython 3.11 Windows x86-64

lie_learn_escience-0.0.2-cp311-cp311-win32.whl (15.1 MB view hashes)

Uploaded CPython 3.11 Windows x86

lie_learn_escience-0.0.2-cp311-cp311-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl (16.6 MB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.5+ x86-64

lie_learn_escience-0.0.2-cp311-cp311-macosx_11_0_arm64.whl (15.1 MB view hashes)

Uploaded CPython 3.11 macOS 11.0+ ARM64

lie_learn_escience-0.0.2-cp311-cp311-macosx_10_9_x86_64.whl (15.2 MB view hashes)

Uploaded CPython 3.11 macOS 10.9+ x86-64

lie_learn_escience-0.0.2-cp310-cp310-win_amd64.whl (15.1 MB view hashes)

Uploaded CPython 3.10 Windows x86-64

lie_learn_escience-0.0.2-cp310-cp310-win32.whl (15.1 MB view hashes)

Uploaded CPython 3.10 Windows x86

lie_learn_escience-0.0.2-cp310-cp310-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl (16.5 MB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.5+ x86-64

lie_learn_escience-0.0.2-cp310-cp310-macosx_11_0_arm64.whl (15.1 MB view hashes)

Uploaded CPython 3.10 macOS 11.0+ ARM64

lie_learn_escience-0.0.2-cp310-cp310-macosx_10_9_x86_64.whl (15.2 MB view hashes)

Uploaded CPython 3.10 macOS 10.9+ x86-64

lie_learn_escience-0.0.2-cp39-cp39-win_amd64.whl (15.1 MB view hashes)

Uploaded CPython 3.9 Windows x86-64

lie_learn_escience-0.0.2-cp39-cp39-win32.whl (15.1 MB view hashes)

Uploaded CPython 3.9 Windows x86

lie_learn_escience-0.0.2-cp39-cp39-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_17_x86_64.manylinux2014_x86_64.whl (16.5 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64 manylinux: glibc 2.5+ x86-64

lie_learn_escience-0.0.2-cp39-cp39-macosx_11_0_arm64.whl (15.1 MB view hashes)

Uploaded CPython 3.9 macOS 11.0+ ARM64

lie_learn_escience-0.0.2-cp39-cp39-macosx_10_9_x86_64.whl (15.2 MB view hashes)

Uploaded CPython 3.9 macOS 10.9+ x86-64

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