Skip to main content

A modular Graph State qompiler for measurement-based quantum computing.

Project description

GraphQOMB

License PyPI version Python Versions Documentation Status codecov pytest typecheck Ruff

GraphQOMB (Qompiler for Measurement-Based Quantum Computing, pronounced graphcomb) is a compiler framework for measurement-based quantum computation (MBQC). It keeps the resource-state structure, classical feedforward, and execution schedule as separate first-class objects, then lowers them to an executable measurement pattern with a Pauli frame.

This design makes GraphQOMB useful both as an executable MBQC compiler and as a foundation for fault-tolerant workflows. The same core pipeline can be used to build patterns, study schedule-dependent resource tradeoffs, simulate them with statevector or density-matrix backends, and export compatible patterns to Stim-oriented downstream tooling.

Core Workflow

GraphQOMB is organized around three explicit compiler interfaces:

  • Labelled graph state: the resource state, measurement bases, and I/O registration.
  • Feedforward maps: explicit xflow and optional zflow describing classical dependencies.
  • Scheduler: preparation, entanglement, and measurement order for executable slices.

These are lowered with qompile(...) into a Pattern carrying:

  • a command stream for scheduled MBQC execution,
  • a PauliFrame for classical dependency tracking,
  • metrics such as max_space, depth, and active_volume.

Features

  • Explicit IR boundaries: work directly with graph-state, feedforward, and schedule objects instead of mixing them into a single representation.
  • Pattern lowering: compile MBQC IRs into executable patterns with TICK-delimited slices and Pauli-frame tracking.
  • Schedule analysis: compare depth-oriented and space-oriented schedules and inspect resulting resource metrics.
  • Simulation: run circuit or pattern simulations with statevector and density-matrix backends.
  • Stim export: compile compatible patterns to Stim text for downstream FT-oriented analysis.
  • Toolchain interoperability: use GraphQOMB downstream of circuit transpilation and graph-rewrite tooling such as PyZX and flow-finding utilities.

Installation

From PyPI

pip install graphqomb

Install optional PyZX integration:

pip install "graphqomb[pyzx]"

From Source

git clone https://github.com/TeamGraphix/graphqomb.git
cd graphqomb
pip install -e .

Install development dependencies:

pip install -e .[dev]

Install documentation dependencies:

pip install -e .[doc]

Quick Start

The quickest way to see the compiler pipeline is to start from an MBQC-native circuit, derive the graph/feedforward/schedule objects, and lower them into a pattern:

import numpy as np

from graphqomb.circuit import MBQCCircuit, circuit2graph
from graphqomb.qompiler import qompile
from graphqomb.simulator import PatternSimulator, SimulatorBackend

circuit = MBQCCircuit(3)
circuit.j(0, 0.5 * np.pi)
circuit.cz(0, 1)
circuit.cz(0, 2)
circuit.j(1, 0.75 * np.pi)
circuit.j(2, 0.25 * np.pi)

graphstate, xflow, scheduler = circuit2graph(circuit)
pattern = qompile(graphstate, xflow, scheduler=scheduler)

print("pattern depth:", pattern.depth)
print("pattern max space:", pattern.max_space)

simulator = PatternSimulator(pattern, SimulatorBackend.StateVector)
simulator.simulate()
print(simulator.state.state())

If you already have a graph-state design and explicit feedforward maps, you can skip circuit2graph(...) and call qompile(...) directly.

Documentation

Current Scope

GraphQOMB currently targets static, branch-free MBQC workflows. It is designed around causal feedforward dependencies and explicit scheduling, which makes it a good fit for pattern generation, simulation, and offline analysis of executable or fault-tolerant MBQC pipelines.

Development

Running Tests

pytest
pytest tests/test_specific.py

Code Quality

ruff check
ruff format
mypy
pyright

Building Documentation

cd docs
make html

Contributing

Contributions are welcome. Please open an issue or pull request with:

  1. A clear description of the change.
  2. Tests for behavioral changes when applicable.
  3. Documentation updates for user-facing features.

Related Projects

  • graphix: MBQC software stack with a different abstraction strategy.
  • PyZX: ZX-calculus tooling that can be used upstream of GraphQOMB.
  • swiflow: Flow-finding utilities for MBQC dependency structures.
  • Stim: Fast stabilizer-circuit simulator targeted by the Stim export path.

Our ongoing projects

License

MIT License

Citation

If you use GraphQOMB in your research, please cite:

@software{graphqomb,
  title = {GraphQOMB: A Modular Graph State Qompiler for Measurement-Based Quantum Computation},
  author = {Masato Fukushima, Sora Shiratani, Yuki Watanabe, and Daichi Sasaki},
  year = {2025},
  url = {https://github.com/TeamGraphix/graphqomb}
}

Acknowledgements

We acknowledge the NICT Quantum Camp for supporting our development.

Special thanks to Fixstars Amplify:

amplify

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

graphqomb-0.3.1.tar.gz (123.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

graphqomb-0.3.1-py3-none-any.whl (84.7 kB view details)

Uploaded Python 3

File details

Details for the file graphqomb-0.3.1.tar.gz.

File metadata

  • Download URL: graphqomb-0.3.1.tar.gz
  • Upload date:
  • Size: 123.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for graphqomb-0.3.1.tar.gz
Algorithm Hash digest
SHA256 ca5d456f770ad51f99aaac7ae952c4ade812e7aed393110cf966819cf01ef3f7
MD5 c8a7f0f1f7df95aa2c3be6af06ba09e7
BLAKE2b-256 47e4a9001f4f96b19d152294edcc40723d94691ba51144216eff928097caaea5

See more details on using hashes here.

Provenance

The following attestation bundles were made for graphqomb-0.3.1.tar.gz:

Publisher: publish-to-pypi.yml on TeamGraphix/graphqomb

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file graphqomb-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: graphqomb-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 84.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for graphqomb-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4f3480db2218e8c0bfb7d6eb5fc73be45f933c40c99820df6a31400f5edfadad
MD5 adb303b8c1cf94ed6f6e31a89a986ef7
BLAKE2b-256 b8951ba513f77196c9fff01c399559c7a6794e42909925977a74ec1a74b376d6

See more details on using hashes here.

Provenance

The following attestation bundles were made for graphqomb-0.3.1-py3-none-any.whl:

Publisher: publish-to-pypi.yml on TeamGraphix/graphqomb

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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