Code Monkey home page Code Monkey logo

openfermion's Introduction

OpenFermion

image

image

Documentation Status

image

image

OpenFermion is an open source effort for compiling and analyzing quantum algorithms to simulate fermionic systems, including quantum chemistry. Among other functionalities, the current version features data structures and tools for obtaining and manipulating representations of fermionic and qubit Hamiltonians. For more information, see our release paper and press release about the project.

Getting started

Installing OpenFermion requires pip. Make sure that you are using an up-to-date version of it. For information about getting started beyond what is provided below please see intro and code examples. Also take a look at the ipython notebook demo as well as our detailed code documentation.

Currently, OpenFermion is only tested on Mac and Linux for the reason that both electronic structure plugins are only compatible with Mac and Linux. 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.

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 about these useful plugins.

Circuit compilation and simulation plugins

Electronic structure package plugins

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.

Authors

Ryan Babbush (Google), Jarrod McClean (Google), Ian Kivlichan (Harvard), Damian Steiger (ETH Zurich), Dave Bacon (Google), Yudong Cao (Harvard), E. Schuyler Fried (Harvard), Craig Gidney (Google), Thomas Häner (ETH Zurich), Vojtĕch Havlíček (Oxford), Zhang Jiang (NASA), Matthew Neeley (Google), Jhonathan Romero (Harvard), Nicholas Rubin (Rigetti), Daniel Sank (Google), Nicolas Sawaya (Harvard), Kanav Setia (Dartmouth), Hannah Sim (Harvard), Wei Sun (Google) and Kevin Sung (University of Michigan).

How to cite

When using OpenFermion for research projects, please cite:

Jarrod R. McClean, Ian D. Kivlichan, Damian S. Steiger, Yudong Cao, E. Schuyler Fried, Craig Gidney, Thomas Häner, Vojtĕch Havlíček, Zhang Jiang, Matthew Neeley, Jhonathan Romero, Nicholas Rubin, Nicolas P. D. Sawaya, Kanav Setia, Sukin Sim, Wei Sun, Kevin Sung and Ryan Babbush. OpenFermion: The Electronic Structure Package for Quantum Computers. arXiv:1710.07629. 2017.

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.

openfermion's People

Contributors

babbush avatar dabacon avatar kevinsung avatar jarrodmcc avatar danielsank avatar spaceenter avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.