Skip to main content

QCoDeS compatible driver for the OPX+ from Quantum Machines

Project description

arbok-driver 🐍⚡️

Documentation Status PyPI License Coverage Python

A dynamically generated QCoDeS instrument for your FPGA based measurements using the Quantum Machines OPX+/OPX1000.


Installation 📲

From pypi install using pip in your environment:

pip install arbok-inspector

Even better if you are using uv, a uv.lock file is included!


Features 🛠️

  • Abstraction: In contrast to traditional static QCoDeS instruments with a fixed set of parameters determined at driver design time, arbok is dynamically generated for the FPGA program itself each time a measurement is run. FPGA progam parameters such as wait times, voltages, and frequencies etc. are automatically exposed through the QCoDeS instrument, without the user needing to interact with or even see the underlying FPGA code.

  • Modularity: Measurements are generated from logical blocks of instructions called SubSequence and ReadSequence whose order can be arranged freely. Those sequences can be nested arbitrarily deep to reach the desired complexity without repeating yourself (imagine a nested dict).

  • Scalability: Arbok strictly separates the qualitative design of FPGA instructions in SubSequence and ReadSequence and their quantitative configuration (through python dicts), ensuring reproducibility. Sequences are written in a fully parameterized way, giving user access to every aspect of the measurement. This approach allows us to grow our quantum chips without re-writing any FPGA sequences by just scaling the configuration we are using, while still exposing every single sub-parameter of the device.

  • Compatibility: At the end of the day, the arbok-driver is still a QCoDeS instrument, giving you all the features you know from running measurements on regular hardware. It slots right into your existing stack and allows you to sweep hardware parameters as well as FPGA instructions.

  • Auto-tuning: All parameters can be defined as undetermined variables and updated by the user in real time without needing to re-compile the FPGA program for each set of parameters. This is particularly interesting for adaptive calibrations, machine learning or qubit benchmarking.

  • Asynchronicity: Support for asynchronously running sequences like qubit state heralding or live qubit feedback (e.g Larmor, Rabi)


Tutorials 🎓

The tutorial series introduces the core concepts of the arbok framework, guiding you from running basic measurements to building modular, scalable, and automated experiments.

Set up your environment, initialise your device, and run a first measurement using existing sequences.

Learn how FPGA program parameters (e.g. voltages, timings, frequencies) are exposed through the QCoDeS interface and how to configure them dynamically.

Understand how to use and compose ReadSequences to extract measurement results in a structured and reusable way.

Build higher-level experiment abstractions to repeatedly run and organise complex measurement routines.

Implement automated tuning and calibration routines using the GenericTuningInterface, enabling adaptive and scalable workflows without recompilation of FPGA instructions

Together, these tutorials demonstrate how arbok enables:

  • Modular composition of measurements from reusable building blocks
  • Full parameter control without modifying FPGA/qua code
  • Seamless scaling from small devices to larger quantum systems
  • Fast iteration through dynamic reloading with Ekans

Stripping jupyter notebooks 📒

We all love running measurements and analysis scripts from notebooks but keeping them up to date with version control can be a pain. Differeing outputs, timestamps and massive binary data can make your diffs massive. We include git hooks that automatically clear the outputs of your notebook once you commit it. The arbok_driver is configured declaratively so dont worry you will reach the same state again once you re-run your notebook.

Install the git hook so that your notebooks are stripped before committing.

Microsoft :

.\tools\git.hooks\setupMicrosoft.ps1

Linux :

./tools/git.hooks/setupLinux.sh

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

arbok_driver-2.5.2.tar.gz (1.5 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

arbok_driver-2.5.2-py3-none-any.whl (93.8 kB view details)

Uploaded Python 3

File details

Details for the file arbok_driver-2.5.2.tar.gz.

File metadata

  • Download URL: arbok_driver-2.5.2.tar.gz
  • Upload date:
  • Size: 1.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for arbok_driver-2.5.2.tar.gz
Algorithm Hash digest
SHA256 f1ebcb60a508b1cb093e6443ce405ddf44d534f4266820ba8a668bb0b7983edd
MD5 7bd18b512ca23df0d06db1e57aca1435
BLAKE2b-256 4edd3fc96b1fcc2394b41ee6d6908afbea166dba0b8c7bcd5ae8ed600a915f74

See more details on using hashes here.

File details

Details for the file arbok_driver-2.5.2-py3-none-any.whl.

File metadata

  • Download URL: arbok_driver-2.5.2-py3-none-any.whl
  • Upload date:
  • Size: 93.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for arbok_driver-2.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c1bf7a3b73161ef753f1de485656bfa156fcc487f475f0a455b724c92395253e
MD5 f4b3bb5c7316dd4f5bce3c3f8396bc73
BLAKE2b-256 8aa3794c241342c18e312b173a67f950b7aeb7eca6e18b61952fd68ff76277ca

See more details on using hashes here.

Supported by

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