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

Uploaded Python 3.12macOS 11.0+ ARM64

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

Uploaded Python 3.11macOS 11.0+ ARM64

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

Uploaded Python 3.10macOS 11.0+ ARM64

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 b70533352f0823ff3aeef79f006a815149c9c2e5a6760ffaf43efc8702999658
MD5 0dd4b5d9956024fb11dc83c7be7411b4
BLAKE2b-256 0de69f0871ae0c05a2bd6ebaa59a17bd7d2a9c45dc98783e6496d3efdb8d25f3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 f37fb44a8a1aa73f59709131220bbcf23752aa0f55880bf08d8850cd7398653e
MD5 ee68091ce8f7659dd776d7259d92d1d0
BLAKE2b-256 419179fe06e0fda4c668b5212585a6604850e95f949a72c7b35d7792cc3ccc60

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 923b8dbefeb2399ada1f3dad4b91252199cdd8847b3a7a59e786fdb457a9e884
MD5 93109a6c674b0b429ed73bb445508a5a
BLAKE2b-256 29481de5c65270d8332bf02487a39d894db11c7ae69bca1ee13105edcab64a67

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 298edf4c9437d7d592bf6aa36924b3046c938601d6f7066ba1fa30c779b82b76
MD5 3eba6f31fe200fff9d73c5e2698be1af
BLAKE2b-256 cccaaa05ee58977d729c3a6257578764ad96b095684c69abcf53d8143923f799

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 f921c7e42d59de19aeabcde1a893b168d5a1ed0bf1ca501f714502ee67dbbf72
MD5 598f4dd3660299f45c759f2132a1ba2d
BLAKE2b-256 ba4f929e697a7eef8ba5f8f5a58e9993c8517d6d983b17229020df9d9d214817

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 bd17cb4d09f6e767d01cd9a20da7a2a1d755243c5745366619e7dd0540d89048
MD5 d08b35f678f7ea7f12b30ca186825598
BLAKE2b-256 6fb5b9b1749509645e3a74d24c8ffbc77c9a65610ee51b6576552f66fc4c6d7b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 6b8cda08071d1e01d94bbe0b5452e6bd7e5811f78eb4e047a829a75e09a037ef
MD5 41026cc4fef91998091732fddd813ca7
BLAKE2b-256 76ce9ca19c791de0213b05ff401d48de56cc1dcc5c94c61bdcfe183aa55629ff

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 cbac360e8baaf883cf057489c2dafe51ef07243ee6035ff584609d058ddda9ee
MD5 36b55794cbc0cce4e7261f44d83118a7
BLAKE2b-256 1976b71afd862e4694067a58a182e86d33864070c768a991b3ce3300859274ec

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 497b46130871412a0d15420d1afd8ce4d723f71fceaf92f1604588147cbe6279
MD5 3d2a618c8e46b0696413b5c369a8ae8d
BLAKE2b-256 2354f88681352867bb2f1bd12e3e2f5aa3aec2d4b796154b941bf41565f8f6e9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 e07a753a66231b91811a86bd1b7d16d0d22928bf9a05314bca00693a07fe7319
MD5 753eb489ab8af3204ea3c020bda9b4ad
BLAKE2b-256 45fcf43f0ebfaec00240dab157165e43e9f93baa1266fb9f90a36b6de432fac3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 689a0be85fafc439a4837931e66018d887849f1506fd32d441b5695a315f486d
MD5 4bf354062517bb3345ea8560034a7acd
BLAKE2b-256 2f7aaca8f8270111f1d039a745da00720cbc84bec0cff4557ba19e245970a4a0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250808022417-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 926827073ab282468fb8f3b2ffd39b7d8345c15955fa15aca5babee8d4588a3b
MD5 76ef47a7b0900cdfe2613d313bab914b
BLAKE2b-256 8ac24067de3afb825bac872bfb385d7702f44879b974b70765d0ac24620fca24

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