Skip to main content

Quantum Instrumentation Controller Kit software library

Project description

QICK logo

QICK: Quantum Instrumentation Control Kit

QICK is an open-source qubit controller, consisting of firmware, software, and an optional frontend for use with Xilinx RFSoC development boards. The goal of the project is to provide a powerful, flexible, cost-effective, and easy-to-learn platform for control and readout of a diverse range of quantum systems.

QICK supports the ZCU111, ZCU216, and RFSoC4x2 development boards. We generally recommend using the newer generation of RFSoCs (ZCU216 and RFSoC4x2) for better overall performance.

It consists of:

  • Firmware for the supported RFSoC boards, both compiled bitstreams and source for the designs and modules
  • The qick Python package, which includes the interface to the firmware and an API for writing QICK programs
  • Jupyter notebooks demonstrating usage

See our Read the Docs site for:

  • Documentation of the firmware and software
  • A quick-start guide for setting up your board and running the example Jupyter notebooks
  • Ways to communicate with QICK developers and the community
  • Extensions to QICK for added functionailty

Updates

The QICK firmware and software is still very much a work in progress. We strive to be consistent with the APIs but cannot guarantee backwards compatibility.

[!NOTE] QICK does not yet support PYNQ v3.1. The QICK quick-start guide (linked above) lists the currently recommended PYNQ OS images for your SD card.

Frequent updates to the QICK firmware and software are made as pull requests. Each pull request will be documented with a description of the notable changes, including any changes that will require you to change your code. We hope that this will help you decide whether or not to update your local code to the latest version. We strive for, but cannot guarantee, bug-free and fully functional pull requests. We also do not guarantee that the demo notebooks will keep pace with every pull request, though we make an effort to update the demos after major API changes.

Our version numbering follows the format major.minor.PR, where PR is the number of the most recently merged pull request. This will result in the PR number often skipping values, and occasionally decreasing. The tagged release of a new minor version will have the format major.minor.0.

Tagged releases can be expected periodically. We recommend that everyone should be using at least the most recent release. We guarantee the following for releases:

  • The demo notebooks will be compatible with the QICK library, and will follow our current best recommendations for writing QICK programs.
  • The firmware images for all supported boards will be fully compatible with the library and the demo notebooks.
  • Release notes will summarize the pull request notes and explain both breaking API changes (what you need to change in your code) and improvements (why you should move to the new release).

We recommend that you "watch" this repository on GitHub to get automatic notifications of pull requests and releases.

Contribute

You are welcome to contribute to QICK development by forking this repository and sending pull requests.

All contributions are expected to be consistent with PEP 8 -- Style Guide for Python Code.

We welcome bug reports and feature requests via GitHub Issues.

License

The QICK source code is licensed under the MIT license, which you can find in the LICENSE file. You are free to use QICK, with or without modification, under the terms of this license.

The QICK logo was designed by Dr. Christie Chiu.

Open-Source Commitment

QICK is and will remain a fully open-source project under the MIT license. Commercial partnerships or integration agreements with third-party companies do not change the licensing, governance, or availability of this project. All QICK source code, including firmware, software, and documentation, will continue to be freely available in this repository, and the QICK developers will continue to support the community. If you have questions or concerns, please don't hesitate to reach out.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

qick-0.2.414.tar.gz (16.7 MB view details)

Uploaded Source

Built Distribution

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

qick-0.2.414-py3-none-any.whl (17.2 MB view details)

Uploaded Python 3

File details

Details for the file qick-0.2.414.tar.gz.

File metadata

  • Download URL: qick-0.2.414.tar.gz
  • Upload date:
  • Size: 16.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for qick-0.2.414.tar.gz
Algorithm Hash digest
SHA256 feb2f2373d0ec1f47e76f8c450eee683ebf83b2025f4e14af9a380436125b88c
MD5 3a5c2c09c85d3568110e000f93fc59fd
BLAKE2b-256 2c407d12cda71c2a6dccab97d260d34f2b638fd0c060f39286b97d56a02c7614

See more details on using hashes here.

Provenance

The following attestation bundles were made for qick-0.2.414.tar.gz:

Publisher: wheels.yml on openquantumhardware/qick

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file qick-0.2.414-py3-none-any.whl.

File metadata

  • Download URL: qick-0.2.414-py3-none-any.whl
  • Upload date:
  • Size: 17.2 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for qick-0.2.414-py3-none-any.whl
Algorithm Hash digest
SHA256 4c9800c7b2e887a4f8d3e6fe85850976c16c427c2610beb20ef9cc638e0a8928
MD5 24d407a792a838933bea11331a5228e2
BLAKE2b-256 f592b89cdf78a3bcc16b57548fd1f5134073de1826f7649f4306a55afcd19a38

See more details on using hashes here.

Provenance

The following attestation bundles were made for qick-0.2.414-py3-none-any.whl:

Publisher: wheels.yml on openquantumhardware/qick

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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