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
  • CHANGELOG.md 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.1-cp310-abi3-win_amd64.whl (15.7 MB view details)

Uploaded CPython 3.10+Windows x86-64

qir_qis-0.1.1-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.1-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.1-cp310-abi3-macosx_13_0_x86_64.whl (17.5 MB view details)

Uploaded CPython 3.10+macOS 13.0+ x86-64

qir_qis-0.1.1-cp310-abi3-macosx_13_0_arm64.whl (15.9 MB view details)

Uploaded CPython 3.10+macOS 13.0+ ARM64

File details

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

File metadata

  • Download URL: qir_qis-0.1.1-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.1-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 4d20c0d7fcff2796d89b7cbb36cb0445eb3a101e0170f88f0b411a32b4d26fba
MD5 65d98598e2087e873dbde4e62bc46c68
BLAKE2b-256 6777e7ad68cc952465182f96927874c13b4374afb729341c6c22b808b2831ed6

See more details on using hashes here.

Provenance

The following attestation bundles were made for qir_qis-0.1.1-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.1-cp310-abi3-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for qir_qis-0.1.1-cp310-abi3-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 57e63c45c5c37b228bdd151c4e799e5bad57bf1451cd87d23dcd5a9f17f8dd0a
MD5 f285619ac8fd330e8d0bb4a78a8329b1
BLAKE2b-256 203eabf7982fe179b348284094a3717770d67b84c22de351e113e478851ecd50

See more details on using hashes here.

Provenance

The following attestation bundles were made for qir_qis-0.1.1-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.1-cp310-abi3-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for qir_qis-0.1.1-cp310-abi3-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 34d0cc13262dd9dfcbecf215e95f0f64270d32ed53f4bc537ebe439710dfc661
MD5 af789c3fe17d184a81f211792a7afd13
BLAKE2b-256 4ccc1516fa8ff7acde54be83dfdde0ed872228304474c72ab8a681ff6e04c293

See more details on using hashes here.

Provenance

The following attestation bundles were made for qir_qis-0.1.1-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.1-cp310-abi3-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for qir_qis-0.1.1-cp310-abi3-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 08756e2072ca8fa5b23b1683fd55d9598d7eff82067b915dc78cb7d79970a407
MD5 3969fe5a0b7c60e41c81ef7a07d21d15
BLAKE2b-256 f47274081d0663fc953a078e959a9971827a888f517ccef1f4985e06e60ec383

See more details on using hashes here.

Provenance

The following attestation bundles were made for qir_qis-0.1.1-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.1-cp310-abi3-macosx_13_0_arm64.whl.

File metadata

File hashes

Hashes for qir_qis-0.1.1-cp310-abi3-macosx_13_0_arm64.whl
Algorithm Hash digest
SHA256 888b0dbbcb0eb1d1e8dbc38b1f6a6ae0bb4843d8328ccc1cd8b4ad6b269d85d6
MD5 12efa2d43a96f27de0d3b4f7875c82ee
BLAKE2b-256 eb5448b81276e4816894285e29143c6a04b154878551b81a3f362cd82ee3fa80

See more details on using hashes here.

Provenance

The following attestation bundles were made for qir_qis-0.1.1-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