Skip to main content

Clifft - fast exact simulator for near-Clifford quantum circuits

Project description

Clifft

Unitary Foundation Docs arXiv License Discord Chat

PyPI version Downloads CI codecov Contributor Covenant

Clifft is a fast exact simulator for near-Clifford quantum circuits.

Built and maintained by the Unitary Foundation.

Clifft accepts Stim-format circuits, extends them with non-Clifford gates, and compiles them into bytecode executed by a high-performance Schrödinger Virtual Machine. It is designed for circuits whose dominant structure is Clifford, but whose behavior depends on localized non-Clifford operations.

The main simulation cost scales with the active dimension k of the dense state vector, rather than directly with the total number of physical qubits n. Non-Clifford operations can increase k, while measurements can reduce it.

Why Clifft?

  • Stim-compatible format and API: parse Stim-format circuits with noise, detectors, observables, and repeat blocks, plus non-Clifford extensions.
  • Exact near-Clifford simulation: simulate localized non-Clifford effects without approximating the quantum state.
  • Optimizing compiler pipeline: compile once, then sample many shots with HIR and bytecode optimization passes.
  • Active-dimension scaling: for low-magic circuits, runtime and memory scale with the localized active state rather than the full Hilbert space.

For QEC workflows, Clifft also supports detector-based post-selection, survivor sampling, and stratified importance sampling for rare-event estimation.

Installation

pip install clifft
Platform / CPU family PyPI wheel
Linux x86_64 with AVX2 Supported
Linux aarch64 Supported
macOS arm64 Supported
Windows amd64 Supported

All other platforms and CPU families should build from source. See the installation docs.

Quick Start

import clifft

program = clifft.compile("""
    H 0
    CNOT 0 1
    T 2
    M 0 1 2
""")

result = clifft.sample(program, shots=1000, seed=42)
print(result.measurements[:5])

For more details and examples, check out the documentation or take Clifft for a spin in the web-based interactive playground.

Performance

Clifft is designed for near-Clifford circuits where non-Clifford activity remains localized. In this regime, the dominant cost scales with the peak active dimension k, not directly with the total number of physical qubits.

Regime Representative benchmark What the results show
Pure Clifford QEC Surface code d=7, r=7 ▶↗ Stim remains the right tool; Clifft is roughly 10× slower while preserving the same sampling-oriented workflow.
Low-magic FT circuits MSC d=3 cultivation ▶↗ Clifft reaches 10.4M shots/s, about 370× faster than Tsim on this benchmark.
Larger near-Clifford FT circuits MSC d=5 cultivation ▶↗ Clifft reaches ~135K shots/s on one CPU core, about 13× faster than SOFT at ~10.6K shots/s on one H800 GPU.
Dense universal circuits Quantum Volume In the worst-case dense limit, Clifft remains neck-and-neck with simulators like qiskit-aer and qsim.

Throughput numbers above were measured on cloud instances; the links to the in-browser WASM playground will report lower throughput.

For benchmark details, plots, hardware notes, and guidance on when Clifft is a good fit, see the performance section of the documentation.

The full methodology and scientific results are described in the Clifft paper and companion clifft-paper repo.

Citation

If you use Clifft in your work, please cite the arXiv preprint below.

@misc{chase2026clifftfastexactsimulation,
      title={Clifft: Fast Exact Simulation of Near-Clifford Quantum Circuits},
      author={Bradley A. Chase and Farrokh Labib},
      year={2026},
      eprint={2604.27058},
      archivePrefix={arXiv},
      primaryClass={quant-ph},
      url={https://arxiv.org/abs/2604.27058},
}

Development

See the building from source guide for build instructions.

AI Acknowledgement

We used generative AI tools during parts of the research, software-development, and writing workflow for this project. These tools assisted with code generation and review, implementation analysis, documentation editing, and checks of selected derivations or arguments. All substantive design, validation, and release decisions were made by the human contributors.

Funding

This work was supported by the U.S. Department of Energy, Office of Science, Office of Advanced Scientific Computing Research, Accelerated Research in Quantum Computing under Award Number DE-SC0025336.

This material is also based upon work supported by the U.S. Department of Energy, Office of Science, National Quantum Information Science Research Centers, Quantum Science Center.

License

Apache-2.0

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

clifft-0.2.0.tar.gz (1.6 MB view details)

Uploaded Source

Built Distributions

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

clifft-0.2.0-cp312-abi3-win_amd64.whl (338.7 kB view details)

Uploaded CPython 3.12+Windows x86-64

clifft-0.2.0-cp312-abi3-manylinux_2_28_x86_64.whl (715.1 kB view details)

Uploaded CPython 3.12+manylinux: glibc 2.28+ x86-64

clifft-0.2.0-cp312-abi3-manylinux_2_28_aarch64.whl (579.0 kB view details)

Uploaded CPython 3.12+manylinux: glibc 2.28+ ARM64

clifft-0.2.0-cp312-abi3-macosx_14_0_arm64.whl (631.0 kB view details)

Uploaded CPython 3.12+macOS 14.0+ ARM64

File details

Details for the file clifft-0.2.0.tar.gz.

File metadata

  • Download URL: clifft-0.2.0.tar.gz
  • Upload date:
  • Size: 1.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for clifft-0.2.0.tar.gz
Algorithm Hash digest
SHA256 29b967d88317a1b706ea134dd3d86bfa5662be7c89c5c3e11d07ad83dfc38346
MD5 2778c2fee3551ec88b90d09ea72f1b85
BLAKE2b-256 aa31a69e657c6da497e3d6d33b8c23a373742cf09a25928b256f5f364d29f158

See more details on using hashes here.

Provenance

The following attestation bundles were made for clifft-0.2.0.tar.gz:

Publisher: release.yml on unitaryfoundation/clifft

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

File details

Details for the file clifft-0.2.0-cp312-abi3-win_amd64.whl.

File metadata

  • Download URL: clifft-0.2.0-cp312-abi3-win_amd64.whl
  • Upload date:
  • Size: 338.7 kB
  • Tags: CPython 3.12+, Windows x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for clifft-0.2.0-cp312-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 deead007c77839799c33e2d2cf0acc57dd2a75efdb01092f6af2444ec9ba47ba
MD5 78e29036b98f3b02edb72f69f174614f
BLAKE2b-256 bc062c6302f0adf89674bf032a3fe13f99a2ab1a1d704b80017e8f45b29fa2e9

See more details on using hashes here.

Provenance

The following attestation bundles were made for clifft-0.2.0-cp312-abi3-win_amd64.whl:

Publisher: release.yml on unitaryfoundation/clifft

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

File details

Details for the file clifft-0.2.0-cp312-abi3-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for clifft-0.2.0-cp312-abi3-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 62f1ba944cae6a4ba3685987f88ec32b67c3c26b6b33207576c61eea952d734e
MD5 79a18c8f07fd82e0dd11fc42920bbe98
BLAKE2b-256 142588a0f951e7d32fa934aecff970eb538634d0ad5a04a59d900ce25a3df8bc

See more details on using hashes here.

Provenance

The following attestation bundles were made for clifft-0.2.0-cp312-abi3-manylinux_2_28_x86_64.whl:

Publisher: release.yml on unitaryfoundation/clifft

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

File details

Details for the file clifft-0.2.0-cp312-abi3-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for clifft-0.2.0-cp312-abi3-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 057622960e2324cdd34f713cae791fc622340e39bff12a3b8cd184615895df78
MD5 53d676d11027d8a8a25fb2e37a71c288
BLAKE2b-256 a7e9b123824a945c6ff2a2aebb8ea83a2c90e540c3c1ee316a372495cde8d1f6

See more details on using hashes here.

Provenance

The following attestation bundles were made for clifft-0.2.0-cp312-abi3-manylinux_2_28_aarch64.whl:

Publisher: release.yml on unitaryfoundation/clifft

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

File details

Details for the file clifft-0.2.0-cp312-abi3-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for clifft-0.2.0-cp312-abi3-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 9b7a7c57d36c93ae805002898358aaa6b30db30961bb632cc38b3e6c656ef426
MD5 2ca1ff4f00d0ff9611a82989a7b026e2
BLAKE2b-256 e331b06e4c2752d0993c6d7ae1d8de8dc3456b199c90396c17545cbad316d3d7

See more details on using hashes here.

Provenance

The following attestation bundles were made for clifft-0.2.0-cp312-abi3-macosx_14_0_arm64.whl:

Publisher: release.yml on unitaryfoundation/clifft

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