# jaqmc **Repository Path**: ByteDance/jaqmc ## Basic Information - **Project Name**: jaqmc - **Description**: JAX accelerated Quantum Monte Carlo - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2022-11-02 - **Last Updated**: 2026-05-07 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README

JaQMC

**JaQMC** is a JAX-based framework for neural network quantum Monte Carlo (QMC). It uses deep neural networks as variational wavefunctions to solve the electronic Schrödinger equation, achieving high accuracy without relying on basis sets or density functionals. If you’re looking for the **old (pre-0.1) JaQMC codebase / APIs**, use the legacy namespace: `import jaqmc_legacy`. If you're interested in neural network QMC and want to get started quickly, run real calculations, or build on top of a clean codebase — JaQMC is designed for you. ## Why JaQMC - **Modular by design.** Wavefunctions, samplers, estimators, and optimizers are independent, swappable components. Want to try a different architecture or loss function? Swap one piece without rewriting the rest. - **General-purpose.** Built to model interacting electrons in any setting — atoms, molecules, crystals, and beyond. Ships today with molecular, solid-state, and fractional quantum Hall (FQHE) support, with an architecture that extends naturally to other quantum systems. - **Ready to use, ready to modify.** Ships with FermiNet and PsiFormer architectures, KFAC, SR, and Optax-based optimizers (for example Adam), and preset configurations for common systems. Everything is configurable from the CLI — or from code if you want deeper control. - **Built on JAX.** Automatic differentiation, JIT compilation, and multi-device parallelism come for free. ## Installation Before you begin, make sure you have: - **Python 3.12** or later - **Git** (for cloning the repository) Clone the repository and navigate to the `jaqmc` directory. ```bash git clone https://github.com/bytedance/jaqmc.git cd jaqmc ``` Install with [uv](https://docs.astral.sh/uv/getting-started/installation/) (recommended): ```bash uv sync --frozen --python 3.12 ``` This installs the exact dependency versions currently tested by the project from the official PyPI index. If you prefer `pip`, or if you use a PyPI mirror, create a virtual environment first and install manually: ```bash python -m venv .venv && source .venv/bin/activate pip install -e . -r requirements.txt --extra-index-url https://pypi.org/simple ``` The `--extra-index-url https://pypi.org/simple` flag is recommended when you use PyPI mirrors, since some mirrors may not include every required package. ### GPU Support For GPU acceleration, choose the option that matches your setup: ```bash # Option 1: Download CUDA libraries (recommended; no system CUDA required) uv sync --frozen --python 3.12 --extra cuda12 # Or with pip: pip install -e ".[cuda12]" -r requirements.txt --extra-index-url https://pypi.org/simple # Option 2: Use a local CUDA installation (requires CUDA 12 to already be installed) uv sync --frozen --python 3.12 --extra cuda12-local # Or with pip: pip install -e ".[cuda12_local]" -r requirements.txt --extra-index-url https://pypi.org/simple ``` For troubleshooting GPU setup, see the [JAX installation guide](https://docs.jax.dev/en/latest/installation.html). ## Quick Start ```bash source .venv/bin/activate # Run the hydrogen atom example jaqmc hydrogen-atom train # Customize parameters jaqmc hydrogen-atom train train.optim.learning_rate.rate=0.01 train.run.iterations=200 # Run a lithium atom simulation jaqmc molecule train system.module=atom system.symbol=Li ``` See the [documentation](https://jaqmc.readthedocs.io/latest/getting-started/quick-start.html) for detailed guides on installation, molecular simulations, and writing custom workflows. ## Where to Go Next - **Train a real system**: See [Molecules](https://jaqmc.readthedocs.io/latest/systems/molecule/index.html), [Solids](https://jaqmc.readthedocs.io/latest/systems/solid/index.html), or [Quantum Hall](https://jaqmc.readthedocs.io/latest/systems/hall/index.html). - **Understand the framework**: Read [Core Concepts](https://jaqmc.readthedocs.io/latest/getting-started/concepts.html). - **Extend JaQMC**: Start from [Extending JaQMC](https://jaqmc.readthedocs.io/latest/extending/index.html). - **Contribute code**: See [CONTRIBUTING.md](CONTRIBUTING.md). ## Development ```bash uv sync --frozen --python 3.12 uv tool install prek prek install # Run tests pytest # Linting and formatting ruff check . mypy . ruff format . ``` ## Citation If you use JaQMC in your research, please cite the following paper, which introduced the first version of the software: ```bibtex @article{ren_towards_2023, title = {Towards the Ground State of Molecules via Diffusion {{Monte Carlo}} on Neural Networks}, author = {Ren, Weiluo and Fu, Weizhong and Wu, Xiaojie and Chen, Ji}, year = 2023, month = apr, journal = {Nature Communications}, volume = {14}, number = {1}, pages = {1860}, publisher = {Nature Publishing Group}, issn = {2041-1723}, doi = {10.1038/s41467-023-37609-3}, } ``` See [Citing JaQMC](https://jaqmc.readthedocs.io/latest/citing.html) for additional citations for specific techniques.