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.

For installation:

pip install tesseract-decoder

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

from tesseract_decoder import tesseract
import stim
import numpy as np


# 1. Define a detector error model (DEM)
dem = stim.DetectorErrorModel("""
    error(0.1) D0 D1 L0
    error(0.2) D1 D2 L1
    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. Create a decoder instance
decoder = config.compile_decoder()

# 4. Simulate detector outcomes
syndrome = np.array([0, 1, 1], dtype=bool)

# 5a. Decode to observables
flipped_observables = decoder.decode(syndrome)
print(f"Flipped observables: {flipped_observables}")

# 5b. Alternatively, decode to errors
decoder.decode_to_errors(syndrome)
predicted_errors = decoder.predicted_errors_buffer
# Indices of predicted errors
print(f"Predicted errors indices: {predicted_errors}")
# Print properties of predicted errors
for i in predicted_errors:
    print(f"    {i}: {decoder.errors[i]}")

Good Starting Points for Tesseract Configurations:

The Tesseract paper recommends two setup for starting your exploration with tesseract:

(1) Long-beam setup:

tesseract_config = tesseract.TesseractConfig(
    dem=dem,
    pqlimit=1_000_000,
    det_beam=20,
    beam_climbing=True,
    num_det_orders=21,
    det_order=tesseract_decoder.utils.DetOrder.DetIndex,
    no_revisit_dets=True,
)

(2) Short-beam setup:

tesseract_config = tesseract.TesseractConfig(
    dem=dem,
    pqlimit=200_000,
    det_beam=15,
    beam_climbing=True,
    num_det_orders=16,
    det_order=tesseract_decoder.utils.DetOrder.DetIndex,
    no_revisit_dets=True,
)

For det_order, you can use two other options of DetIndex and DetCoordinate as well. These values balance decoding speed and accuracy across the benchmarks reported in the paper and can be adjusted for specific use cases.

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.dev20250927191441-py313-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl (3.5 MB view details)

Uploaded Python 3.13manylinux: glibc 2.39+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py313-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl (3.6 MB view details)

Uploaded Python 3.13manylinux: glibc 2.35+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py313-none-macosx_11_0_arm64.whl (3.1 MB view details)

Uploaded Python 3.13macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250927191441-py313-none-macosx_10_13_x86_64.whl (3.1 MB view details)

Uploaded Python 3.13macOS 10.13+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl (3.5 MB view details)

Uploaded Python 3.12manylinux: glibc 2.39+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl (3.6 MB view details)

Uploaded Python 3.12manylinux: glibc 2.35+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py312-none-macosx_11_0_arm64.whl (3.1 MB view details)

Uploaded Python 3.12macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250927191441-py312-none-macosx_10_13_x86_64.whl (3.1 MB view details)

Uploaded Python 3.12macOS 10.13+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl (3.5 MB view details)

Uploaded Python 3.11manylinux: glibc 2.39+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl (3.6 MB view details)

Uploaded Python 3.11manylinux: glibc 2.35+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py311-none-macosx_11_0_arm64.whl (3.2 MB view details)

Uploaded Python 3.11macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250927191441-py311-none-macosx_10_13_x86_64.whl (3.1 MB view details)

Uploaded Python 3.11macOS 10.13+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl (3.5 MB view details)

Uploaded Python 3.10manylinux: glibc 2.39+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl (3.6 MB view details)

Uploaded Python 3.10manylinux: glibc 2.35+ x86-64

tesseract_decoder-0.1.1.dev20250927191441-py310-none-macosx_11_0_arm64.whl (3.2 MB view details)

Uploaded Python 3.10macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250927191441-py310-none-macosx_10_13_x86_64.whl (3.1 MB view details)

Uploaded Python 3.10macOS 10.13+ x86-64

File details

Details for the file tesseract_decoder-0.1.1.dev20250927191441-py313-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py313-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 64fe1ad673d9cf267185b3eb2ee731149538205496554a8a88ca5a792b749e62
MD5 f19cdb3f79a3c3b105e12f8bd5fe6098
BLAKE2b-256 930ce7f3904a49a0fb13e1b15bd6985d30f3180ad3d9e2b6a636cb375afed7f1

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250927191441-py313-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py313-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 17afe7dc7a463349de4032cf3140820346bd78f5f8fe67a2b141e6754e6a6cb4
MD5 e44b5b4c52a515f987e28f127d2f4865
BLAKE2b-256 5fd15e727132d230e66260179ff97ca41b491d52f743ca155e3d59c8527cdb96

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250927191441-py313-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py313-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 ba4ab541a2d1fb9d5e2996dedf1b6133162c4a16d6eff3f46a45147d51c71f26
MD5 fa261dc28eab9eff4ddf7ff322731a4f
BLAKE2b-256 fa4b9117924094c4ded8d486bd9f9353a107574953bf03447805de5020067189

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250927191441-py313-none-macosx_10_13_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py313-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 9e483a4347ac7fdb09a1a8fadd85a1112da4c72865154e6d89b0b110716452da
MD5 b5b3be970d43c1b90d7351d59fc12a64
BLAKE2b-256 8310f6f83429614fa888a848fa04bfdfd483e8b00cacba9194ba0865354d2d89

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 c1157553c4ada79f443bb1744ffcb85ce42ca0bfb5f3b0b33d569385f48ae9b4
MD5 927a00285282f74cac8f2143565faff2
BLAKE2b-256 f252e7494632ef51a4b17d957c9f8da38b859ac42e5638e8f79aea6be1937af6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 4514964d47c2e1b360e6d91c132d5fd2513e470a4d119f4c406e15902244969b
MD5 5b8a67b16d169102642da89b551cfcf8
BLAKE2b-256 0a39571b86a72f4070bf75820ccebc77823f2a925726897f364595f62d0d8253

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 74e957e8492366d9efd3d0c8c76240bcbe60ee2026de8da9705841194c12b622
MD5 d00b5aa28b204afceeb0454a86db315d
BLAKE2b-256 90116f8f61365cff4056eb6c61b7e4ebded12becd0d41e776adac16ea7cacc02

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 436988034321e4ea17fdc543133ff3fee0ef3ddd77cd00cbecf02d1f9ccd6406
MD5 8dddbaad113dc195205bb84d1a3dabb6
BLAKE2b-256 78a7b03f0395ec2aef110967a72d11abc75d7282b370cab302a8d541c762b8bb

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 701263a6c59c1e6641374924dc8149d0e2dad75ac29fad3d74d736900396bfed
MD5 5d1a456d79a77a42aded3d8640d9a45e
BLAKE2b-256 eab199da835c938de5285e50b1abd5b17686c3b33c89aece405d04e347671757

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 455a19db1a6d08debebbdb9789821cada14cc5df3e784a5ace845b0da621381c
MD5 aad366e9854df4ae6f6c4bad8dbb38a1
BLAKE2b-256 fbdf9d958b235157733a415d11ba1ae8186f78a59299a9066273cd17450331be

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 08f7ff5122a9893643fe498172baaee7e4590189d0a97ba2e9ad15af8f0e50f2
MD5 e167bd7ea07ab5e9ab69bece71933401
BLAKE2b-256 ba109b405e8f6c0edff94e0821b8ca25976d1af0f4c575e5cb4bcda71e768d77

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 6b9330ab595a03664ee934813ecf49c2b3868058bb16d5a9e076c9b8fb4c9567
MD5 03014b285f8bc75ad395ff94bcda108d
BLAKE2b-256 08ed272efaa6adcf6835595ea6c74fb69fa5a9e2a75adef793453f9adfad637f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 3616a571c8de44b890d378000cd6d3929668b60b642fb36845730f705126421f
MD5 39d4d6a6ea1fd15bd260473dce82564c
BLAKE2b-256 385fe29d9fe608abd98114878f4c044a52444f221680618a665228ec5cce6a4c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 27fd261cd5a2402aae3a3da75a16c5b472f133c8253703c4144444d0fff174fc
MD5 d54eae84ecc3097286ad2e3cfa676204
BLAKE2b-256 6813f5eb702928cbbdc416a9fb6d921eae7de2708cecee5daab2ddee7bb21f8f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 84d5d36a43904fc245634289354b52f8b21f79a37caf8b7ed0c6de8e13eed384
MD5 e54d5c6007421d3122c23a6c56c9578f
BLAKE2b-256 e0fc23a697d6caf0d3735d66e7ced0148ef446a7fadd5a5b968562350f8de6d6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250927191441-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 11aec9a1d4d6ca801b31711cc36acb98144db594cf0881d96d122b8bf5202fce
MD5 069348efffcb3fe7afc876d8e47b41e7
BLAKE2b-256 8abef955ed38b7588234d8b25a7ebe730d3493115aadaba81514a8969ce53fb1

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