Code Monkey home page Code Monkey logo

qupulse's Introduction

qupulse: A Quantum compUting PULse parametrization and SEquencing framework

Coverage Status Build Status Documentation Status DOI

The qupulse project aims to produce a software toolkit facilitating experiments involving pulse driven state manipulation of physical qubits.

It provides a high-level hardware-independent representation of pulses as well as means to translate this representation to hardware-specific device instructions and waveforms, execute these instructions and perform corresponding measurements.

Pulses can be assembled from previously defined subpulses, allowing easy construction of high-level from low-level pulses and re-use of previous work. Additionally, all pulses are parameterizable allowing users to fine-tune and adapt pulse templates to specific hardware or functionality without redefining an entire pulse sequence. To ensure meaningful parameter values, constraints can be put on parameters on a per-pulse basis.

Status

Note that the project is still in development and thus not feature-complete.

The qupulse library is already used productively by the Quantum Technology Group at the 2nd Institute of Physics at the RWTH Aachen University. As such, some features - such as pulse definition - are mostly complete and tested and interfaces are expected to remain largely stable (or changes to be backward compatible). However, it is still possible for existing portions of the code base to be redesigned if this will increase the usability long-term.

The current feature list is as follows:

  • Definition of complex (arbitrarily deep nested and looped pulses) parameterized pulses in Python (including measurement windows)
  • Mathematical expression evaluation (based on sympy) for parameter values and parameter constraints
  • Serialization of pulses (to allow storing into permanent storage)
  • Hardware model representation (prototype, work in progress)
  • High-level pulse to hardware configuration and waveform translation routines
  • Hardware drivers for Tabor Electronics, Tektronix and Zurich Instruments AWGs and AlazarTech Digitizers
  • MATLAB interface to access qupulse functionality

Installation

qupulse is available on PyPi and the latest release can be installed by executing:

pip3 install qupulse

qupulse version numbers follow the Semantic Versioning conventions.

Alternatively, the current development version of qupulse can be installed by executing in the cloned repository root folder:

pip3 install .

qupulse is developed using Python 3.6 and tested on 3.5 - 3.7 It relies on some external Python packages as dependencies; requirements.txt lists the versions of these qupulse is developed against. We intentionally did not restrict versions of dependencies in the install scripts to not unnecessarily prevent usage of newer releases of dependencies that might be compatible. However, if qupulse does encounter problems with a particular dependency version, try installing the version listed in requirements.txt.

The backend for TaborAWGs requires packages that can be found here. As a shortcut you can install it from the python interpreter via qupulse.hardware.awgs.install_requirements('tabor').

The data acquisition backend for AlazarTech cards needs a package that unfortunately is not open source (yet). If you need it or have questions contact [email protected].

The optional script tests/utils/syntax_check.py invokes pyflakes to perform a static code analysis, so pyflakes should be installed if its usage is intended.

Documentation

You can find documentation on how to use this library on readthedocs and IPython notebooks with examples in this repo. You can build it locally with python setup.py build_sphinx.

Folder Structure

The repository primarily consists of the folders qupulse (toolkit core code) and tests (toolkit core tests). Additional parts of the project reside in MATLAB (MATLAB interface) and doc (configuration and source files to build documentation)

qupulse contains the entire Python source code of the project and is further partitioned the following packages of related modules

  • pulses which contains all modules related to pulse representation.
  • hardware containing classes for hardware representation as well as hardware drivers
  • utils containing miscellaneous utility modules or wrapping code for external libraries
  • _program contains general and hardware specific representations of instantiated (parameter free) pulses. It is private because there is no stability guarantee.

Contents of tests mirror the structure of qupulse. For every <module> somewhere in qupulse there should exist a <module>Tests.py in the corresponding subdirectory of tests.

qupulse's People

Contributors

terrorfisch avatar lumip avatar pcerf avatar pbethke avatar hylta avatar j340m3 avatar m-superposition avatar ekammerloher avatar qutech-lab avatar lankes-fzj avatar thangleiter avatar eendebakpt avatar m-kreutz avatar peendebak 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.