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

Uploaded Python 3.12macOS 11.0+ ARM64

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

Uploaded Python 3.11macOS 11.0+ ARM64

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

Uploaded Python 3.10macOS 11.0+ ARM64

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 1b2183d696e9869f5acc618c7ef30b4f50e08dddfc1fa04a62411c3b31aaa5d2
MD5 0972158265f61fb9e02b1a5883bb499c
BLAKE2b-256 a59429e9e0f886e428d151ec4468038fdac234ccca46eefd525491f676f794e1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 817ebe681a71cad37273bd5325ae387bc8aa3351f80fbc9b9ccaaab68692625e
MD5 7d33f37ef0c78b7126c60690cdf672e9
BLAKE2b-256 29614c29f77f5451b5fc5b95aed6091daa7a98a1f57b0131bc145eb1a2c10665

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 acbe72af54923a59644172c758fa845602d79739418af496f83d4cc72a8d5fca
MD5 badc673b5f702d73519323f565e31104
BLAKE2b-256 20b81d8bfed1bbd4ed587fc5a996a7e365edb812e26c276b22e4cb98b11c1f65

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 3d6f63373610cc0f73c0c27b92104169068f1a079817865c8472b96101b1414e
MD5 78f868e9d2e8dc5dcb07b0d7a225e208
BLAKE2b-256 46afb12c24096d748e5b6a9272ec70bbc20022ed5fd15159f59e03b8fe5689d6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 2d5f0bcfb7857917d96f9aa780ce5b192b6576ded5d212a73f35fa97dc2d66f8
MD5 5704e54157dd367b6e7f5ff89502dca5
BLAKE2b-256 a10411fdd7a3a27654088b84483cf22c77b2f288ef1755f1a84286ab72b562c9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 0bd2cdd07813d2e30b4bab85aaad79bf248674d49e6dfe050a910d1a8f865047
MD5 bbd73f2d402e324ef616ce7465c2efff
BLAKE2b-256 d692c7253b765807b15524d38d8af43a7c87ebbd4d223398e879db6be8a41c8c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 17de3c797c6ac12fca0c4d045348be78f28139e4645e408bdfcd5a756635f945
MD5 50af3c337808116c605c39315ee6fcc2
BLAKE2b-256 b06eec6a57beb7b4fbce373e021f0b8e7af8ad50eb5ab749df1a5616fcfa221d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 56198cf09d5532a3d4d1194a2cf4cab283cc849aad5795d85900e8638f54fa4d
MD5 570d4eb1e2728ebe1e9b553d267da2a2
BLAKE2b-256 c4ea35091c20225ca0d68da7b57178ccae084881b578386452d0827185c0f7f1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 ce2898589e9bce63c60c4e2b4130359310ae3a3d1de73e971535d7dc655cb88b
MD5 d4ea1ec5a0b1f1c37e60fe21bb755a03
BLAKE2b-256 4adfd2550313314965c7b5f0b68367279b3ba984982c73e0d1c6a51620cd98f2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 50c47bb2cb5d61ee50a790dd929fd731e3dac5be8cd665c1411aeccc8ff208a2
MD5 f7f1293f8ad40291fba2716c215515b0
BLAKE2b-256 d85cb1b5c4da9adfab2982669db621bbd9adc70e82f69d4d699de477f9a08c30

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 67e7c891eaf855e60a31a2f2e3e0fdd677a9c4d291b06c2737882ec6f741b50e
MD5 90e210986b0df626e1c3a9954b898e69
BLAKE2b-256 31c434ed0418d8bb286aebbbd8c6cc996c7546c3599234219766bd3ed7300173

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250813231523-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 71e46830e738f1d5e3cb99777ef2f4405d037609d9f59bb40f5d272a81dc9f5b
MD5 855192c3079936545e4c80c34f8ce6d7
BLAKE2b-256 e3be620d07f4c91d30831c75ac6aa2640e89bb1ab7f75978656e52abaf87eed9

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