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

Uploaded Python 3.12macOS 11.0+ ARM64

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

Uploaded Python 3.11macOS 11.0+ ARM64

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

Uploaded Python 3.10macOS 11.0+ ARM64

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 10d5ddea77a7a08d06ab2851cde48c2ebbcec75c94c1f0bdbccbef013991da45
MD5 28fd178c357faf8f13f85e95181aa40d
BLAKE2b-256 54a90be588aaf5422e659d6158a3c75fff6dfd5fe4714e397ef46da9f4ae3459

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 510698f5a8c732260660abc87e4c0e362010f036d7ae58dbfd86af883d8ff4cb
MD5 21b33041000ea4874c61888d9e443711
BLAKE2b-256 c12472a0c0c5e5fbc72ada0f92831e95878e7877f8718eb7bfbe621e6622193c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 86279909561f7a4bafc9c57d4c62021bc2c97c677d9476cc2242485416ffda95
MD5 82411f6a424900934652f8c3af017706
BLAKE2b-256 61a5f62b90f145f56c9d045ff185b9b72685386e15c60d2084ae7ff308223c72

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 ddf360555bc449c960d717564a3494fe4dc5ab1b09534457b91d5a5121da9e64
MD5 5f45999ec3ef1717cbd53a02ed35293b
BLAKE2b-256 80f1c8d21aeb48a4cb5e6ce420b84f9b13413eb497431df46baf9ee7b3fa4db3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 9ccac087142b3ed0cef24028fabda8be276866624e773eb1f394d605a481cff5
MD5 c6f6eba7b1badc6c6fb2c661321f0406
BLAKE2b-256 86b53feeca4770951d415aa5af49e5f323d6909ad27b3814c05b9bee8d6f4b40

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 fca0f4dab250ee2930aa5e138d383d138f3842b2132037de049d0def16960f89
MD5 29b591b0b0bbf430017b2b118afe9d4d
BLAKE2b-256 18a3acf00f6cf5f8072530a3f927c0aa48c800bdb0630b5a9aac7905d4257a0f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 bb7f21808a611cdcc3a7038d4b4372ef74983c0e358ff3966b7530c3d079a00f
MD5 b0b0cec7b5e897127ea234cad5ac80d8
BLAKE2b-256 520881207094b9286adb76a4542748092eeb48e2db00fe5c2b9fbf1bb23904af

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 b8eefe96283ca12430c2c5d02c04851fcce564dac81352b6c4913634286a2bb3
MD5 a8be30eade103cf51b239ca79a2b97e7
BLAKE2b-256 22b6405bb8dd57a8b484465d4c56c316b96054a0eb73bfd2edc7ef125137c1cc

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 d53a3bc79fa80a7fad191990d28e2da877ab4099b0080ef7eac485981e689c97
MD5 9190a9f8aa173976185b3cb6c17daa8e
BLAKE2b-256 cfb58dd3358a16612ed121bee75a2f84c0f12ff3fee5c4be8ece0a3e0b7a6058

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 21ebb9b89ae0357c589615b9eb9ff6d7ae2a722e8e4256cea682c2501f30504e
MD5 08f38a216049d3b9794ae75b819f3354
BLAKE2b-256 3f738440fcdae7b0728b47216ae342b5b5675e6c08c7cced171ad8749168a8b7

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 ce307beac158003a6b5e135e02cb6ff34f2ea6cf1f0e255ae7b972e64022ebf9
MD5 820709e42cb4de0c18b626f1e43b4f95
BLAKE2b-256 c8f2c42a40ddc3fe47f6e6e9515c78a666b7f2070edc23a20447253b5b3f50d7

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250812191432-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 a2d8612bb9f3c7bba3ee5423347537670c21a188be83062e10b6f34e3744cd64
MD5 025ddbce741e4ecbe6d3e0c75e51735e
BLAKE2b-256 6dd3cff5b205786aca8e0e19cd8331b3c6128482b8da80be89497f470854d642

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