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

Uploaded Python 3.12manylinux: glibc 2.39+ x86-64

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

Uploaded Python 3.12macOS 11.0+ ARM64

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

Uploaded Python 3.11manylinux: glibc 2.39+ x86-64

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

Uploaded Python 3.11macOS 11.0+ ARM64

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

Uploaded Python 3.10manylinux: glibc 2.39+ x86-64

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

Uploaded Python 3.10macOS 11.0+ ARM64

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 0aefa3d1269757548a9dad3b0633b4071d3deb0a102f28b1a922fc93a57fda6b
MD5 4e1c6e33fde2ef5451fa50d73e9fc101
BLAKE2b-256 27d4466496194ffc3d26b6ed8ff263f5a0b54e15153eb302c5af7f2e0738e114

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 f75657dc25cfd2474f4469a478d07d4b23a13c21f0426148d3fc79f83a150ff1
MD5 544b61e1c99c84174362cc6cf7d1348e
BLAKE2b-256 058f7a8557371150558fc565445d54616c7826cfbebe7bb6ab9785ca2c086a4f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 8e52752cdc4e4527ad9df470fad80a3b6f93e7de3a6d6ed41e7a0192e8f030c3
MD5 1428dda83cb6959e5ebf6b66f2f5bf4f
BLAKE2b-256 ecc82b3d098c98b5dcd5b2aa940990f2962f2d37cdf52a7cc0af11d5560ebaaa

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 4fccb533c6ef0afc961984f28f3021831deaff75b675eac6c7db7724049ba244
MD5 dfd9d649acff4da8a26ea4b9e0cbab2e
BLAKE2b-256 3ddd0a44e4a8324d322ae36c779672d6d8ed06533c2bd88ae8ec74c3b5353631

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 c2210e1a1f023745c5b972043c3bf8f119477795623339fa7231973b48cbc212
MD5 525accecf813e37bea2f8e20ed2a4969
BLAKE2b-256 56130da010b572e4c126c7f34695757f117f274e38cb0be86711813ad3599042

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 9e0e8fd580a7bcc3b4e16bf8025b7d7d146624a2ba0d6bb3ba41f7f5f425fd49
MD5 d22af6b8176cced33df9589910a27ad1
BLAKE2b-256 225ec7401d1f501545b8e1de6f6cfba3b517214b0d0f0411b264aff257726a2d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 9502e07406f9574c6a3aafba0db2d2f5eb4d4b3a479f7e739cbb5e8aedec1b23
MD5 55f2bfcde640bb1368fb103a52b7ded1
BLAKE2b-256 ed0982538ef137c52355063f32f80fcdd547092efdb8033efb0a96274b8ccafd

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 ff595d1ed80848f84e65e0714e147754171816993218dc8ae02fe0b53d20a30c
MD5 ac62fb14ca10b99739b7a05e5ced8539
BLAKE2b-256 f02e5082e49f7eabd2c6a8e681c86b688cd964f7038a2847456d7c78dc619b08

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 64e42fbbcf86538454f7feeb6ca795d5acbcab2dc5d684ed5235243fad2b7d5b
MD5 6f0c1686c907c62847bd0450a1cc35c6
BLAKE2b-256 ac469dbdf9f51763d16b7de8a67eab5e8c3cdd421d43142e92a9e11e14737c07

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 be25fe924f8e0e7a7d924b3dd3e79245e9a07909dfc77e3daf0a8eb54acbc4a5
MD5 c9f80ca65abfd52ab40ae54f89f78ca9
BLAKE2b-256 bcbf6c0410b065afd1a08ecedcb9eb97b6e1bb0f2c9b2343927baa85c0bcb90b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 462d5b52cfbde2be49885d219c6649b880aa969aaf8252627338392c3f5fe929
MD5 1fb00aa7967fb18155802b76529cb796
BLAKE2b-256 eacddadecc443185fa06a4ed95c7bdc4e86d81c91f89e2a68d53a05b68236913

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250801001043-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 4b373cd2ade7f09cab4b4087d6bebad0bd19ee7c81ff9e2320c42e489e17da25
MD5 a5ae952f8678bd4c8c8ba8053859a5e1
BLAKE2b-256 1daf6a80cfd6fab829a25af40c8c3a9877a3c404ed2b51b9ee9d58c0bf7ffc36

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