All Projects → quantumlib → Openfermion

quantumlib / Openfermion

Licence: apache-2.0
The electronic structure package for quantum computers.

Programming Languages

python
139335 projects - #7 most used programming language

Projects that are alternatives of or similar to Openfermion

Openfermion Cirq
Quantum circuits for simulations of quantum chemistry and materials.
Stars: ✭ 258 (-76.52%)
Mutual labels:  quantum-algorithms, quantum-computing, quantum-chemistry
OpenFermion-PySCF
OpenFermion plugin to interface with the electronic structure package PySCF.
Stars: ✭ 76 (-93.08%)
Mutual labels:  quantum-computing, quantum-chemistry, quantum-algorithms
Awesome Quantum Software
Curated list of open-source quantum software projects.
Stars: ✭ 647 (-41.13%)
Mutual labels:  quantum-algorithms, quantum-computing, quantum-chemistry
Openfermion Psi4
OpenFermion plugin to interface with the electronic structure package Psi4.
Stars: ✭ 63 (-94.27%)
Mutual labels:  quantum-algorithms, quantum-computing, quantum-chemistry
Quantum-Computing-UK-Repository
This repository contains all of the code found in the quantum computing tutorials at : https://quantumcomputinguk.org.
Stars: ✭ 52 (-95.27%)
Mutual labels:  quantum-computing, quantum-algorithms
learn-qc-with-python-and-qsharp
Companion code for Learn Quantum Computing with Python and Q# Book by Dr. Sarah Kaiser and Dr. Chris Granade 💖
Stars: ✭ 62 (-94.36%)
Mutual labels:  quantum-computing, quantum-algorithms
launchpad
Resources to get started in Quantum Computing!
Stars: ✭ 21 (-98.09%)
Mutual labels:  quantum-computing, quantum-algorithms
Quantum-Computing-Collection-Of-Resources
A Well Maintained Repository On Quantum Computing Resources [Code+Theory] Updated Regularly During My Time At IBM, Qubit x Qubit And The Coding School's Introduction To Quantum Computing Course '21
Stars: ✭ 183 (-83.35%)
Mutual labels:  quantum-computing, quantum-algorithms
unitaryhack
Rules and information for the 2021 unitaryHACK event hosted by @unitaryfund
Stars: ✭ 16 (-98.54%)
Mutual labels:  quantum-computing, quantum-algorithms
qibo
A framework for quantum computing with hardware acceleration.
Stars: ✭ 120 (-89.08%)
Mutual labels:  quantum-computing, quantum-algorithms
Awesome Ai Books
Some awesome AI related books and pdfs for learning and downloading, also apply some playground models for learning
Stars: ✭ 855 (-22.2%)
Mutual labels:  quantum-algorithms, quantum-computing
Quantumflow Dev
QuantumFlow: A Quantum Algorithms Development Toolkit
Stars: ✭ 43 (-96.09%)
Mutual labels:  quantum-algorithms, quantum-computing
Quantum-Computer-Simulator-with-Algorithms
C++ simulator of quantum registers and quantum algorithms
Stars: ✭ 15 (-98.64%)
Mutual labels:  quantum-computing, quantum-algorithms
Quantum-Computing-Resources
This repository contains the best resources for learning practical quantum computing. This repository will be updated frequently.
Stars: ✭ 60 (-94.54%)
Mutual labels:  quantum-computing, quantum-algorithms
Blueqat
Quantum Computer Library for Everyone
Stars: ✭ 298 (-72.88%)
Mutual labels:  quantum-algorithms, quantum-computing
Pennylane
PennyLane is a cross-platform Python library for differentiable programming of quantum computers. Train a quantum computer the same way as a neural network.
Stars: ✭ 800 (-27.21%)
Mutual labels:  quantum-computing, quantum-chemistry
Strawberryfields
Strawberry Fields is a full-stack Python library for designing, simulating, and optimizing continuous variable (CV) quantum optical circuits.
Stars: ✭ 505 (-54.05%)
Mutual labels:  quantum-algorithms, quantum-computing
cusp cirq demo
Demonstration of CUSP algorithm using Cirq
Stars: ✭ 35 (-96.82%)
Mutual labels:  quantum-computing, quantum-algorithms
Quantum-Machine-Learning
This repository contains implementations of Quantum Machine Learning algorithms, feature maps, variational circuits and research papers.
Stars: ✭ 47 (-95.72%)
Mutual labels:  quantum-computing, quantum-algorithms
Cirq
A python framework for creating, editing, and invoking Noisy Intermediate Scale Quantum (NISQ) circuits.
Stars: ✭ 3,115 (+183.44%)
Mutual labels:  quantum-algorithms, quantum-computing

.. image:: docs/images/logo_horizontal.svg

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 <https://arxiv.org/abs/1710.07629>__.

.. image:: https://github.com/quantumlib/OpenFermion/workflows/Continuous%20Integration/badge.svg :target: https://github.com/quantumlib/OpenFermion/workflows/Continuous%20Integration/badge.svg

.. image:: https://readthedocs.org/projects/openfermion/badge/?version=latest :target: http://openfermion.readthedocs.io/en/latest/?badge=latest :alt: Documentation Status

.. image:: https://badge.fury.io/py/openfermion.svg :target: https://badge.fury.io/py/openfermion

Run the interactive Jupyter Notebooks in Colab_ or MyBinder_:

.. _Colab: https://colab.research.google.com/github/quantumlib/OpenFermion .. _MyBinder: https://mybinder.org/v2/gh/quantumlib/OpenFermion/master?filepath=examples

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 <https://quantumai.google/openfermion>__ and the following links

  • Installation <https://quantumai.google/openfermion/install>__

  • API Docs <https://quantumai.google/reference/python/openfermion/all_symbols>__

  • Tutorials <https://quantumai.google/openfermion/tutorials/intro_to_openfermion>__

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 <https://github.com/quantumlib/OpenFermion/tree/master/docker>__. 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 <https://github.com/quantumlib/OpenFermion/tree/master/cloud_library>__ where users can share and download precomputed molecular benchmark files.

Check out other projects and papers using OpenFermion <https://quantumai.google/openfermion/projects>__ for inspiration, and let us know if you've been using OpenFermion!

Developer install

To install the latest version of OpenFermion (in development mode):

.. code-block:: bash

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):

.. code-block:: bash

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!

Circuit compilation and simulation plugins

  • Forest-OpenFermion <https://github.com/rigetticomputing/forestopenfermion>__ to support integration with Forest <https://www.rigetti.com/forest>__.

  • SFOpenBoson <https://github.com/XanaduAI/SFOpenBoson>__ to support integration with Strawberry Fields <https://github.com/XanaduAI/strawberryfields>__.

Electronic structure package plugins

  • OpenFermion-Psi4 <http://github.com/quantumlib/OpenFermion-Psi4>__ to support integration with Psi4 <http://psicode.org>__.

  • OpenFermion-PySCF <http://github.com/quantumlib/OpenFermion-PySCF>__ to support integration with PySCF <https://github.com/sunqm/pyscf>__.

  • OpenFermion-Dirac <https://github.com/bsenjean/Openfermion-Dirac>__ to support integration with DIRAC <http://diracprogram.org/doku.php>__.

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 <https://help.github.com/articles/about-pull-requests/>__ 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 <https://www.python.org/dev/peps/pep-0008/>_ and use the corresponding linter <https://pypi.python.org/pypi/pep8>_ to check for it. Code should always come with documentation, which is generated automatically and can be found here <http://openfermion.readthedocs.io/en/latest/openfermion.html>_.

We use Github issues <https://github.com/quantumlib/OpenFermion/issues>__ for tracking requests and bugs. Please post questions to the Quantum Computing Stack Exchange <https://quantumcomputing.stackexchange.com/>__ with an 'openfermion' tag.

Authors

Ryan Babbush <http://ryanbabbush.com>__ (Google), Jarrod McClean <http://jarrodmcclean.com>__ (Google), Nicholas Rubin <https://github.com/ncrubin>__ (Google), Kevin Sung <https://github.com/kevinsung>__ (University of Michigan), Ian Kivlichan <http://aspuru.chem.harvard.edu/ian-kivlichan/>__ (Harvard), Dave Bacon <https://github.com/dabacon>__ (Google), Xavier Bonet-Monroig <https://github.com/xabomon>__ (Leiden University), Yudong Cao <https://github.com/yudongcao>__ (Harvard), Chengyu Dai <https://github.com/jdaaph>__ (University of Michigan), E. Schuyler Fried <https://github.com/schuylerfried>__ (Harvard), Craig Gidney <https://github.com/Strilanc>__ (Google), Brendan Gimby <https://github.com/bgimby>__ (University of Michigan), Pranav Gokhale <https://github.com/singular-value>__ (University of Chicago), Thomas Häner <https://github.com/thomashaener>__ (ETH Zurich), Tarini Hardikar <https://github.com/TariniHardikar>__ (Dartmouth), Vojtĕch Havlíček <https://github.com/VojtaHavlicek>__ (Oxford), Oscar Higgott <https://github.com/oscarhiggott>__ (University College London), Cupjin Huang <https://github.com/pertoX4726>__ (University of Michigan), Josh Izaac <https://github.com/josh146>__ (Xanadu), Zhang Jiang <https://ti.arc.nasa.gov/profile/zjiang3>__ (NASA), William Kirby <https://williammkirby.com>__ (Tufts University), Xinle Liu <https://github.com/sheilaliuxl>__ (Google), Sam McArdle <https://github.com/sammcardle30>__ (Oxford), Matthew Neeley <https://github.com/maffoo>__ (Google), Thomas O'Brien <https://github.com/obriente>__ (Leiden University), Bryan O'Gorman <https://ti.arc.nasa.gov/profile/bogorman>__ (UC Berkeley, NASA), Isil Ozfidan <https://github.com/conta877>__ (D-Wave Systems), Max Radin <https://github.com/max-radin>__ (UC Santa Barbara), Jhonathan Romero <https://github.com/jromerofontalvo>__ (Harvard), Daniel Sank <https://github.com/DanielSank>__ (Google), Nicolas Sawaya <https://github.com/nicolassawaya>__ (Harvard), Bruno Senjean <https://github.com/bsenjean>__ (Leiden University), Kanav Setia <https://github.com/kanavsetia>__ (Dartmouth), Hannah Sim <https://github.com/hsim13372>__ (Harvard), Damian Steiger <https://github.com/damiansteiger>__ (ETH Zurich), Mark Steudtner <https://github.com/msteudtner>__ (Leiden University), Qiming Sun <https://github.com/sunqm>__ (Caltech), Wei Sun <https://github.com/Spaceenter>__ (Google), Daochen Wang <https://github.com/daochenw>__ (River Lane Research), Chris Winkler <https://github.com/quid256>__ (University of Chicago) and Fang Zhang <https://github.com/fangzh-umich>__ (University of Michigan).

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 <https://iopscience.iop.org/article/10.1088/2058-9565/ab8ebc/meta>`__.

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.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].