Skip to main content

PyQIR parses, generates and evaluates the Quantum Intermediate Representation.

Project description

PyQIR

The pyqir package provides the ability to generate QIR as well as an easy way to parse and analyze QIR.

QIR generation is intended to be used by code automating translation processes enabling the conversion in some format to QIR via Python; i.e., this is a low-level API intended to be used as a bridge to existing Python frameworks enabling the generation of QIR rather than directly consumed by an end-user. It is not intended to be used as a framework for algorithm and application development.

Installation

The package is released on PyPI and can be installed via pip:

pip install pyqir

Examples

PyQIR examples can be found in this repository's examples folder.

Generation

The following code creates QIR for a Bell pair before measuring each qubit and returning the result. The unoptimized QIR is displayed in the terminal when executed:

from pyqir import BasicQisBuilder, SimpleModule

module = SimpleModule("Bell", num_qubits=2, num_results=2)
qis = BasicQisBuilder(module.builder)

qis.h(module.qubits[0])
qis.cx(module.qubits[0], module.qubits[1])

qis.mz(module.qubits[0], module.results[0])
qis.mz(module.qubits[1], module.results[1])

print(module.ir())

The QIR output will look like:

; ModuleID = 'Bell'
source_filename = "Bell"

%Qubit = type opaque
%Result = type opaque

define void @main() #0 {
entry:
  call void @__quantum__qis__h__body(%Qubit* null)
  call void @__quantum__qis__cnot__body(%Qubit* null, %Qubit* inttoptr (i64 1 to %Qubit*))
  call void @__quantum__qis__mz__body(%Qubit* null, %Result* null)
  call void @__quantum__qis__mz__body(%Qubit* inttoptr (i64 1 to %Qubit*), %Result* inttoptr (i64 1 to %Result*))
  ret void
}

declare void @__quantum__qis__h__body(%Qubit*)

declare void @__quantum__qis__cnot__body(%Qubit*, %Qubit*)

declare void @__quantum__qis__mz__body(%Qubit*, %Result* writeonly) #1

attributes #0 = { "entry_point" "output_labeling_schema" "qir_profiles"="custom" "required_num_qubits"="2" "required_num_results"="2" }
attributes #1 = { "irreversible" }

!llvm.module.flags = !{!0, !1, !2, !3}

!0 = !{i32 1, !"qir_major_version", i32 1}
!1 = !{i32 7, !"qir_minor_version", i32 0}
!2 = !{i32 1, !"dynamic_qubit_management", i1 false}
!3 = !{i32 1, !"dynamic_result_management", i1 false}

Contributing

There are many ways in which you can contribute to PyQIR, whether by contributing a feature or by engaging in discussions; we value contributions in all shapes and sizes! We refer to this document for guidelines and ideas for how you can get involved.

Contributing a pull request to this repo requires to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. A CLA-bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately. Simply follow the instructions provided by the bot. You will only need to do this once.

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.

iqm_pyqir-0.12.0-cp38-abi3-win_amd64.whl (1.7 MB view details)

Uploaded CPython 3.8+Windows x86-64

iqm_pyqir-0.12.0-cp38-abi3-manylinux_2_31_x86_64.whl (2.3 MB view details)

Uploaded CPython 3.8+manylinux: glibc 2.31+ x86-64

iqm_pyqir-0.12.0-cp38-abi3-macosx_11_0_arm64.whl (1.7 MB view details)

Uploaded CPython 3.8+macOS 11.0+ ARM64

iqm_pyqir-0.12.0-cp38-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl (2.1 MB view details)

Uploaded CPython 3.8+macOS 10.12+ universal2 (ARM64, x86-64)macOS 10.12+ x86-64macOS 11.0+ ARM64

File details

Details for the file iqm_pyqir-0.12.0-cp38-abi3-win_amd64.whl.

File metadata

  • Download URL: iqm_pyqir-0.12.0-cp38-abi3-win_amd64.whl
  • Upload date:
  • Size: 1.7 MB
  • Tags: CPython 3.8+, Windows x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for iqm_pyqir-0.12.0-cp38-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 73dc870519df09b60c303e421a61bcde563d0df8c11bb83ea206f17aa14a4ecd
MD5 4870c65f90c29d886eb31961ad3c0482
BLAKE2b-256 7b95e76f67f976b84b09208c86c6a1a06c3b49cbaf2c5bc1de228729f7915102

See more details on using hashes here.

File details

Details for the file iqm_pyqir-0.12.0-cp38-abi3-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for iqm_pyqir-0.12.0-cp38-abi3-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 28a1a2daeff5749fc8dea1122fe64a777b22a778d991cd9c8b7a8ae383efca8b
MD5 bad6d58fc00004f551006d0471d9e75e
BLAKE2b-256 6c219f3ad7f2b9a22c11dbd3f3bc1f0a593fc55fbf05c529ea651f73322b73df

See more details on using hashes here.

File details

Details for the file iqm_pyqir-0.12.0-cp38-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for iqm_pyqir-0.12.0-cp38-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 8f508cda10e48be776c28482fd68b734e981ff57ae0366a0ee5f0e642e9b02e2
MD5 3189041fcd8b7e3809f525be0916bf5c
BLAKE2b-256 9d39dc5883b5a767256a0e35c1e099f07f447cb3c49b556d2a574492a5f0cb97

See more details on using hashes here.

File details

Details for the file iqm_pyqir-0.12.0-cp38-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl.

File metadata

File hashes

Hashes for iqm_pyqir-0.12.0-cp38-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl
Algorithm Hash digest
SHA256 628ad8ef42bfd209e0a38c2a342b6bbf76cf1042164ac3218f57634178ce8fc4
MD5 151977a87839d6a65ce2e2887fbf5275
BLAKE2b-256 954dddcb71dd61d31c3fcdec0e402a59239ca3aa11a743975914bca71a7bd97e

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