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++

InstallationUsagePython InterfacePaperHelpCitationContact

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

Full Python wrapper documentation

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}")

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.dev20250809152744-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.dev20250809152744-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.dev20250809152744-py312-none-macosx_11_0_arm64.whl (3.1 MB view details)

Uploaded Python 3.12macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250809152744-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.dev20250809152744-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.dev20250809152744-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.dev20250809152744-py311-none-macosx_11_0_arm64.whl (3.1 MB view details)

Uploaded Python 3.11macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250809152744-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.dev20250809152744-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.dev20250809152744-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.dev20250809152744-py310-none-macosx_11_0_arm64.whl (3.1 MB view details)

Uploaded Python 3.10macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250809152744-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.dev20250809152744-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 e6960300d6c80169333805655ad0d5b49edbdc2bc6f861524dc9cca1cd80fe64
MD5 f73cf8c084a2ce46decd0b9647028a12
BLAKE2b-256 de624606cbd5643babc93eab3d38ee5f0e9d157f352d0f4619e6956d6fa9a4f3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 d642b399fa62534749831a2b66471b54ce04d55616831795b63a2484ce36b37a
MD5 374f329897f79b58a1afc8a39514f823
BLAKE2b-256 79cb7dd4fea35733d32989df4024c07e0490d8429f576621e249096fc4f2655b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 b36d368516eab4bf6102bd559e33f0d62efb6a51a43b410389c771ea171c3bd0
MD5 34afa2c4b77e03f16a45d6909a0d9faa
BLAKE2b-256 cefcfa73f08417ceca27868fb7d6b3181774e44a2a9e445e72d4fe674914a69b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 c8f308857c716b09a93701af6fa24b318963a8bc58090766a4af3351c4677edf
MD5 0030d0547e25111ff35393c5be3766f2
BLAKE2b-256 97fa4a804a41db5d9a53c0e155d1e2e8bd06999abccf2061b03a1c8c813b4ccf

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 4179c4a2a072d73a91796c51203c80afe20737ae287c3ab7231a56c2c139340f
MD5 f3af088614adb0bec3d66f79e0c47985
BLAKE2b-256 b3022587d2393db1086ddc8f6a98a0f1d38bf92a57005d642d3753e94370f2af

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 9d75583381b5638b4f028a4f883213a43035c45cdaafd4056e008ac284fb676a
MD5 efe061b4d81009363ac85c0567cee8f6
BLAKE2b-256 0a4487e47c03e3c2315f46fd53bbdb060883d341429d1407a9dea77e9f66f677

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 fefb6873d41c9e6e7e65d8cd336f30e357007b94c7a057e0e6845b2ad9c46f06
MD5 efcae531941ce75738da16d793b970d1
BLAKE2b-256 3270b3b74a5e3bed39fecf3f3deeb92af23e89e2052587aeb4170101dcb38531

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 2a2ef78e57152f6e4aa068eaf9ed4cfac065f514452de6f1a93ce6d20c90b65f
MD5 11c21bb58ecba7a3c30b90118ab9ad24
BLAKE2b-256 5eb8ef5a169ce5246fb19e32768fd623d2f32a68531c345bd66daae9e40547ba

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 6e08f3f5f8ff03540ba01771c6c7eac45d5e5125636a6e784634d30e1c5c7a1d
MD5 0807f83a76a4e6a4ca0e47236c813bab
BLAKE2b-256 61ae708b705a9dcf6b86e0411934f4ddd9fc138ccf65729a0a0ab72b49700299

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 414e8a10057e287f5cb30c33be44288870750cbecede7e4c34e2f7c1e4ad569c
MD5 4be370d680d0f54f05b259c0770c3904
BLAKE2b-256 32f6ee29aff54fce57991af9aec01fd89a36339921bac30b69e6a3af9f167f84

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 af6a4a7123756dc1f26c9cd7e2ecda164c463ca9766ddaed6417bd775d893834
MD5 98f006a52c7b26d2732bf546d3bda13b
BLAKE2b-256 0aa241a0b754c15f006a9ab813aaf71e85066dc4a46466b08862ce6c95c39f14

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250809152744-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 f0d29d5593e4b03840c2f969effe83329d047fbebf7d3161722b79b8e42d1678
MD5 2a14954415f7920be7ecf0b716dd6b5a
BLAKE2b-256 f20344aefc9ccb55161dee9e1d5d3fbe265a016b3e3de18ae5aead41d7bb8b3e

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