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.

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 detection events
syndrome = [0, 1, 1]

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

# 5b. Alternatively, decode to errors
decoder.decode_to_errors(np.where(syndrome)[0])
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]}")

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

Uploaded Python 3.12macOS 11.0+ ARM64

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

Uploaded Python 3.11macOS 11.0+ ARM64

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

Uploaded Python 3.10macOS 11.0+ ARM64

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 e9b1c9151c4c215f241b4789d6f0e5a2ca074bc30eb02a27e112fab4e877f59a
MD5 a92f28816d6c5808664239cb8f7f9c68
BLAKE2b-256 bfa22bdabe5a56a2c5abdbd04ca4acb35f5a5bcea3319ce20fde527662fd8db9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 6dea3756de73e336e256f858a88ece9bcbe36a68bf78e2d5e0e5b7e1d5b90d99
MD5 857a4e82735a5d7d3c5607b7430b1b9a
BLAKE2b-256 140f41a7864302a333f5dfb9a344d15c363813ec8ee138fbfab89b99c23076a0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 113896f840a68398973b81c7a24633232b571e6ebc20fdbbf752939232fa9c09
MD5 5297ca3bd65a6b1029fae2f394630bac
BLAKE2b-256 ca36adbc016cd10bdf84c62e4a067e792f5f9c033f2ffe6d4a499ec67ec84517

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 83fa15165e044bffb48b1e05c6723cee118344845c776a98adc687a0f637f906
MD5 719cc5c72e6cdee85b78a1e74103a858
BLAKE2b-256 02d1f9b9c2b2b7e8dd52cc88b744e2d1170edde6edcfed07b959999180df02b3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 2ffa5b3d4a2d57ddea26a269518021414a5e06ad5a345e8a19e8b148397959de
MD5 89b680c451d11be3ceb86fdcf36126b5
BLAKE2b-256 0f116c56c2e080a3f8d314d4256789cb77a306e0e4a60bdc4b00a7987b2611da

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 649963d317b8d7d2f437212c2109cae38ac01742c318fe7e6169f9426de4a2f4
MD5 357d27c475c69bf55278e5fb5b6ee2d1
BLAKE2b-256 014a6e0dd36ba245311cf7c5fb191c566b4e37e3c8daf9c1f5ce62cfe104f470

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 ca55caaa8bd6379f95b24864669989a78774529819cd688f9261da0fdd69debb
MD5 6bb1cabd3d3849b0364c546657098e8c
BLAKE2b-256 393a3ca54aa901f88c9d071ea9453ed34619c1c46d8830b37df2f44b5cd3234f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 ee802d94450dd170043492c6347c436fc19eb785253a8b5246e53e0ea7678be6
MD5 c7b9c43ed58afa872c5e6f2c8a7958d4
BLAKE2b-256 a2ecc844bad5fdbd5ce79f48499301a82c073ddbdbcf8157316afed2f216b271

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 825aeac4369fc8ee857cf3578903141efe7f9dfbd60ddbc31a5abe4ad61dbc57
MD5 0f4183cd6874bf03cd1ff8116b30bfa6
BLAKE2b-256 3736a667522d490d93710829f321288220325df6d63cc0eef2daf431c5d1ca90

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 7e4b540424777b3508b424e3e2d7609dc7e8ee40cbd3faf7054f92fa577ac3f3
MD5 bcfbc65b184b6fa3e128f75ba612027e
BLAKE2b-256 873e2a1af73136b104db24cfdd84bc519bb185dc2d104475c435ed8434264ab0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 c9eae8dcfd37c35b7335db2b3e69288f09cbdf2ddb826e97c305ae4dbcbbae62
MD5 1be9a28d78d07c90ac4b4169d44fb600
BLAKE2b-256 b574a06d656fd3744c8ca3d58e5c07c3e8d1b2b096d349b874e5cdcdb88787c2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250819194213-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 f8eedf44feb405be64db2d71f76811b3657f158d7beb1fde439643938c49d48e
MD5 045dc89b4bf5ee7c40518a89d2a084aa
BLAKE2b-256 c16656cce2d3d9d3964e19b0ea5112762e85cad9217633c83a8eeeb9d5f97830

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