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

Uploaded Python 3.12macOS 11.0+ ARM64

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

Uploaded Python 3.11macOS 11.0+ ARM64

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

Uploaded Python 3.10macOS 11.0+ ARM64

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 f6e5646b8addc190743a7c948396fa32328db4b91743bb56a23645f2f79b024e
MD5 40fcdbc8dcf8336fd33f8ef2de622e49
BLAKE2b-256 ead4720df4122ca7a019f80bf33ae5a945e14048ca78e94085cde8e4fe83799c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 51c12fef9bba5e2eab9568a735a15173f6b90b80718b9c64707f1f030083e1c8
MD5 665e39b32a341d5b3979bf2add990e24
BLAKE2b-256 16a6a9d7e09058d5d0a655450071f2c4f099c0b97e89d654610287e8cc033540

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 2b5666276567a6ce246689c07b3a4f7bb9d14468944c9c1c21281b9bdb808192
MD5 207ace3d9ec2b27f37af6c196fdb277c
BLAKE2b-256 83ef8d53eac577d040ac863a7d92525b3ca01473d1f3581b46eeac3f9a67a685

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 96d1ba375333e87ebfb77cd59a86358d981f6fddf563e37ed8690e12187c6d5b
MD5 0f7e8b6a0450dd0b18396a2b28dda3fd
BLAKE2b-256 53cbcb20899a897a5b19f313f3ce6cb071b05c3447bea7595d9798328d13e6a9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 8a092597e8e9a25c1ea2b4b93e28ba006269f942aaff35b0aa89488076932b41
MD5 894b04e6c6b3f3fa0692f782e39185ab
BLAKE2b-256 25f744496319b7203707b9562288679e548a06b08635aebae8e750d87f00e285

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 834b74d4234673628e7445b344b823d7f543ed8a5c17d39daeaf9e157022a3ea
MD5 ff18aac9cc87cea5e22c157cd75e3f3c
BLAKE2b-256 d219d64ecb7348dcd70c748306205593c6d1a7951f1b87602c5425986e1f6a64

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 e47428ff4d9555dfd2f5b52ba73855c5cac1a474b579ae2e0c3f6fa90d05554f
MD5 7e8d68c2972c82b47cbb84bbad2224a4
BLAKE2b-256 daedc99d5b40c9200000414d27db92feea3717a8884645780416726cf17327c2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 00bf1480a1bbe988f3516ce5bdfdf3f26e473e8f6ebda7acf7bf0c52b97ddc77
MD5 007acfba2f717f378571fa975863eeab
BLAKE2b-256 005f43dd4c15402bfc6141e94a4ad657edfbc4dbb256fe9b14e20da4981a488e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 bc2a90e13d1923c213c3124eb8fb8928a56d78c7ff88845775a64a503e2511ba
MD5 4e0a315eb60aa075b4edfa71c51c4531
BLAKE2b-256 0a52d5a502d410c3550c570e0a5f238ae23ccaf3994e6ba585c9067e601c3803

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 a0ad79b7c5de0a19628a2d579b18ae4daf941b079a55e13e2b8289e9c7c72e9d
MD5 e574f435b99a070b8247e9d71ec453a4
BLAKE2b-256 794e4f40776039ef111521355f6f9ec5ed57d7e3f4653b5fb7de1c11c3c8c755

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 ec43a02a85c65c8dcb4034bf6ccf0cadaee1b363f20feacfc6dcbba8cb848b10
MD5 fdbe379153b7dbf6ad195d251f9d955d
BLAKE2b-256 bedb7026e9a2df7edfc4083789ab086290c36e5b67677601084a608ca0f9d8b4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812175719-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 9c7eadcf5c15645e8e2c368e11e2ee071d81477c48909c81d0f139267bfdf186
MD5 9750d0a91acaa2cadcb6d1eb0f334dd7
BLAKE2b-256 07fcdf28e9994e46ac72c32274c57282f53e8aed8e162e32ea4f5ebdef385600

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