Skip to main content

A search-based decoder for quantum error correction (QEC).

Project description

Tesseract Decoder

A Search-Based Decoder for Quantum Error Correction.

Licensed under the Apache 2.0 open-source license C++

InstallationUsagePaperHelpCitationContact

Tesseract is a Most Likely Error decoder designed for Low Density Parity Check (LDPC) quantum error-correcting codes. It applies pruning heuristics and manifold orientation techniques during a search over the error subsets to identify the most likely error configuration consistent with the observed syndrome. Tesseract achieves significant speed improvements over traditional integer programming-based decoders while maintaining comparable accuracy at moderate physical error rates.

We tested the Tesseract decoder for:

  • Surface codes
  • Color codes
  • Bivariate-bicycle codes
  • Transversal CNOT protocols for surface codes

Features

  • A* search: deploys A* search while running a Dijkstra algorithm with early stop for high performance.
  • Stim and DEM Support: processes Stim circuit files and Detector Error Model (DEM) files with arbitrary error models. Zero-probability error instructions are automatically removed when a DEM is loaded.
  • Parallel Decoding: uses multithreading to accelerate the decoding process, making it suitable for large-scale simulations.
  • Efficient Beam Search: implements a beam search algorithm to minimize decoding cost and enhance efficiency. Sampling and Shot Range Processing: supports sampling shots from circuits. When a detection error model is provided without an accompanying circuit, Tesseract requires detection events from files using --in. The decoder can also process specific shot ranges for flexible experiment setups.
  • Detailed Statistics: provides comprehensive statistics output, including shot counts, error counts, and processing times.
  • Heuristics: includes flexible heuristic options: --beam, --det-penalty, --beam-climbing, --no-revisit-dets, --at-most-two-errors-per-detector, and --pqlimit to improve performance while maintaining a low logical error rate. To learn more about these options, use ./bazel-bin/src/tesseract --help
  • Visualization tool: open the viz directory in your browser to view decoding results. See viz/README.md for instructions on generating the visualization JSON.

Installation

Tesseract relies on the following external libraries:

  • argparse: For command-line argument parsing.
  • nlohmann/json: For JSON handling (used for statistics output).
  • Stim: For quantum circuit simulation and error model handling.

Build Instructions

Tesseract uses Bazel as its build system. To build the decoder:

bazel build src:all

Running Tests

Unit tests are executed with Bazel. Run the quick test suite using:

bazel test //src:all

By default the tests use reduced parameters and finish in under 30 seconds. To run a more exhaustive suite with additional shots and larger distances, set:

TESSERACT_LONG_TESTS=1 bazel test //src:all

Usage

The file tesseract_main.cc provides the main entry point for Tesseract Decoder. It can decode error events from Stim circuits, DEM files, and pre-existing detection event files.

Basic Usage:

./tesseract --circuit CIRCUIT_FILE.stim --sample-num-shots N --print-stats

To decode pre-generated detection events, provide the input file using --in SHOTS_FILE --in-format FORMAT.

Example with Advanced Options:

./tesseract \
        --pqlimit 1000000 \
        --at-most-two-errors-per-detector \
        --det-order-seed 232852747 \
        --circuit circuit_file.stim \
        --sample-seed 232856747 \
        --sample-num-shots 10000 \
        --threads 32 \
        --print-stats \
        --beam 23 \
        --num-det-orders 1 \
        --shot-range-begin 582 \
        --shot-range-end 583

Example Usage

Sampling Shots from a Circuit:

./tesseract --circuit surface_code.stim --sample-num-shots 1000 --out predictions.01 --out-format 01

Using a Detection Event File:

./tesseract --in events.01 --in-format 01 --dem surface_code.dem --out decoded.txt

Using a Detection Event File and Observable Flips:

./tesseract --in events.01 --in-format 01 --obs_in obs.01 --obs-in-format 01 --dem surface_code.dem --out decoded.txt

Tesseract supports reading and writing from all of Stim's standard output formats.

Performance Optimization

Here are some tips for improving performance:

  • Parallelism over shots: increase --threads to leverage multicore processors for faster decoding.
  • Beam Search: use --beam to control the trade-off between accuracy and speed. Smaller beam sizes result in faster decoding but potentially lower accuracy.
  • Beam Climbing: enable --beam-climbing for enhanced cost-based decoding.
  • At most two errors per detector: enable --at-most-two-errors-per-detector to improve performance.
  • Priority Queue limit: use --pqlimit to limit the size of the priority queue.

Output Formats

  • Observable flips output: predictions of logical errors.
  • DEM usage frequency output: if --dem-out is specified, outputs estimated error frequencies.
  • Statistics output: includes number of shots, errors, low confidence shots, and processing time.

Python Interface

This repository contains the C++ implementation of the Tesseract quantum error correction decoder, along with a Python wrapper. The Python wrapper/interface exposes the decoding algorithms and helper utilities, allowing Python users to leverage this high-performance decoding algorithm.

The following example demonstrates how to create and use the Tesseract decoder using the Python interface.

import tesseract_decoder.tesseract as tesseract
import stim

# 1. Define a detector error model (DEM)
dem = stim.DetectorErrorModel("""
    error(0.1) D0 D1
    error(0.2) D1 D2 L0
    detector(0, 0, 0) D0
    detector(1, 0, 0) D1
    detector(2, 0, 0) D2
""")

# 2. Create the decoder configuration
config = tesseract.TesseractConfig(dem=dem, det_beam=50)

# 3. Configure and create a decoder instance
decoder = tesseract.TesseractDecoder(config)

# 4. Simulate detection events and decode it
detections = [1, 2]
flipped_observables = decoder.decode(detections)

print(f"Detections: {detections}")
print(f"Flipped observables: {flipped_observables}")

For full documentation and detailed examples of the Python interface, please refer to the docs.

Help

We are committed to providing a friendly, safe, and welcoming environment for all. Please read and respect our Code of Conduct.

Citation

When publishing articles or otherwise writing about Tesseract Decoder, please cite the following:

@misc{beni2025tesseractdecoder,
    title={Tesseract: A Search-Based Decoder for Quantum Error Correction},
    author = {Aghababaie Beni, Laleh and Higgott, Oscar and Shutty, Noah},
    year={2025},
    eprint={2503.10988},
    archivePrefix={arXiv},
    primaryClass={quant-ph},
    doi = {10.48550/arXiv.2503.10988},
    url={https://arxiv.org/abs/2503.10988},
}

Contact

For any questions or concerns not addressed here, please email tesseract-decoder-dev@google.com.

Disclaimer

Tesseract Decoder is not an officially supported Google product. This project is not eligible for the Google Open Source Software Vulnerability Rewards Program.

Copyright 2025 Google LLC.

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 Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

tesseract_decoder-0.1.1.dev20250808040006-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl (3.4 MB view details)

Uploaded Python 3.12manylinux: glibc 2.39+ x86-64

tesseract_decoder-0.1.1.dev20250808040006-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl (3.5 MB view details)

Uploaded Python 3.12manylinux: glibc 2.35+ x86-64

tesseract_decoder-0.1.1.dev20250808040006-py312-none-macosx_11_0_arm64.whl (3.0 MB view details)

Uploaded Python 3.12macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250808040006-py312-none-macosx_10_13_x86_64.whl (3.0 MB view details)

Uploaded Python 3.12macOS 10.13+ x86-64

tesseract_decoder-0.1.1.dev20250808040006-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl (3.4 MB view details)

Uploaded Python 3.11manylinux: glibc 2.39+ x86-64

tesseract_decoder-0.1.1.dev20250808040006-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl (3.5 MB view details)

Uploaded Python 3.11manylinux: glibc 2.35+ x86-64

tesseract_decoder-0.1.1.dev20250808040006-py311-none-macosx_11_0_arm64.whl (3.0 MB view details)

Uploaded Python 3.11macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250808040006-py311-none-macosx_10_13_x86_64.whl (3.0 MB view details)

Uploaded Python 3.11macOS 10.13+ x86-64

tesseract_decoder-0.1.1.dev20250808040006-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl (3.4 MB view details)

Uploaded Python 3.10manylinux: glibc 2.39+ x86-64

tesseract_decoder-0.1.1.dev20250808040006-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl (3.5 MB view details)

Uploaded Python 3.10manylinux: glibc 2.35+ x86-64

tesseract_decoder-0.1.1.dev20250808040006-py310-none-macosx_11_0_arm64.whl (3.0 MB view details)

Uploaded Python 3.10macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250808040006-py310-none-macosx_10_13_x86_64.whl (3.0 MB view details)

Uploaded Python 3.10macOS 10.13+ x86-64

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 d6449a76864d306811ee62c0287bf93911165207107b0ab64adad499f993aa24
MD5 c85eba8cfa51ba0a32caf995a4de1dd9
BLAKE2b-256 f7f6e47afa6e93b8d2cc80562e6bdbb7dc14e9a36d96baa82b30ad52825dc5b9

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 a96a9e9fbec5e770a1d16987b6b67826e6d36751d6a64e5de1fbf7610af361ba
MD5 6a6ccfe17241842b8f11f890c66598b9
BLAKE2b-256 a1c4ec6ebc4af8bd779eb55ae398f22a19655c26d69db2d74842ce5f4c2e6750

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py312-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 38f3d28970f7b27f73d3e42da8d666d4f033c56c0d126bfba5704bbf42693275
MD5 fcc28be49dc9cbf10846e8d955993e0a
BLAKE2b-256 14d0799801778e00cc6e6a42d67bc888f328126b6ecfd156db6727a08bcfd9db

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py312-none-macosx_10_13_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 60c301c0e19aa97efe55118fabc00dfb27ee53f9f6cfa689fc2384222ac5b17b
MD5 ceb4998f47213a12602ce18f902e5142
BLAKE2b-256 347c55d8331e4dc6a27703b7114bfc77e8f3bb5732fcb1a430a8d28d8831245c

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 65cd0eee2037ba79028de949d7a57e175e54619c0eaf101867520e9849d9e3a9
MD5 72862a91c2865693915f0c4401a52330
BLAKE2b-256 530e8bc530f852bbcfc5eaf2ad47b1884d717533238d1728c34dab41c62d3396

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 b0d48186fd757a04815553dbc6dad8223cf062331ebd002cfcc331eb8ff09373
MD5 fc9f84720d9dbdf733595eba574cc7b3
BLAKE2b-256 9d820cc94f6d1b3c0f56c75a88eb34e235657b8df67db0ece3c142faefcde74d

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py311-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 c72e76a80f30a0e47cd25cdd44b71d9dbe2d89190a16922f2287364e9552eb4e
MD5 2d2fc18a1f2df0259c9860fa46c4b7f2
BLAKE2b-256 a01830be7faa0dbec0ea2327ed2d4b5e83a355aa338cdaa0249fdbea6136e318

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py311-none-macosx_10_13_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 e78745cf29396cbdf642984b7e2e7f6034f2b6cce6bd21b5f2309c054db45b0f
MD5 0649c8da3821f20813c09707c61d7c30
BLAKE2b-256 a8d9d4648c5ea87165a8a6e5d5b2bfa47ea232d621a027dd5718fce21bb0c74d

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 75b6501c506afb8d49b5a0bca9593afecc44ed71a0c81fab679d047dbffb70b0
MD5 24b9307c8f7702d071a2ec7b392e59f5
BLAKE2b-256 e44c091be3617e9b4402ea6835a686168057f18e77fc5c22f3f53cd0567e0fba

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 4fbf0f36e2d21eff6b3794e84f97de72a368d9ff35344020a136023dcde5b038
MD5 865b0ca958a1c159922ce63080c898fb
BLAKE2b-256 126d6f28351700b64ea57da0af2974c2268b3401804177624e7a1415ad9f4d3d

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py310-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 6afb6d5bdf9407506009167baf689136e0f14d435c89580dd540cf56fde2adfd
MD5 a1ab6561b1cbfb078e1809ce8dfff9d6
BLAKE2b-256 8f5786667d9249664c795901ac4481895e76658b888da49aea3f0035746f244a

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250808040006-py310-none-macosx_10_13_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808040006-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 4dd073ea2b52d58a78f772dd7a4a3db38374b4f478070093e452c17c7eb4a6c8
MD5 b6f725cd8796ddd7fc921ea9e0d7201f
BLAKE2b-256 e6a97543474423605253e45c80ddf293c2c1ee0e8fa3bb4c87916f2c9fb45e12

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