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

Uploaded Python 3.12macOS 11.0+ ARM64

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

Uploaded Python 3.11macOS 11.0+ ARM64

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

Uploaded Python 3.10macOS 11.0+ ARM64

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 520f0d8c23873468270139df6883090aba0a382728ff5ae212548121a2f4b709
MD5 94e683b442aaa2dcaeafade96a04cdf3
BLAKE2b-256 60693adaf076992f96741f47a23f7b6a154f2b83a38add8389fcaa1e5b63e4b8

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 0eab3a9696cd58b2bc09c742c008ffd02a64ac2131c2a54c0499f6e951fe5542
MD5 2f2700319dcb507c51994d10e1e130cc
BLAKE2b-256 7422168d724cda2742890caacd22c8a2b76d8e9193faff967c2b0bd5597fb5b5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 eebd1aa77702759c45a7264ecbda4b53f012bdb9ef84cb177096118d6b248dec
MD5 cabb14b5686d8ae0453734f58605c27c
BLAKE2b-256 99a59640cbb29a1d85dc74dedf145235ba78a94140ab9c079ae9e60d6093ebe8

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 b777efa985496b9240bee67622e77fe52b77a4829c6c738478124a702d86ea7c
MD5 165b483bfde8379b6e1cd1d9275556c4
BLAKE2b-256 388a805e83ad862afd840e3765567c69317944d2dddbd590a8cda25dc1fe3d3f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 3f1b60aa7a272e8b462919c6c2e304ec384a4f1241ade90035dfd0199fca25ef
MD5 25aa6fad49de1c556a4ed8a1abbfee37
BLAKE2b-256 9ad8fc6e6ac81254638316e20f2032d63d6871b4ebc996076ce47e29835be3e5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 73b8f8ef140a781c6cd02951f4c1e22ab1410f057bc7de2ab8a3c2f1d0194f8e
MD5 0aa001b510e349f9281e20d8e1b055f9
BLAKE2b-256 7e83ef32ade123a9a98f5af8bbf0965dd7c56650f4e5f1b0f8299c2ccb54113a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 f4f1759bb45f3987846a4ab593edca442fb540fe8b64be32b823e8d2e8ee9cb9
MD5 88981a07bea0b1d66b1f3f34c50a1dbf
BLAKE2b-256 f0495e98c37d23f54a23b71534d8accc1a134b71f45b1ba468bb7eb79fec7cb3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 730be0b65469d6966d76dfb7212c3d16c257372cf49e0a7a073d567e89978986
MD5 692a4b440e57c0a19190ab2d6c28cdae
BLAKE2b-256 1c13ca5df17ebd9588bda4784a96611ac416c7934bd38d1f469b8171af8ebbec

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 739a38910dbf0720952764c209d9537459f5f89fb051c743a42f4c487bde4402
MD5 a75ab9c2e3c48be7b6e3a3d555c8476e
BLAKE2b-256 d9a49edecb799338eb4a27d7d0690ecc8db3de336f3ddbf235a638ae08b9b97d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 eb2186898ea85eadaafa732bbd4e35e2e94e9090e0dc2b1f937cfc5ab4d170bb
MD5 b20659ba372c10c4d5026967dbfd5870
BLAKE2b-256 34aa3d130a5b557b8c361b170e94749efdff53dbc94f238c3283a56b36f84151

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 0d17df47bd52da1d962e2b597705a1a8380f7546e08694fba84ac7847a4417c3
MD5 44d5bd76118c668be5eb95d934a68b30
BLAKE2b-256 095fcaa08d839f37e2b5503b692d7ee43567357a2098cd27a28be678c35a9970

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250814210317-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 4741299b5c36d35dbf30d981935726fe4df0de50c43bd314ae28dcaf31159686
MD5 f5589af4ecd1d1c5e4ec85fd6fdc0d1a
BLAKE2b-256 d980d29f1b2852fdd2b9a9eeee64e4d2f87fcc56d583c20dea5748c365ab2ba8

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