Skip to main content

deq: quantum error correction decoding system.

Project description

deq: dynamic and generic QEC decoding system

deq is a quantum error correction (QEC) decoding system that provides an automated workflow from declarative definitions of QEC codes and logical instructions to a runtime decoder for arbitrary dynamic logical circuits.

Key features:

  • Declarative .deq language — define QEC codes and their physical gate realizations using a stim-compatible DSL; deq automatically discovers checks (detectors) from the Clifford circuit
  • Dynamic circuit decoding — decode logical circuits whose instructions stream in at runtime, not just static offline-known circuits
  • Simulation & deployment — run logical error rate simulations, latency benchmarks, and deploy on real hardware with the same compiled library

See the Tutorial for a full introduction, language reference, and worked examples.

Installation

pip install deq deq-runtime

See Install from source below if you want a development build or to hack on the Rust runtime.

Quick start

Here is an example deq program:

# define a QEC code of [[n,k,d]] (d is optional)
CODE RepetitionCode [[3,1,3]] {
    LOGICAL X0*X1*X2 Z0*Z1*Z2
    STABILIZER Z0*Z1 Z1*Z2
}

GADGET PrepareZ {
    R 0 1 2
    X_ERROR(0.03) 0 1 2
    OUTPUT RepetitionCode 0 1 2
}

GADGET Idle {
    INPUT RepetitionCode 0 2 4
    X_ERROR(0.03) 0 2 4  # data qubit error
    R 1 3
    CX 0 1 2 3
    CX 2 1 4 3
    M(0.03) 1 3  # measurement error
    OUTPUT RepetitionCode 0 2 4
}

GADGET MeasureZ {
    INPUT RepetitionCode 0 1 2
    M(0.03) 0 1 2  # measurement error
    READOUT rec[-1] rec[-2] rec[-3]
}

# a logical circuit with criteria of logical error
PROGRAM Simulation {
    PrepareZ 0
    Idle 0
    MeasureZ 0
    ASSERT_EQ rec[-1] 0
}
# Transpile a .deq definition into a JIT library
deq transpile example.deq --out example.deq.jit --program Simulation

# Run a logical error rate simulation
deq server --decoder black-box-relay-bp --coordinator window \
    --controller jit --controller-config '{"filepath":"example.deq.jit"}' \
    --simulator jit-static --simulator-config '{"filepath":"example.stim","jit_library_filepath":"example.deq.jit","shots":100000}'

Install from source

Prerequisites

  • Python ≥ 3.10
  • Rust toolchain (for building deq_runtime)
  • maturin (pip install maturin)
  • protobuf compiler (apt install protobuf-compiler on Ubuntu, brew install protobuf on macOS)

Steps

# 1. Build and install the Rust runtime (deq_runtime)
cd deq_runtime
maturin develop --release
cd ..

# 2. Generate protobuf Python bindings
python deq/proto/compile.py

# 3. Install the deq Python package
pip install -e .

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

deq-0.3.1.tar.gz (199.3 kB view details)

Uploaded Source

Built Distribution

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

deq-0.3.1-py3-none-any.whl (268.2 kB view details)

Uploaded Python 3

File details

Details for the file deq-0.3.1.tar.gz.

File metadata

  • Download URL: deq-0.3.1.tar.gz
  • Upload date:
  • Size: 199.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: RestSharp/106.13.0.0

File hashes

Hashes for deq-0.3.1.tar.gz
Algorithm Hash digest
SHA256 ae231da03268f03c912533be048d3926625b85be938d6630c8e31c933e120506
MD5 f7427a544830432d06dce8524384639a
BLAKE2b-256 8f651723c60ef26c2b684473baa2ed32ee227c4b1637859e3039e72adf7fc816

See more details on using hashes here.

File details

Details for the file deq-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: deq-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 268.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: RestSharp/106.13.0.0

File hashes

Hashes for deq-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ce32846597fd1c66e36b807993bef29e11139f27e4ab802b71a0004d63ce04a7
MD5 d0f4fadad85c80e2f064f424e8102ed6
BLAKE2b-256 1c4bd2b5af90582e798c54286990094b131cef241513d1a3a9cd97f4b65b89f3

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