Skip to main content

A toolkit for building high-performance molecular simulations on JAX.

Project description

kUPS
kUPS demo

A toolkit for building high-performance molecular simulations on JAX

kUPS provides composable, differentiable primitives — samplers, potentials, and propagators — with hardware acceleration on CPU, GPU, and TPU.

Documentation | Quick Start | Features | Examples

License Python JAX


Installation

Standard Installation
pip install kups
GPU Support
pip install kups[cuda]
Development
git clone https://github.com/cusp-ai-oss/kups.git
cd kups
uv sync

Quick Start

[!TIP] The repository includes example applications built with kUPS in the examples/ directory.

Monte Carlo Simulation (GCMC)
cd examples
kups_mcmc_rigid mcmc_rigid.yaml
Molecular Dynamics (Lennard-Jones)
cd examples
kups_md_lj md_lj_argon_nvt.yaml

Features

Simulation Methods

  • Monte Carlo — NVT and GCMC ensembles with translation, rotation, reinsertion, and exchange moves
  • Molecular Dynamics — NVE, NVT, NPT ensembles
  • Geometry Optimization — FIRE and L-BFGS relaxation

Force Fields & Potentials

  • Lennard-Jones potential
  • Coulomb interactions (Ewald summation)
  • Harmonic bonds and angles
  • Morse potential
  • MACE and UMA ML force fields

Core Capabilities

  • Composable — shared propagator interface; methods and potentials snap together freely
  • Batched — run thousands of independent simulations as vectorized computations

Performance & Integration

  • GPU-native — JIT-compiled on CPU, GPU, and TPU with no code changes
  • Differentiable — full automatic differentiation via JAX
  • PyTorch interop — bring PyTorch models into JAX via Tojax

Documentation

Full documentation is available at cusp-ai-oss.github.io/kUPS.

Building docs locally

To build the docs locally run ./docs/scripts/build.sh, which executes and renders all documentation notebooks and generates API pages in markdown.

./docs/scripts/build.sh           # build into site/
./docs/scripts/build.sh --serve   # serve with live updates on http://127.0.0.1:8000

Citation

If you use kUPS in your research, please cite:

@software{kups2026,
  author = {Gao, Nicholas
    and K{\"o}hler, Jonas
    and Hanke, Felix
    and Ramanan, Anita
    and Moubarak, Elias
    and Morrow, Joe
    and de Haan, Pim
    and Openshaw, Hannah
    and Welling, Max
    and CuspAI Team},
  title = {kUPS - a universal particle simulation toolkit},
  year = {2026},
  url = {https://github.com/cusp-ai-oss/kups}
}

License

Apache License 2.0 — see LICENSE.

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

kups-1.0.1.tar.gz (243.9 kB view details)

Uploaded Source

Built Distribution

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

kups-1.0.1-py3-none-any.whl (321.0 kB view details)

Uploaded Python 3

File details

Details for the file kups-1.0.1.tar.gz.

File metadata

  • Download URL: kups-1.0.1.tar.gz
  • Upload date:
  • Size: 243.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for kups-1.0.1.tar.gz
Algorithm Hash digest
SHA256 85badba27b13831c115960da05cd927f7c43d3a254a7b051a2a31997b08230c5
MD5 944bbc65b9b07b48ea9c353d55203cab
BLAKE2b-256 e87544c490d32a2fe2181d063cbc81dfa2752d044c0d242439062cf163f4a113

See more details on using hashes here.

Provenance

The following attestation bundles were made for kups-1.0.1.tar.gz:

Publisher: release.yaml on cusp-ai-oss/kUPS

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kups-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: kups-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 321.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for kups-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8a2582181ff1024a274c3799086ff283eb1e44ca1f5255c58d1a56171d4a90a6
MD5 52c57fda643b1e9229d9b01bd84ceba6
BLAKE2b-256 23891a026c21430e3867ac18132ea42bbbd57a528b6558b18d63584a983ffae9

See more details on using hashes here.

Provenance

The following attestation bundles were made for kups-1.0.1-py3-none-any.whl:

Publisher: release.yaml on cusp-ai-oss/kUPS

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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