Skip to main content

jVMC: Versatile and performant variational Monte Carlo

Project description

Documentation Status PyPi version arXiv

jVMC

This is an impementation of Variational Monte Carlo (VMC) for quantum many-body dynamics using the JAX library (and Flax on top) to exploit the blessings of automatic differentiation for easy model composition and just-in-time compilation for execution on accelerators.

  1. Documentation
  2. Installation
  3. Online example
  4. Important gotchas
  5. Citing jVMC

Please report bugs as well as other issues or suggestions on our issues page.

Documentation

Documentation is available here.

Installation

Option 1: pip-install

    pip install jVMC

To install jVMC with GPU support, use

    pip install jVMC[gpu]

This is assuming, that jax[cuda12] will work for you (see the JAX documentation).

Option 2: Clone and pip-install for development

  1. Clone the jVMC repository and check out the development branch:

     git clone https://github.com/markusschmitt/vmc_jax.git
     cd vmc_jax
    
  2. pip-install the package

     pip install -e ".[dev]"
    

Test that everything worked, e.g. run 'python -c "import jVMC"' from a place different than vmc_jax.

Online example

Open In Colab

Click on the badge above to open a notebook that implements an exemplary ground state search in Google Colab.

Important gotchas

Out-of-memory issues and batching

Memory requirements grow with increasing network sizes. To avoid out-of-memory issues, the batchSize parameter of the NQS class has to be adjusted. The batchSize indicates on how many input configurations the network is evaluated concurrently. Out-of-memory issues are usually resolved by reducing this number. The numChains parameter of the Sampler class for Markov Chain Monte Carlo sampling plays a similar role, but its optimal values in terms of computational speed are typically not memory critical.

Citing jVMC

If you use the jVMC package for your research, please cite our reference paper SciPost Phys. Codebases 2 (2022)

    @Article{jVMC,
            title={{jVMC: Versatile and performant variational Monte Carlo leveraging automated differentiation and GPU acceleration}},
            author={Markus Schmitt and Moritz Reh},
            journal={SciPost Phys. Codebases},
            pages={2},
            year={2022},
            publisher={SciPost},
            doi={10.21468/SciPostPhysCodeb.2},
            url={https://scipost.org/10.21468/SciPostPhysCodeb.2},
    }

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

jvmc-1.5.8.tar.gz (50.1 kB view details)

Uploaded Source

Built Distribution

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

jvmc-1.5.8-py3-none-any.whl (59.6 kB view details)

Uploaded Python 3

File details

Details for the file jvmc-1.5.8.tar.gz.

File metadata

  • Download URL: jvmc-1.5.8.tar.gz
  • Upload date:
  • Size: 50.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.23

File hashes

Hashes for jvmc-1.5.8.tar.gz
Algorithm Hash digest
SHA256 b97a701c54ae890abfd40d433d253912c7ba5dba1d49c7f96947b52167ad8c8b
MD5 d0ae4d0b9a871a961805743db891e462
BLAKE2b-256 7b5a19a1ed7ce7d01b123b9f34336543ae5e8f39f88dc5202c96b22aebb60dbc

See more details on using hashes here.

File details

Details for the file jvmc-1.5.8-py3-none-any.whl.

File metadata

  • Download URL: jvmc-1.5.8-py3-none-any.whl
  • Upload date:
  • Size: 59.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.23

File hashes

Hashes for jvmc-1.5.8-py3-none-any.whl
Algorithm Hash digest
SHA256 fbceaa732f188bdbdca8f14299f5453a6b7062b9f4f24f8287f265c3e04ad22c
MD5 0e329590fa7cdf71f5650954cf73a3af
BLAKE2b-256 ee76d007b6e483efa8750f5e486e91d03c063081f6ce2289074559fd05b4faaa

See more details on using hashes here.

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