Skip to main content

A Quantum compUting PULse parametrization and SEquencing framework

Project description

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 and stability

The qupulse library is 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). A key goal is that experiments should be repeatable with new versions of qupulse. 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
  • 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

Pending changes are tracked in the changes.d subdirectory and published in RELEASE_NOTES.rst on release using the tool towncrier.

Installation

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

python -m pip install qupulse[default]

which will install all required and optional dependencies except for hardware support. qupulse version numbers follow the Semantic Versioning conventions.

Alternatively, the current development version of qupulse can be installed by executing

python -m pip install -e git+https://github.com/qutech/qupulse.git#egg=qupulse[default]

which will clone the github repository to ./src/qupulse and do an editable/development install.

Requirements and dependencies

qupulse requires at least Python 3.8 and is tested on 3.8, 3.9 and 3.10. It relies on some external Python packages as dependencies. 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 please file an issue.

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 simon.humpohl@rwth-aachen.de.

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.

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

qupulse-0.9.tar.gz (187.5 kB view details)

Uploaded Source

Built Distribution

qupulse-0.9-py3-none-any.whl (216.8 kB view details)

Uploaded Python 3

File details

Details for the file qupulse-0.9.tar.gz.

File metadata

  • Download URL: qupulse-0.9.tar.gz
  • Upload date:
  • Size: 187.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.18

File hashes

Hashes for qupulse-0.9.tar.gz
Algorithm Hash digest
SHA256 6ac260ca74305d083714898f1c2a8b1ab36c9ddf46510e2ac04facf8f49e8980
MD5 6d37dc857456de5bfdc79dd03e47dcea
BLAKE2b-256 318247faf06e13b685b432e6683ca72bd87d5557e71c2080bbf8a8189b82dbb8

See more details on using hashes here.

File details

Details for the file qupulse-0.9-py3-none-any.whl.

File metadata

  • Download URL: qupulse-0.9-py3-none-any.whl
  • Upload date:
  • Size: 216.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.18

File hashes

Hashes for qupulse-0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 100fa0923d485bf8da42a4cdf646ae1504be7c429f6b2c04ba74c589061388a7
MD5 cb945fe23245f4eca1b20fa1d07be009
BLAKE2b-256 b95aa806887f1e5587d3fa5e84c3107300b2e2089e9690fbca084329f1517642

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page