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

Uploaded Python 3.13macOS 11.0+ ARM64

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

Uploaded Python 3.12macOS 11.0+ ARM64

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

Uploaded Python 3.11macOS 11.0+ ARM64

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

Uploaded Python 3.10macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250925181019-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.dev20250925181019-py313-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py313-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 328d1e542fc0f45cee2bfe368b91b3e48fa489946393093c8c7e38ae22549a7b
MD5 bd5c17ef5a6670c36ca88dc696cafea7
BLAKE2b-256 8a548a20056278ceeeac862aa695abbb907a3bfbc10d34067718188e71a47f6e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py313-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 28ade367517c30c4c1d60e99fbb80014ea2f0c2f4eea23dfd3efbd0b271bb710
MD5 5a0560c5daaecd0a783398c6eb4662e7
BLAKE2b-256 2d6a814308b6d1f22af78f567960bbddbf69a696028cf7d533a98a415bd1026a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py313-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 18fadb9b1e668879dfd93b284f06e641d2900eb722ec283e4e3db03fe22b71a0
MD5 a07c7fcd7e6b0eb70881e2087a1402e1
BLAKE2b-256 d1ff4237eaed18b4aa369a2bab21fb14acab0c8aad2e71fe2948233d62d0445a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py313-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 b1f5046aacd7f8b233ec42b14c63da87b60ebe4d80f0058732847b4bb939b265
MD5 af410bcfe3457ebe40cc4a87eb1ff879
BLAKE2b-256 657c340666dbdec8032d65419cb7d7ec4488b309b38b6b803b5f0ae6358dfbb8

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 fa92b5b5ed8f0a04c0ed8186cfad3de12aafacb37d97f8a429c7e0c18fad84f2
MD5 20cdef0f4a4274e84e4dc96fadd9bb2d
BLAKE2b-256 a1b750e87aa98be0f5315a20146d047850de378aca7a955aecac67c59cd88b3d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 20a5b2be74f3765b6e11f90e2b8a44cfb3c41bad1cdaef9a7f1afd56cc92f908
MD5 a7f3c9f4d1e548a00acd5b759ba05351
BLAKE2b-256 e77293ab20110bf4a12b931a462a6345bef618efe40951dd982bedf1c9296778

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 45a835a96e48e4369ca188f28997f14a08758f36f3cdbc31f06271364b48b63c
MD5 dbc66a535caf3616251d2a6745bf033f
BLAKE2b-256 2dc2a00769de9e10cbe07674be4ec548732d517432a10c1b65862dc7e707a0ad

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 57617d66f635da0677ab66d8d84996ad88f33d8faea4338a27c932a78b9adbe5
MD5 d5247bdba15eb8b785682b90b9b31a17
BLAKE2b-256 78c109f19aa07d67acaf8ac8ad4e0e2d58bf106630a76940b63f4c153b6a74c2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 e4cd889d6d5815b1f53df1544daf09df9d275fce206913f1c5611b0c796e90ae
MD5 e13562527da3ed7cba4dd3b0b999ff61
BLAKE2b-256 c5dd87a7c2468c8b540a47b8da01c51182afeeda64ee02fbdbda1f1a1eaae288

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 00c48df5a63d74329b5156f2270e6c88049148c229343bcd8c99e2183addac44
MD5 a84b77b68bbdd4dd6cc6c5294a6c567a
BLAKE2b-256 73e990885d841ec9a89743b019293a9ff4e23623fd8250390332fdcf5317005a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 619b97d5e7d724725190a0022968c411ab967d12e1e620386cba3d05724a5504
MD5 eee2ed9cf53db0060c693f86e2e113af
BLAKE2b-256 b32b4980c6799a07c010365e34ea4f4acc588c9124bfd23a63020767a018f57a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 40c7b5605400153232b878e2b4eb3d6b5b8c71d9cc3bf80de2245f942b5a4982
MD5 8b28bfb8369cdba6b7b1f385ab7f39f3
BLAKE2b-256 8303d8c2540317bc5e94d51f6b379908a7077f3275b8129613646d878f16179b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 13dad8fd4a038573ad01fb3d8ac2f30b9edf2937e6aaf80fbc71a0e32d911444
MD5 1f8a7ea2893cf677260b47fb16c5bff6
BLAKE2b-256 8726941c4fc0123af124f38a1896401d23c7a156408192eae2a8e94335bc42ec

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 b4d3fd5c429e32d2561da24aafa5f419a3efaa8b2438b2ead551cee2a171f6e0
MD5 cda2aec5634ff504f175895776fbe467
BLAKE2b-256 65e7a42d0112c0609dc1c4f70a3895d06258db020a36c7db21d0ce13db11fbb1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 bde28c65417a5408579b08c5dace22957b63d1d924615de10c3d6aa453dacb37
MD5 35a56cffd96ad48bfb75e8e95d1f276c
BLAKE2b-256 1e19b80d425dde3ae8ce32c642ba8163da3de3d08aed63b597b98a3ca6a4c7c3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250925181019-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 668fdf82920094e007781d586e0b77e51b082097fbebb3d3cc092a0a5dd57c2e
MD5 b8dd0bf7d7d7d1c1745dd1fba3d59ece
BLAKE2b-256 ecba09e70e80e808c52de068e43afdb0d050247740acb94a68022ae14d2afc01

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