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.

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.dev20250730181611-py312-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (3.3 MB view details)

Uploaded Python 3.12manylinux: glibc 2.17+ x86-64

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

Uploaded Python 3.12macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250730181611-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.dev20250730181611-py311-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (3.3 MB view details)

Uploaded Python 3.11manylinux: glibc 2.17+ x86-64

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

Uploaded Python 3.11macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250730181611-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.dev20250730181611-py310-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (3.3 MB view details)

Uploaded Python 3.10manylinux: glibc 2.17+ x86-64

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

Uploaded Python 3.10macOS 11.0+ ARM64

tesseract_decoder-0.1.1.dev20250730181611-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.dev20250730181611-py312-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250730181611-py312-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 8ddfcaf1cfeb320264aba050e5b8a183ed9f16bb9818680838a4e58003016855
MD5 a87050f3b22b0f0a0501c5d27e298696
BLAKE2b-256 c84a123843a14f3f91f169c289684a4437f660c9c1bf91dd38d6ddf987a90554

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250730181611-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 0352d598c08a0bc8287070679a6cf4a70d6f3a8407fbf636deef3db29d22962a
MD5 de5c7cda34be64c99423c8705cdff565
BLAKE2b-256 9ef9f4529171fec73a63f22435699671d4118f24992adcae52954a1c9ab16ffe

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250730181611-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 cc1c1b15569a4eaa6bb087101cb027056f186b4a52c71a3c712b11a2a393f6ee
MD5 b0f2715b041120e8a351b5f18c5d7904
BLAKE2b-256 870f974b5c4544ca3a3b0e77746b2d96aa4ef13ea33dce9eae1fda8c665aa840

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250730181611-py311-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250730181611-py311-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 4802016a143dce2b412b3ac4a80bc4edde8512e9ad91748a99a77b7158dd7d2e
MD5 6eb89c21111db8857fb9fb64fe3ff1f3
BLAKE2b-256 7107a11631d6303b5d5d400d8707d32684a8405740b8c57012433b510fe35e23

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250730181611-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 068e37430028b09d09603cb4ad2c46bfb4170b4a963a05b92fa7a5de9b26e03f
MD5 8ba3e13f436dec7e45774ae70b32dd62
BLAKE2b-256 2e774161245beeb0fa8c1e1911332eb64ebe8692d482ecbd11a34a46ffdb887c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250730181611-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 f02edea3b1a73374af35c7b7e6481944f02bcdfbe9967c21054109fecd6f92af
MD5 9fa07481b142dd912f9a6d98a8c140a6
BLAKE2b-256 e23258dd9ec29aafb587c08f23efee08f382bbd80b128cdae49e163e1902f853

See more details on using hashes here.

File details

Details for the file tesseract_decoder-0.1.1.dev20250730181611-py310-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250730181611-py310-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 061b9d338b650f0df5f65abcd72e8313600e86ce474e0c2b5ff683ae91f58118
MD5 e47e4c4f2a6bbc1d6840e32f6910829b
BLAKE2b-256 f2dcabdca985b1eaf18c90b71aadb621992f1ffd4a0a97876e0559f577c0756e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250730181611-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 258ccbac5adc35c13eeed66afed7a68b1ab9299ccca3f079cb27691716412740
MD5 6224325e530b5f3dccec5c414ea1cc13
BLAKE2b-256 d40f834ad0bbd577fd1b9f7bfad9ba887ec9a5b3efd03cc267dff21897b54221

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250730181611-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 d8eb7a45ee30d21e083f378515113230b39016d8462ebabac59f84a1211e622f
MD5 9d9b61a5a3a1e1dfaac8a847a12f7066
BLAKE2b-256 f0fdacfaa5262d5b0f16b750d259f238206607d85944c09d246829acab0d5e7b

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