The electronic structure package for quantum computers.
Project description
OpenFermion is an open source library for compiling and analyzing quantum algorithms to simulate fermionic systems, including quantum chemistry. Among other functionalities, this version features data structures and tools for obtaining and manipulating representations of fermionic and qubit Hamiltonians. For more information, see our release paper.
Run the interactive Jupyter Notebooks in Colab or MyBinder:
Installation and Documentation
Installing the latest stable OpenFermion requires pip. Make sure that you are using an up-to-date version of it.
Documentation can be found at quantumai.google/openfermion and the following links
Currently, OpenFermion is tested on Mac, Windows, and Linux. We recommend using Mac or Linux because the electronic structure plugins are only compatible on these platforms. However, for those who would like to use Windows, or for anyone having other difficulties with installing OpenFermion or its plugins, we have provided a Docker image and usage instructions in the docker folder. The Docker image provides a virtual environment with OpenFermion and select plugins pre-installed. The Docker installation should run on any operating system.
You might also want to explore the alpha release of the OpenFermion Cloud Library where users can share and download precomputed molecular benchmark files.
Developer install
To install the latest version of OpenFermion (in development mode):
git clone https://github.com/quantumlib/OpenFermion
cd OpenFermion
python -m pip install -e .
Library install
To install the latest PyPI release as a library (in user mode):
python -m pip install --user openfermion
Plugins
OpenFermion relies on modular plugin libraries for significant functionality. Specifically, plugins are used to simulate and compile quantum circuits and to perform classical electronic structure calculations. Follow the links below to learn more!
High performance simulators
OpenFermion-FQE is a high performance emulator of fermionic quantum evolutions specified by a sequence of fermion operators, which can exploit fermionic symmetries such as spin and particle number.
Circuit compilation plugins
Forest-OpenFermion to support integration with Forest.
SFOpenBoson to support integration with Strawberry Fields.
Electronic structure package plugins
OpenFermion-Psi4 to support integration with Psi4.
OpenFermion-PySCF to support integration with PySCF.
OpenFermion-Dirac to support integration with DIRAC.
OpenFermion-QChem to support integration with Q-Chem.
How to contribute
We’d love to accept your contributions and patches to OpenFermion. There are a few small guidelines you need to follow. Contributions to OpenFermion must be accompanied by a Contributor License Agreement. You (or your employer) retain the copyright to your contribution, this simply gives us permission to use and redistribute your contributions as part of the project. Head over to https://cla.developers.google.com/ to see your current agreements on file or to sign a new one.
All submissions, including submissions by project members, require review. We use GitHub pull requests for this purpose. Consult GitHub Help for more information on using pull requests. Furthermore, please make sure your new code comes with extensive tests! We use automatic testing to make sure all pull requests pass tests and do not decrease overall test coverage by too much. Make sure you adhere to our style guide. Just have a look at our code for clues. We mostly follow PEP 8 and use the corresponding linter to check for it. Code should always come with documentation, which is generated automatically and can be found here.
We use Github issues for tracking requests and bugs. Please post questions to the Quantum Computing Stack Exchange with an ‘openfermion’ tag.
How to cite
When using OpenFermion for research projects, please cite:
Jarrod R McClean, Nicholas C Rubin, Kevin J Sung, Ian D Kivlichan, Xavier Bonet-Monroig, Yudong Cao, Chengyu Dai, E Schuyler Fried, Craig Gidney, Brendan Gimby, Pranav Gokhale, Thomas Häner, Tarini Hardikar, Vojtěch Havlíček, Oscar Higgott, Cupjin Huang, Josh Izaac, Zhang Jiang, Xinle Liu, Sam McArdle, Matthew Neeley, Thomas O’Brien, Bryan O’Gorman, Isil Ozfidan, Maxwell D Radin, Jhonathan Romero, Nicolas P D Sawaya, Bruno Senjean, Kanav Setia, Sukin Sim, Damian S Steiger, Mark Steudtner, Qiming Sun, Wei Sun, Daochen Wang, Fang Zhang, and Ryan Babbush OpenFermion: The Electronic Structure Package for Quantum Computers. Quantum Science and Technology 5.3 (2020): 034014.
We are happy to include future contributors as authors on later releases.
Disclaimer
Copyright 2017 The OpenFermion Developers. This is not an official Google product.
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
Hashes for openfermion-1.5.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0e49c51d4c6a7cb176fddff0a40918365d5d497db1b7f032182653690829dff4 |
|
MD5 | f41a0add90ace4a060a7cedf46d190de |
|
BLAKE2b-256 | de69bece34b058acd17715111d81f212007cdc4001cbe204c2a7795151876a73 |