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

Uploaded Python 3.12macOS 11.0+ ARM64

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

Uploaded Python 3.11macOS 11.0+ ARM64

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

Uploaded Python 3.10macOS 11.0+ ARM64

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 5c5afb3842e859a74e52b327f1d983822fe78e70a40f1b0f36ea9efe192bf8e2
MD5 6dfe96dc6d3a05d01e148bc4a10006fb
BLAKE2b-256 3b2b7245b28790db2d1abd57e9042b5d5a8bdbea76823bf0c1f123df82a63959

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 a152b9d5271604b6b09aae56aa5a9a4011cae570e4552167a808212ff7004b6d
MD5 3c5b65acdca5e0cfec71e5343ded4af1
BLAKE2b-256 840522c809b677144537c1939cdbe70295c7024168f9ce2f15a2fbb87ae9f2f9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 3d52d6119800a5c5c1076367489723600730ef51463f67bc4763076519a087d5
MD5 f135dab60d307b4ea22c5ec5ddaef1f3
BLAKE2b-256 5b0197e17b72d70e2993a5a483dadca5bed3e8caf949db57d4adc85d9b7be7d7

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 cc0022b7dc0db355f2da26d014e7cbfdedceeb38c4ded81a9dbcb3114d80d11a
MD5 fd89ea7751c0e90411e98f2f8d23b452
BLAKE2b-256 c9dd46dfdd4630ac09b68955143e31b61f4259dc6f018880c84facdeb4b178d5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 0d4a530d7cabb524e86435aa2affbcf2285b414e7a34c46760ab37bcd658e08a
MD5 b23a02c86601d61e9320a29642510a31
BLAKE2b-256 443a4e01c226e511a304ef2a4d8d50ae0c86a149cfdd462065307f685ced0b77

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 db9d785d80fe92d2c56a8cc6947c89e697927e8277a643f86c808102bb7a96cc
MD5 d60542421c3dce1cc0a686c68fd566d6
BLAKE2b-256 0a772fc7e13a801f14b94e8c49df04509f573117bd6ea23f6b306c79fc60b5d0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 cf167c22821af96602185ed457b3cd34462c489b2b12a109763601c53a0cf24d
MD5 7c1e42521a22ecb73eefff843df27d47
BLAKE2b-256 406dec2480ccf123a9b590849b38a45bcb7bcc59070e9bbf50de98ff0011f48e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 521c75194d2c608675c1f9852ad044d499742e22db92112505962170b765d884
MD5 dfa0bf5b4c46faa8fce3527f0f29e217
BLAKE2b-256 c72d54277d44d8fb639a3132d7fb28ad39b585065161be7b6f1470bb818b1ac7

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 9cd099543150e7ee5d4fed08c213c57577b1472b3180f9e02865f56aa509b9c1
MD5 b36dd508605728cfbeec120c607e071c
BLAKE2b-256 f35074a8054dca403718a0b8e5be4b054a24261421ff082da4a906888c778fa4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 37baf4a526a3792e15a36fc3050e93e3bb07901e968e427aed76ced445c99205
MD5 646ebf9539133c85e7b221e08dbaf144
BLAKE2b-256 7dfa015836bc76a53caf2ad2227153360caef1698ca484e550ff69f268c81f31

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 a86a7a621f0e6e9e7f5651408084782adef1c60953d3ae2b03eed53301e76f3a
MD5 e9d0563172c05ed1db6af9b44879d909
BLAKE2b-256 e6b053681ad548622769917f70b439e07208320b921254320fcd975d3876d866

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250807174848-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 2c2dd42cfbd60036b2c68e6831d302cc79dbf7278725324ea572f6e29b0be270
MD5 15fced6195e693fb93388d30b13732fb
BLAKE2b-256 7dc4bc44bcde4387b53ffb66953671a91bf41d1885dab888e8e1a97b6dbc0d1b

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