Particle-mesh based calculations of long-range interactions in PyTorch
Project description
torch-pme enables efficient and auto-differentiable computation of long-range interactions in PyTorch. Auto-differentiation is supported for particle positions,
charges/dipoles, and cell parameters, allowing not only the automatic computation of forces but also enabling general applications in machine learning tasks. For monopoles the library offers classes for Particle-Particle Particle-Mesh Ewald (P3M), Particle Mesh Ewald (PME), standard Ewald, and non-periodic methods. The library has the flexibility to calculate potentials beyond \(1/r\) electrostatics, including arbitrary order \(1/r^p\) potentials. For dipolar interaction we offer to calculate the \(1/r^3\) potential using the standard Ewald method.
Optimized for both CPU and GPU devices, torch-pme is fully TorchScriptable, allowing it to be converted into a format that runs independently of Python, such as in C++, making it ideal for high-performance production environments.
We also provide an experimental implementation for JAX in jax-pme.
Documentation
For details, tutorials, and examples, please have a look at our documentation.
Installation
You can install torch-pme using pip with
pip install torch-pme
or conda
conda install -c conda-forge torch-pme
and import torchpme to use it in your projects!
We also provide bindings to metatensor which can optionally be installed together and used as torchpme.metatensor via
pip install torch-pme[metatensor]
Quickstart
Here is a simple example to get started with torch-pme:
>>> import torch
>>> import torchpme
>>> # Single charge in a cubic box
>>> positions = torch.zeros((1, 3))
>>> cell = 8 * torch.eye(3)
>>> charges = torch.tensor([[1.0]])
>>> # No neighbors for a single atom; use `vesin` for neighbors if needed
>>> neighbor_indices = torch.zeros((0, 2), dtype=torch.int64)
>>> neighbor_distances = torch.zeros((0,))
>>> # Tune P3M parameters
>>> smearing, p3m_parameters, _ = torchpme.tuning.tune_p3m(
... charges=charges,
... cell=cell,
... positions=positions,
... cutoff=5.0,
... neighbor_indices=neighbor_indices,
... neighbor_distances=neighbor_distances,
... )
>>> # Initialize potential and calculator
>>> potential = torchpme.CoulombPotential(smearing)
>>> calculator = torchpme.P3MCalculator(potential, **p3m_parameters)
>>> # Start recording operations done to ``positions``
>>> _ = positions.requires_grad_()
>>> # Compute (per-atom) potentials
>>> potentials = calculator.forward(
... charges=charges,
... cell=cell,
... positions=positions,
... neighbor_indices=neighbor_indices,
... neighbor_distances=neighbor_distances,
... )
>>> # Calculate total energy and forces
>>> energy = torch.sum(charges * potentials)
>>> energy.backward()
>>> forces = -positions.grad
For more examples and details, please refer to the documentation.
Having problems or ideas?
Having a problem with torch-pme? Please let us know by submitting an issue.
Submit new features or bug fixes through a pull request.
Reference
If you use torch-pme for your work, please read and cite our publication available on JCP.
@article{10.1063/5.0251713,
title = {Fast and flexible long-range models for atomistic machine learning},
author = {Loche, Philip and Huguenin-Dumittan, Kevin K. and Honarmand, Melika and Xu, Qianjun and Rumiantsev, Egor and How, Wei Bin and Langer, Marcel F. and Ceriotti, Michele},
journal = {The Journal of Chemical Physics},
volume = {162},
number = {14},
pages = {142501},
year = {2025},
month = {04},
issn = {0021-9606},
doi = {10.1063/5.0251713},
url = {https://doi.org/10.1063/5.0251713},
}
Contributors
Thanks goes to all people that make torch-pme possible:
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
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 torch_pme-0.3.2.tar.gz.
File metadata
- Download URL: torch_pme-0.3.2.tar.gz
- Upload date:
- Size: 46.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
143678e0735404b9edcd24cc7591200a5a968a3e916a806c48b552614d22243f
|
|
| MD5 |
1ee053e3ee3e34f2f3455ed62286afe1
|
|
| BLAKE2b-256 |
98498f7a794ec741dcba9078641fecb0f38ea57488850a357237508410deeb56
|
Provenance
The following attestation bundles were made for torch_pme-0.3.2.tar.gz:
Publisher:
release.yml on lab-cosmo/torch-pme
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
torch_pme-0.3.2.tar.gz -
Subject digest:
143678e0735404b9edcd24cc7591200a5a968a3e916a806c48b552614d22243f - Sigstore transparency entry: 589374082
- Sigstore integration time:
-
Permalink:
lab-cosmo/torch-pme@3ae8eae0024933d0110ee4a9fc682cfa9111ab49 -
Branch / Tag:
refs/tags/v0.3.2 - Owner: https://github.com/lab-cosmo
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@3ae8eae0024933d0110ee4a9fc682cfa9111ab49 -
Trigger Event:
push
-
Statement type:
File details
Details for the file torch_pme-0.3.2-py3-none-any.whl.
File metadata
- Download URL: torch_pme-0.3.2-py3-none-any.whl
- Upload date:
- Size: 66.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cae78c49186ab621288f67c9484e12233b9a1663d01a1df4153468dc0d3f5e0c
|
|
| MD5 |
b1d00131fb634b4778ba4124c28e0a62
|
|
| BLAKE2b-256 |
46fa6b040bc6f9a81155e181a1920cd14468b97eb94e31a302dca3451659339a
|
Provenance
The following attestation bundles were made for torch_pme-0.3.2-py3-none-any.whl:
Publisher:
release.yml on lab-cosmo/torch-pme
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
torch_pme-0.3.2-py3-none-any.whl -
Subject digest:
cae78c49186ab621288f67c9484e12233b9a1663d01a1df4153468dc0d3f5e0c - Sigstore transparency entry: 589374263
- Sigstore integration time:
-
Permalink:
lab-cosmo/torch-pme@3ae8eae0024933d0110ee4a9fc682cfa9111ab49 -
Branch / Tag:
refs/tags/v0.3.2 - Owner: https://github.com/lab-cosmo
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@3ae8eae0024933d0110ee4a9fc682cfa9111ab49 -
Trigger Event:
push
-
Statement type: