Minimal O(3) irreducible representations with optional JAX support. A lightweight, pure-Python replacement for the core of e3nn-jax.
Project description
irrepx
Install
pip install irrepx # Light mode: representation algebra only
pip install irrepx[jax] # Full mode: JAX (any platform, pre-installed)
One-step install with the right JAX backend:
pip install irrepx[jax-cpu] # CPU
pip install irrepx[jax-cuda12] # CUDA 12
pip install irrepx[jax-cuda13] # CUDA 13
pip install irrepx[jax-tpu] # TPU
Quick Start
from irrepx import Irrep, Irreps
# Structural algebra (no JAX needed)
irreps = Irreps("32x0e + 16x1o + 8x2e")
assert irreps.dim == 32 + 48 + 40
assert Irrep("2e") in Irrep("1o") * Irrep("1o")
With JAX installed:
import jax.numpy as jnp
from irrepx import IrrepsArray, spherical_harmonics
x = IrrepsArray("1o", jnp.array([[1.0, 0.0, 0.0]]))
sh = spherical_harmonics([0, 1, 2], x, normalize=True)
print(sh.irreps) # 1x0e+1x1o+1x2e
Pre-computed constants
irrepx ships pre-computed Clebsch-Gordan coefficients, JD seed matrices, and spherical Bessel roots as npz files. These are loaded lazily on first access.
from irrepx import load_cg, load_jd, load_sb_roots
cg = load_cg() # loads from cg.npz, lmax=7 by default
cg = load_cg(lmax=5) # subset up to lmax=5
jd = load_jd() # loads from jd.npz, lmax=13 by default
sb = load_sb_roots() # loads from sb_root.npz, lmax=13 by default
If the requested lmax exceeds the shipped tables, rebuild them with the CLI:
irrepx constants status
irrepx constants update --cg-lmax 10 --jd-lmax 15 --sb-lmax 20
For per-triplet CG access (used internally by spherical_harmonics and
tensor_product), use the computational function:
from irrepx import clebsch_gordan
cg = clebsch_gordan(1, 1, 2) # returns dense (3, 3, 5) array
License
GPL-3.0-or-later
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file irrepx-0.5.0-py3-none-any.whl.
File metadata
- Download URL: irrepx-0.5.0-py3-none-any.whl
- Upload date:
- Size: 350.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
21ecf997f7a41bdc288a5551b69b788a665d74238796883db0ec0bc73f7afce6
|
|
| MD5 |
39298afe8255abd4ad6d9eccce00de46
|
|
| BLAKE2b-256 |
2a7ba3458f0ec8d4d797f36b3e1fddd87abace83041deb3475420c15159bf832
|
Provenance
The following attestation bundles were made for irrepx-0.5.0-py3-none-any.whl:
Publisher:
publish.yaml on kYangLi/irrepx
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
irrepx-0.5.0-py3-none-any.whl -
Subject digest:
21ecf997f7a41bdc288a5551b69b788a665d74238796883db0ec0bc73f7afce6 - Sigstore transparency entry: 1832671032
- Sigstore integration time:
-
Permalink:
kYangLi/irrepx@e8abc6457c8985324e815e593980c552a1437ad4 -
Branch / Tag:
refs/tags/v0.5.0 - Owner: https://github.com/kYangLi
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yaml@e8abc6457c8985324e815e593980c552a1437ad4 -
Trigger Event:
release
-
Statement type: