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

Learn about dynamic FPGA program reloading and real-time parameter updates for fast iteration and adaptive measurements

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

Developer guides

Learn how to write your own SubSequence from scratch: defining a ParameterClass, writing qua_sequence, scaling to multiple gates with ParameterMap, using lifecycle hooks, and composing sequences by nesting.

Learn how to write AbstractReadout subclasses and compose them into a ReadSequence: producing and consuming gettables, adding settable parameters, declaring temporary QUA variables, and writing the configuration.

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.5.tar.gz (1.8 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.5-py3-none-any.whl (102.3 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for arbok_driver-2.5.5.tar.gz
Algorithm Hash digest
SHA256 3768521b96d6525424dc151a4515d636a0c5e2e28a0cf19186b812effa4c9694
MD5 e1310b22c61b434b7a1da9317940ce37
BLAKE2b-256 5ef5c3a1033f8ec229a34c47fbe44274fcd3cd2082c8106457cba661666b4649

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for arbok_driver-2.5.5-py3-none-any.whl
Algorithm Hash digest
SHA256 3257576d78b689e45aa0e92167abc5817254f5dd6378cdcd23fe556b264e6860
MD5 5edb96923a991ddf1b2aacce4f95433f
BLAKE2b-256 ed2accd202e1d6af0aa7bf52a8d4cb77d6a547c360dd33a5abeef11888e0c05d

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