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

InstallationUsagePython InterfacePaperHelpCitationContact

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

Full Python wrapper documentation

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}")

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

Uploaded Python 3.12macOS 11.0+ ARM64

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

Uploaded Python 3.11macOS 11.0+ ARM64

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

Uploaded Python 3.10macOS 11.0+ ARM64

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py312-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 4258569c20a80202691e083da6924d7309312ca442ccfdceb591e91a4d6b639d
MD5 b146dba8537700eb61e32c3ea450d495
BLAKE2b-256 ea705c774ba620b4693b049dc089f89311f73ee2aac4f729857d798cd2fe105d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py312-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 db9bdf6b5e881b38b7b76ef8dd5020979c8846c5287374549e143bc3817cfb4d
MD5 cb8194e8292c2d799c69efd35c383a19
BLAKE2b-256 01392ba553ed6713213fdd1c2929bc55366021a8152e8b66a6ba047557189771

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py312-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 6ac0fc9015eedbc72de24e3ffffb0b292393e7e96485d170b914c65cf75050fd
MD5 f077dd5e458a3259dd8f874fc4497cef
BLAKE2b-256 b21a3ff944b556023a704d88f5387513c1acb4405a08b20b5452d20985a48d88

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py312-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 fec8f865aedcf645ec6e4e0f60cbd4ef057ae20ed62df238d8aaf7327a3068da
MD5 9e66ad242fd952d065c9755e9d551da5
BLAKE2b-256 a3aea3cbbadf0e4c3f652ad1e6ef92fab98273a09365b6083b4c996e39ed5f82

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py311-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 0a14e44a71059ea4eaf392f6c1b28054571e9efc89fa86792f795594ccd5decd
MD5 74865ee59b8ec87b5964022f8433b24f
BLAKE2b-256 3f027d1d0ce4dec7259070c200b28e98724632da5af0c527efc7c1f4d97824e8

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py311-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 6815c129b2a4e82b229ff3162b23abaf28c63dbd05c227d63f10319449add54f
MD5 dcbb9b39f85e0811d2042fb911f5fb1d
BLAKE2b-256 5c3e9a8d0705e01a5a385dbd526b0eca9adaf8fb818347a4b887417107e6934d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py311-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 7dc238210364a00dea52286e0ee56408bbcc90a4bad1441546e77876a2afaae5
MD5 b0386dd62c96dc595e0558ebe6b80d85
BLAKE2b-256 f934b5799426532694110df452b20579cf5dc61c184b6626ae62556d80d9c44e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py311-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 98874c681cf080be7a0c82e76741321c2477634548f75220015dd74ad2d439a7
MD5 3b6f6a85e68861f42102bda7f7f9698a
BLAKE2b-256 5722e80a90babe5b3688df46fb919e0287f450d054d144ac4fe1b355685ff85d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py310-none-manylinux_2_39_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 b0b25b07987d65458251b8671c1043770f7b0ca378657e21e231298c9c1490aa
MD5 d12ddc88ea904dbc634add6b38228f70
BLAKE2b-256 e0a782f9d5f6e114a307067984e9b02b6182225fa58e3df871d735995fe7b9a5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py310-none-manylinux_2_35_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 48909c42e0b46027d065e2dc152a37b05c14bd357e2d7f71f09e37bafc5f91e0
MD5 da6a68eb049e8adc536df4b2cc729224
BLAKE2b-256 87f297e96f30351601fda538ea73f65837f3f42129e3ed9550595904c3990155

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py310-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 cfe5a1af85a466b708780506629860a3d4f95d89d16ccf043c664456094884dd
MD5 44747b22c0d0024b8252a6742bb277f9
BLAKE2b-256 4065462185c2ba277897fe34737ebeb2d9e16bfb486359e386ee898201c7e230

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tesseract_decoder-0.1.1.dev20250810203310-py310-none-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 d507db972e513a266f071915e9ba9cbcb0157197507b3aa15c613d86479531f4
MD5 4b42d60ffa196f2cd47fe175ca1acf89
BLAKE2b-256 262b7ca4698aedac115485e53ea6b7892446fc29088d70e298d3b96a40a0bdcb

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