A Quantum compUting PULse parametrization and SEquencing framework
qupulse: A Quantum compUting PULse parametrization and SEquencing framework
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.
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 AWGs and AlazarTech Digitizers
- MATLAB interface to access qupulse functionality
qupulse is developed using Python 3.5 but should also run on previous 3.3+ versions.
The package is installed with:
python3 setup.py install
The backend for TaborAWGs requires packages that can be found here.
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@example.com.
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.
You can find documentation on how to use this library on readthedocs and IPython notebooks with examples in this repo
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
pulseswhich contains all modules related to pulse representation.
hardwarecontaining classes for hardware representation as well as hardware drivers
utilscontaining miscellaneous utility modules or wrapping code for external libraries
tests mirror the structure of
qupulse. For every
<module> somewhere in
qupulse there should exist a
<module>Tests.py in the corresponding subdirectory of
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.