Skip to content

Commit

Permalink
Merge branch 'main' into splinegpu
Browse files Browse the repository at this point in the history
  • Loading branch information
E-Rum committed Jan 8, 2025
2 parents 62598e3 + b3310fb commit adc165d
Show file tree
Hide file tree
Showing 4 changed files with 127 additions and 1 deletion.
85 changes: 85 additions & 0 deletions CITATION.cff
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
cff-version: 1.2.0
message: "If you use torch-pme for your work, please read and cite it as below."
title: >-
Fast and flexible range-separated models for atomistic machine learning
abstract: |
Most atomistic machine learning (ML) models rely on a locality ansatz, and decompose the energy into a sum of short-ranged, atom-centered contributions. This leads to clear limitations when trying to describe problems that are dominated by long-range physical effects - most notably electrostatics. Many approaches have been proposed to overcome these limitations, but efforts to make them efficient and widely available are hampered by the need to incorporate an ad hoc implementation of methods to treat long-range interactions. We develop a framework aiming to bring some of the established algorithms to evaluate non-bonded interactions - including Ewald summation, classical particle-mesh Ewald (PME), and particle-particle/particle-mesh (P3M) Ewald - into atomistic ML. We provide a reference implementation for PyTorch as well as an experimental one for JAX. Beyond Coulomb and more general long-range potentials, we introduce purified descriptors which disregard the immediate neighborhood of each atom, and are more suitable for general long-ranged ML applications. Our implementations are fast, feature-rich, and modular: They provide an accurate evaluation of physical long-range forces that can be used in the construction of (semi)empirical baseline potentials; they exploit the availability of automatic differentiation to seamlessly combine long-range models with conventional, local ML schemes; and they are sufficiently flexible to implement more complex architectures that use physical interactions as building blocks. We benchmark and demonstrate our torch-pme and jax-pme libraries to perform molecular dynamics simulations, to train range-separated ML potentials, and to evaluate long-range equivariant descriptors of atomic structures.
type: preprint
database: arXiv.org
date-accessed: 2024-12-05T12:43:16Z
repository: arXiv
url: http://arxiv.org/abs/2412.03281
keywords:
- Physics - Chemical Physics
authors:
- family-names: Loche
given-names: Philip
- family-names: Huguenin-Dumittan
given-names: Kevin K.
- family-names: Honarmand
given-names: Melika
- family-names: Xu
given-names: Qianjun
- family-names: Rumiantsev
given-names: Egor
- family-names: How
given-names: Wei Bin
- family-names: Langer
given-names: Marcel F.
- family-names: Ceriotti
given-names: Michele
editors:
- family-names: Loche
given-names: Philip
- family-names: Huguenin-Dumittan
given-names: Kevin K.
- family-names: Honarmand
given-names: Melika
- family-names: Xu
given-names: Qianjun
- family-names: Rumiantsev
given-names: Egor
- family-names: How
given-names: Wei Bin
- family-names: Langer
given-names: Marcel F.
- family-names: Ceriotti
given-names: Michele
recipients:
- family-names: Loche
given-names: Philip
- family-names: Huguenin-Dumittan
given-names: Kevin K.
- family-names: Honarmand
given-names: Melika
- family-names: Xu
given-names: Qianjun
- family-names: Rumiantsev
given-names: Egor
- family-names: How
given-names: Wei Bin
- family-names: Langer
given-names: Marcel F.
- family-names: Ceriotti
given-names: Michele
translators:
- family-names: Loche
given-names: Philip
- family-names: Huguenin-Dumittan
given-names: Kevin K.
- family-names: Honarmand
given-names: Melika
- family-names: Xu
given-names: Qianjun
- family-names: Rumiantsev
given-names: Egor
- family-names: How
given-names: Wei Bin
- family-names: Langer
given-names: Marcel F.
- family-names: Ceriotti
given-names: Michele
date-published: 2024-12-04
identifiers:
- type: doi
value: 10.48550/arXiv.2412.03281
1 change: 1 addition & 0 deletions MANIFEST.in
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
graft src

include LICENSE
include CITATION.cff
include README.rst

prune docs
Expand Down
40 changes: 40 additions & 0 deletions docs/src/references/changelog.rst
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,46 @@ changelog <https://keepachangelog.com/en/1.1.0/>`_ format. This project follows
Fixed
#####

* Fix inconsistent ``cutoff`` in neighbor list example
* All calculators now check if the cell is zero if the potential is range-separated


`Version 0.1.0 <https://github.com/lab-cosmo/torch-pme/releases/tag/v0.1.0>`_ - 2024-12-05
------------------------------------------------------------------------------------------

Added
#####

* First release outside of the lab
.. _userdoc-changelog:

Changelog
=========

All notable changes to ``torch-pme`` are documented here, following the `keep a
changelog <https://keepachangelog.com/en/1.1.0/>`_ format. This project follows
`Semantic Versioning <https://semver.org/spec/v2.0.0.html>`_.

.. Possible sections for each release:
.. Added
.. #####
.. Fixed
.. #####
.. Changed
.. #######
.. Removed
.. #######
`Unreleased <https://github.com/lab-cosmo/torch-pme/>`_
-------------------------------------------------------

Fixed
#####

* Fixed consistency of dtype and device in the SplinePotential class
* All calculators now check if the cell is zero if the potential is range-separated

Expand Down
2 changes: 1 addition & 1 deletion examples/2-neighbor-lists-usage.py
Original file line number Diff line number Diff line change
Expand Up @@ -224,7 +224,7 @@ def distances(
#
# and create new distances in a similar manner as above.

nl = vesin.torch.NeighborList(cutoff=1.0, full_list=False)
nl = vesin.torch.NeighborList(cutoff=cutoff, full_list=False)
neighbor_indices_new, d = nl.compute(
points=positions_new, box=cell, periodic=True, quantities="Pd"
)
Expand Down

0 comments on commit adc165d

Please sign in to comment.