Skip to main content

QIR to Quantinuum QIS (Quantum Instruction Set) compiler

Project description

QIR-QIS

Crates.io PyPI

A compiler that validates and translates QIR (Quantum Intermediate Representation) to Quantinuum QIS (Quantum Instruction Set). This tool enables quantum programs written in QIR to run on Quantinuum's quantum computing systems.

Features

  • QIR Validation: Validates QIR bitcode for correctness and spec compliance
  • QIS Translation: Compiles QIR to Quantinuum's native QIS instruction set
  • Python & Rust API: Use as a Rust library or Python package
  • CLI Tool: Command-line interface for quick compilation

See qtm-qir-reference.md for details on supported QIR features and their mapping to Quantinuum QIS.

Installation

From Source (Rust)

Requirements:

  • Rust >= 1.91.0
  • LLVM 14
cargo build --release

The compiled binary will be available at target/release/qir-qis.

Python Package

Requirements:

  • Python >= 3.10, < 3.15
  • uv (recommended) or pip

Available pre-built wheels:

  • Linux: x86_64 (manylinux_2_28), aarch64 (manylinux_2_28)
  • macOS: x86_64, arm64 (Apple Silicon)
  • Windows: x86_64

All wheels support Python 3.10+ using the stable ABI (abi3).

# Using uv (recommended)
uv pip install qir-qis

# Using pip
pip install qir-qis

For development installation:

uv sync

Usage

Command Line

Compile a QIR LLVM IR file to QIS bitcode:

# Basic usage
qir-qis input.ll

# With custom optimization level
qir-qis -O 3 input.ll

# Specify target architecture
qir-qis -t x86-64 input.ll

# Or using cargo
cargo run -- input.ll

This generates input.qis.bc containing the compiled QIS bitcode.

Python API

See examples/python_api.py for a complete working example.

uv run examples/python_api.py

For a more comprehensive example with quantum simulation, see main.py.

Rust API

See examples/rust_api.rs for a complete working example.

cargo run --example rust_api

Development

Setting Up Development Environment

# Clone the repository
git clone https://github.com/quantinuum/qir-qis.git
cd qir-qis

# Install Rust dependencies and build
cargo build

# Install Python dependencies
uv sync

Building

# Build Rust binary
cargo build --release

# Build Python package
uv run maturin build --release

Testing

Running Tests

Tests require cargo-nextest:

# Run all tests
make test

# Or directly with cargo
cargo nextest run --all-targets --all-features

Testing Individual Files

# Compile a single QIR file
make compile FILE=tests/data/adaptive.ll

# Compile all test files
make allcompile

Simulation Testing with Selene

Test the compiled QIS using Selene quantum simulator:

# Simulate a single file (runs 5 shots by default)
make sim FILE=tests/data/adaptive.ll

# Simulate all test files
make allsim

This will:

  1. Compile the QIR to QIS
  2. Run it on the Selene/Quest simulator
  3. Display measurement results

Code Quality

# Run linters
make lint

# This runs:
# - prek (pre-commit checks, https://prek.j178.dev/)
# - typos checker
# - cargo clippy

Regenerating Python Stubs

After modifying the Python API:

make stubs

This updates qir_qis.pyi with the latest type signatures.

Project Structure

qir-qis/
├── src/
│   ├── main.rs          # CLI entry point
│   ├── lib.rs           # Library and Python bindings
│   ├── convert.rs       # QIR to QIS conversion logic
│   ├── decompose.rs     # Gate decomposition
│   ├── opt.rs           # LLVM optimization passes
│   └── utils.rs         # Helper utilities
├── tests/
│   ├── data/            # Test QIR files
│   └── snaps/           # Snapshot test results
├── main.py              # Example Python usage with simulation
├── Cargo.toml           # Rust package configuration
├── pyproject.toml       # Python package configuration
└── Makefile             # Common development tasks

Common Makefile Targets

Command Description
make test Run all unit and integration tests
make compile FILE=<path> Compile a single QIR file
make sim FILE=<path> Compile and simulate a QIR file
make lint Run code quality checks
make stubs Regenerate Python type stubs
make allcompile Compile all test files
make allsim Simulate all test files

Contributing

Contributions are welcome! Please read CONTRIBUTING.md for:

  • How to report issues and submit pull requests
  • Coding standards and commit message format
  • Development workflow and testing requirements

Quick checklist before submitting:

  • Tests pass: make test
  • Linters pass: make lint
  • Documentation updated

License

Apache-2.0

Copyright Quantinuum

Project details


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.

qir_qis-0.1.3-cp310-abi3-win_amd64.whl (15.7 MB view details)

Uploaded CPython 3.10+Windows x86-64

qir_qis-0.1.3-cp310-abi3-manylinux_2_28_x86_64.whl (18.8 MB view details)

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

qir_qis-0.1.3-cp310-abi3-manylinux_2_28_aarch64.whl (17.5 MB view details)

Uploaded CPython 3.10+manylinux: glibc 2.28+ ARM64

qir_qis-0.1.3-cp310-abi3-macosx_13_0_x86_64.whl (17.6 MB view details)

Uploaded CPython 3.10+macOS 13.0+ x86-64

qir_qis-0.1.3-cp310-abi3-macosx_13_0_arm64.whl (16.0 MB view details)

Uploaded CPython 3.10+macOS 13.0+ ARM64

File details

Details for the file qir_qis-0.1.3-cp310-abi3-win_amd64.whl.

File metadata

  • Download URL: qir_qis-0.1.3-cp310-abi3-win_amd64.whl
  • Upload date:
  • Size: 15.7 MB
  • Tags: CPython 3.10+, Windows x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for qir_qis-0.1.3-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 855bc462e4f31d0dc05cba063f7632610d16a1c66e40ef99ace215355ce76faa
MD5 7d5e1c34e63cc859b23bd10579cee834
BLAKE2b-256 f31625aa2d6ac5dba9d052c4b58049452d0174f4b2a049e6a38e4540c4a72a46

See more details on using hashes here.

Provenance

The following attestation bundles were made for qir_qis-0.1.3-cp310-abi3-win_amd64.whl:

Publisher: wheels-release.yml on Quantinuum/qir-qis

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

File details

Details for the file qir_qis-0.1.3-cp310-abi3-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for qir_qis-0.1.3-cp310-abi3-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 5864b1165a08270a327b80ccb5c02b28544e6e40860a1ca3ec4976b99183f7e8
MD5 29bcf1adb00d47181b25c5fd381e4fb8
BLAKE2b-256 3f1843aaac65f8d6637db0dc18ce6fa7e5458f7924dae9a1b22b9ec84b985bcb

See more details on using hashes here.

Provenance

The following attestation bundles were made for qir_qis-0.1.3-cp310-abi3-manylinux_2_28_x86_64.whl:

Publisher: wheels-release.yml on Quantinuum/qir-qis

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

File details

Details for the file qir_qis-0.1.3-cp310-abi3-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for qir_qis-0.1.3-cp310-abi3-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 eff1fc1bc282e33707658c65ca483bc9f5558c618f746920004d74dca9ba48c6
MD5 5f7791ccd0437d98328e39bf7f487288
BLAKE2b-256 81d0817ee7e71154d79be5e7f0c6fda45f925261b22b0b5abaf3d9932366f1ec

See more details on using hashes here.

Provenance

The following attestation bundles were made for qir_qis-0.1.3-cp310-abi3-manylinux_2_28_aarch64.whl:

Publisher: wheels-release.yml on Quantinuum/qir-qis

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

File details

Details for the file qir_qis-0.1.3-cp310-abi3-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for qir_qis-0.1.3-cp310-abi3-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 9a0e488bdd4015330602645aa77002f9f970764ba4ccb7b8548490aa7c3de5ed
MD5 69638af72e261e336b3add371fb06f8c
BLAKE2b-256 6502bd01b83fe4a811d1e2e0c20ccd49e92289e561a74480cafdfc7c00ef98f1

See more details on using hashes here.

Provenance

The following attestation bundles were made for qir_qis-0.1.3-cp310-abi3-macosx_13_0_x86_64.whl:

Publisher: wheels-release.yml on Quantinuum/qir-qis

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

File details

Details for the file qir_qis-0.1.3-cp310-abi3-macosx_13_0_arm64.whl.

File metadata

File hashes

Hashes for qir_qis-0.1.3-cp310-abi3-macosx_13_0_arm64.whl
Algorithm Hash digest
SHA256 e1704efcafea5983d686b8658f4c8dff9110229af6f47bd2d5b5213a7256aeb3
MD5 fb6c349559156463288e236c4f74fd46
BLAKE2b-256 52c924906128a455d2de1e08ad05b6de7a0b25002e1cc1db941b7ad4a9314f6e

See more details on using hashes here.

Provenance

The following attestation bundles were made for qir_qis-0.1.3-cp310-abi3-macosx_13_0_arm64.whl:

Publisher: wheels-release.yml on Quantinuum/qir-qis

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