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++

InstallationUsagePaperHelpCitationContact

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

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.

import tesseract_decoder.tesseract as tesseract
import stim

# 1. Define a detector error model (DEM)
dem = stim.DetectorErrorModel("""
    error(0.1) D0 D1
    error(0.2) D1 D2 L0
    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. Configure and create a decoder instance
decoder = tesseract.TesseractDecoder(config)

# 4. Simulate detection events and decode it
detections = [1, 2]
flipped_observables = decoder.decode(detections)

print(f"Detections: {detections}")
print(f"Flipped observables: {flipped_observables}")

For full documentation and detailed examples of the Python interface, please refer to the docs.

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 quantum-oss-maintainers@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.dev20250807185254-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.dev20250807185254-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl (3.4 MB view details)

Uploaded Python 3.12manylinux: glibc 2.35+ x86-64

tesseract_decoder-0.1.1.dev20250807185254-py312-none-macosx_11_0_arm64.whl (3.0 MB view details)

Uploaded Python 3.12macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250807185254-py312-none-macosx_10_13_x86_64.whl (2.9 MB view details)

Uploaded Python 3.12macOS 10.13+ x86-64

tesseract_decoder-0.1.1.dev20250807185254-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.dev20250807185254-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl (3.4 MB view details)

Uploaded Python 3.11manylinux: glibc 2.35+ x86-64

tesseract_decoder-0.1.1.dev20250807185254-py311-none-macosx_11_0_arm64.whl (3.0 MB view details)

Uploaded Python 3.11macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250807185254-py311-none-macosx_10_13_x86_64.whl (2.9 MB view details)

Uploaded Python 3.11macOS 10.13+ x86-64

tesseract_decoder-0.1.1.dev20250807185254-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.dev20250807185254-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl (3.4 MB view details)

Uploaded Python 3.10manylinux: glibc 2.35+ x86-64

tesseract_decoder-0.1.1.dev20250807185254-py310-none-macosx_11_0_arm64.whl (3.0 MB view details)

Uploaded Python 3.10macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250807185254-py310-none-macosx_10_13_x86_64.whl (2.9 MB view details)

Uploaded Python 3.10macOS 10.13+ x86-64

File details

Details for the file tesseract_decoder-0.1.1.dev20250807185254-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 0dbdebe165a6fb46684a645b5c8593280cf19815784a74a4dcb23f0d98b99167
MD5 a331d2936ae8fa7e2e7714b89d9a3ef1
BLAKE2b-256 0dcdff3d3211a39a95fbd25876816808afdb9788616cba329f65b838fb8c912e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 606ebfbee11063defa481d698092819e6365d1fbc238af340170d977c63c0d0f
MD5 c436640a802e52acc839bc99e996fa7f
BLAKE2b-256 c20435e150185e9b245c0f600b88d4c4890f74fcbd991717e2532a48786a2970

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 c0058d6ffbdb7d7d01c91b9c2a8c63e1493349f85a4d174ef7527de15e885c53
MD5 6f16e9531546203a909d64a665ef9b8b
BLAKE2b-256 d3bab6cbf24c50c777c0d57588994ee6d3dc7271574457554f35640c9a693af6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 3c609758e6be1a0656528cedd14a3d646238d2890b1a982cc7ef8c4f3f946736
MD5 647c827c8c2148590b746b0e31e901d4
BLAKE2b-256 da45c4f2e48cb4f867b51371fc6c83f902f2acf62fc228db0ff3bff2d6122f4f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 8d7a7c34697add6963b8242bf329f0ec9c5155d188b551d2bdfa2fb3e48626e8
MD5 fa1ef2345d1a4c77f587ecce5561d19c
BLAKE2b-256 d51caa56a9f71947c933a10842931959e2fba38bfb7dd91ec47eda794062d414

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 da2f37f1ebaa02343cf9be03a725eb88e275cd6679bd5acd68d0b32fa31e57ff
MD5 b07cc381431ccab49700c8abc5805ced
BLAKE2b-256 859a0b496d3e0033f8325381324b79afaf7744cc0b3f49fbc918e45660e57cf0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 7d847cbbf6567c15dd0654f1ac8326370de563835317f609cbd7e33ae1e8af40
MD5 1e4d7b524c8fe53cd19fb65053c3594c
BLAKE2b-256 6288660c5ab6db0b7c2fe4443fe742c0b43d67f7ed0a136c25119054b0630d6a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 4f92b240b8f019d10d74f1abf275d3d9741a99f925d44f0fcdcb07362e4ae82f
MD5 9ba60e35f1a43abbd46c5dd5b095eee5
BLAKE2b-256 752f01a3b63c8674b3a69843584a043f2c50bc08b182e755a61634c9d62e723f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 ac04a1c33792b7355c853acb033e9859d6bd437b6ec38a4ab9e95754b839082c
MD5 1dcdf9a48aeeff3597d733803da8c69a
BLAKE2b-256 d223ec5336577bc53b88aecff2fd40f55d1ea5e8d4ad258c4b29228992bda1c3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 bce15742a6c1bac24a507752ce9dfb4539448c36ef377296c7e8db373be5a3fb
MD5 5886063886b832ab7fab2cb09ce1573f
BLAKE2b-256 06de711e2833d23d1f209dc3fa1001fb4c1c8575ba957d8b064a0d1fb2b3db9c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 a2c087ea1b873c9ac2a5fd256d11d8f7aae501f8c1c6b8d75633254b7515e9f5
MD5 8062925010f05e1277ac21438aef9152
BLAKE2b-256 fa796e4989315a5b559b6e7d0b55e9e4ee46811c95397adea0142d2ee79f8b5b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807185254-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 a611f45c147281db6661293946ba0066bdb24ee3ff59440f7736b9da6e45b809
MD5 573ed900ddd70ffba296af1a77c65550
BLAKE2b-256 fb921c5863e1585d21b89e12f0924ffd2edcc3b07c77b5c63226e058c656b30f

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