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

pyqir-0.10.2-cp38-abi3-win_amd64.whl (1.6 MB view details)

Uploaded CPython 3.8+ Windows x86-64

pyqir-0.10.2-cp38-abi3-manylinux_2_31_x86_64.whl (2.2 MB view details)

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

pyqir-0.10.2-cp38-abi3-macosx_11_0_arm64.whl (1.6 MB view details)

Uploaded CPython 3.8+ macOS 11.0+ ARM64

pyqir-0.10.2-cp38-abi3-macosx_10_12_x86_64.whl (1.7 MB view details)

Uploaded CPython 3.8+ macOS 10.12+ x86-64

pyqir-0.10.2-cp38-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl (3.3 MB view details)

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

File details

Details for the file pyqir-0.10.2-cp38-abi3-win_amd64.whl.

File metadata

  • Download URL: pyqir-0.10.2-cp38-abi3-win_amd64.whl
  • Upload date:
  • Size: 1.6 MB
  • Tags: CPython 3.8+, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: RestSharp/106.13.0.0

File hashes

Hashes for pyqir-0.10.2-cp38-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 e994938521af707d60af579e684af8271882f9b852916da4f6b4c535718d5e82
MD5 daf937683db4c6e3f9cb9e5612cd7ca7
BLAKE2b-256 4e9514d556db52595a1420cedc2883cddc156b45184b05bdfc39b5d45912ce53

See more details on using hashes here.

File details

Details for the file pyqir-0.10.2-cp38-abi3-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for pyqir-0.10.2-cp38-abi3-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 e7e610b715b9cdbf507ee45b6b0f5d7731cda75369a57a09dd2fe6fe8e234da3
MD5 19abad27c503f43a054ddc46eaf1ad29
BLAKE2b-256 924e0ea27f4195f90837d13fc668608cebcc8db4be508c146bf174c82f9bfd5a

See more details on using hashes here.

File details

Details for the file pyqir-0.10.2-cp38-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pyqir-0.10.2-cp38-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 51f9e54f7e8c420a794fea8320f29f0bf03ca008c28c3e49e2d39a01da801673
MD5 ccd36a97ca811ffd8cbc199e4afb8d55
BLAKE2b-256 588395111a2d4c2a038d9c85fc3ff2209e1ecc04ebe97858efa18bb96837d4df

See more details on using hashes here.

File details

Details for the file pyqir-0.10.2-cp38-abi3-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for pyqir-0.10.2-cp38-abi3-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 2da2f25fed9048f3dcd80659abc1836456f9b476cd211fadb981a24f45d25af8
MD5 06a43c4768093e66b19b98ed6dede0eb
BLAKE2b-256 52e2e5a1ae3acae6f13b82365602d4de1330131306881de6f1ae0562ff8596e6

See more details on using hashes here.

File details

Details for the file pyqir-0.10.2-cp38-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl.

File metadata

File hashes

Hashes for pyqir-0.10.2-cp38-abi3-macosx_10_12_x86_64.macosx_11_0_arm64.macosx_10_12_universal2.whl
Algorithm Hash digest
SHA256 c36bb36e8350bfa1c19a4dbca4532de68b7359909f67f28ddaa9fa645f9b7cdd
MD5 75425b05b282b241463b507a4a57d6d4
BLAKE2b-256 8f5c70ddc6838622e006b7f8002473eb6a2ba9ec12712eb0800a16d97113d285

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page