Generic Superconducting Quantum Process Design Kit
Project description
QPDK is an open-source process design kit (PDK) for superconducting quantum RF applications built on gdsfactory. It provides a library of parametric quantum circuit components (transmon qubits, CPW resonators, Josephson junctions, etc.), analytical S-parameter models, routing utilities, and test-chip examples.
QPDK gives researchers, engineers, and students a scriptable, version-controlled foundation to go from concept to GDSII in minutes.
Key Features
- Rich component library — Transmons, fluxonium, unimon qubits, CPW resonators, interdigital capacitors, SQUID junctions, launchers, bump bonds, TSVs, and more.
- Parametric & composable — Combine Python functions (
@gf.cell) into hierarchical designs or define full chips in YAML. - Analytical circuit models — Fast, differentiable S-parameter simulations powered by SAX and JAX.
- Automated routing — CPW-aware routing strategies with auto-tapers for complex layouts, and DoRoutes.
- KLayout integration — Layer definitions, technology files, and cross sections for immediate visual inspection.
- Regression-tested — GDS regression tests, netlist checks, and model validation.
- Notebook-driven workflows — Jupyter notebooks for frequency modeling, tolerance analysis, parameter extraction, pulse-level simulation, and optimization.
- GDSFactory+ integration — Seamlessly design, verify, and validate chips with the enhanced commercial extension. Includes access to 43+ foundry PDKs, graphical layout and schematic editors directly in VSCode, an AI assistant, and comprehensive verification tools (DRC, LVS, Connectivity checks).
Notable Components
QPDK ships with a broad set of ready-to-use superconducting circuit components. Browse all the components in the documentation.
Qubits
| Transmon | Fluxonium |
|---|---|
| Double-pad capacitively shunted qubit | Superinductance-shunted qubit |
| Unimon | SQUID Junction |
|---|---|
| Resonator-embedded junction qubit | Superconducting quantum interference device |
Passive Components
| CPW Resonator | Interdigital Capacitor |
|---|---|
| Meandering coplanar waveguide resonator | Finger-style lumped-element capacitor |
Composite Components
Transmon with Resonator & Probeline — Qubit cell with coupled resonator and probeline section:
Sample Test Chips
QPDK includes some complete, tapeout-ready test chip examples that demonstrate real-world design workflows.
Qubit Test Chip
A four-transmon test chip with coupled readout resonators, probeline routing, flux lines, and launchers. Defined entirely in YAML.
Filled Qubit Test Chip
The same qubit test chip with magnetic vortex trapping holes filling the ground plane and chip edges.
Resonator Test Chip
A 16-resonator characterization chip with systematically varied CPW widths and gaps across two probelines. Ideal for extracting loss tangents and kinetic inductance. Also check the notebook demonstrating network model simulations and fabrication tolerance Monte Carlo.
Quick Start
import gdsfactory as gf
from qpdk import PDK
PDK.activate()
# Create a transmon qubit
from qpdk.cells.transmon import double_pad_transmon
qubit = double_pad_transmon(pad_size=(250, 400), pad_gap=15)
qubit.plot()
# Build a complete test chip from YAML
from gdsfactory.read import from_yaml
from qpdk import tech
chip = from_yaml(
"qpdk/samples/qubit_test_chip.pic.yml",
routing_strategies=tech.routing_strategies,
)
chip.show() # Opens in KLayout
Examples & Notebooks
- PDK cells in the documentation — Collection of all available geometries.
qpdk/samples/— Example layouts and simulations including qubit test chips, resonator arrays, routing demos, and 3D export.notebooks/— Jupyter notebooks covering:- Resonator frequency modeling and S-parameter analysis
- Circuit simulation with SAX
- Monte Carlo fabrication tolerance analysis
- Hamiltonian parameter extraction with scqubits
- Pulse-level quantum gate simulation with QuTiP
- Capacitor geometry optimization with Optuna
- Dispersive shift calculation with Pymablock
- Transmon design optimization with NetKet
- gsim example notebooks — Electromagnetic simulation examples using Palace and Meep with gdsfactory.
Installation
We recommend using uv for package management. just is used
for project-specific recipes.
Installation for Users
Install the package with:
uv pip install qpdk
Or with pip:
pip install qpdk
Optional dependencies for the analytical models and simulation tools (SAX, scqubits, JAX) can be installed with:
uv pip install qpdk[models]
KLayout Technology Installation
To use the PDK in KLayout (for viewing GDS files with correct layers and technology settings), install the technology files:
python -m qpdk.install_tech
[!NOTE] After installation, restart KLayout to ensure the new technology appears.
Installation for Contributors
For contributors, please follow the installation and development workflow instructions.
Project Structure
qpdk/ Core Python package
cells/ Component definitions (transmons, resonators, capacitors, …)
models/ Analytical models, mostly S-parameters
samples/ Example layouts and complete test chips
klayout/ KLayout technology files
tech.py Layer stack, cross sections, routing strategies
tests/ Regression, integration and unit tests
notebooks/ Jupyter notebooks for design and simulation workflows
docs/ Sphinx documentation (HTML + PDF)
Documentation
Contributing
We welcome contributions of all sizes: new components, improved models, bug fixes, documentation, and notebook tutorials. Please see the contributing guide to get started.
Support
For commercial support, training, and custom PDK development, please visit gdsfactory+ (gdsfactory.com/plus).
License
QPDK is released under the MIT License.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file qpdk-0.3.8.tar.gz.
File metadata
- Download URL: qpdk-0.3.8.tar.gz
- Upload date:
- Size: 105.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
928a412fcdf87c6c8e29dccb613417944fb74e5919d501685a17936586995405
|
|
| MD5 |
98b8cdb7eef2f651c1f8f32dcb83297c
|
|
| BLAKE2b-256 |
59b4ae77a41eeb2af03cece1f28a9d99327a014750f8c2c350102a0586a928dd
|
Provenance
The following attestation bundles were made for qpdk-0.3.8.tar.gz:
Publisher:
release.yml on gdsfactory/quantum-rf-pdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
qpdk-0.3.8.tar.gz -
Subject digest:
928a412fcdf87c6c8e29dccb613417944fb74e5919d501685a17936586995405 - Sigstore transparency entry: 1590582033
- Sigstore integration time:
-
Permalink:
gdsfactory/quantum-rf-pdk@7756cbdeb80c9d2a57d50a9eccee17c0b2b73cbe -
Branch / Tag:
refs/heads/main - Owner: https://github.com/gdsfactory
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@7756cbdeb80c9d2a57d50a9eccee17c0b2b73cbe -
Trigger Event:
push
-
Statement type:
File details
Details for the file qpdk-0.3.8-py3-none-any.whl.
File metadata
- Download URL: qpdk-0.3.8-py3-none-any.whl
- Upload date:
- Size: 134.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
36e3f4cd6800491152abbc958473d4d9a00ee79475966df884771995683e3006
|
|
| MD5 |
269b373c5fdf1083678c9fd83af3ab87
|
|
| BLAKE2b-256 |
6b00fa7d26376703884f1860ffc02080764d33168997a3d2964c964e3498597e
|
Provenance
The following attestation bundles were made for qpdk-0.3.8-py3-none-any.whl:
Publisher:
release.yml on gdsfactory/quantum-rf-pdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
qpdk-0.3.8-py3-none-any.whl -
Subject digest:
36e3f4cd6800491152abbc958473d4d9a00ee79475966df884771995683e3006 - Sigstore transparency entry: 1590582122
- Sigstore integration time:
-
Permalink:
gdsfactory/quantum-rf-pdk@7756cbdeb80c9d2a57d50a9eccee17c0b2b73cbe -
Branch / Tag:
refs/heads/main - Owner: https://github.com/gdsfactory
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@7756cbdeb80c9d2a57d50a9eccee17c0b2b73cbe -
Trigger Event:
push
-
Statement type: