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.0-cp38-abi3-win_amd64.whl (1.4 MB view details)

Uploaded CPython 3.8+ Windows x86-64

pyqir-0.10.0-cp38-abi3-manylinux_2_31_x86_64.whl (2.6 MB view details)

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

pyqir-0.10.0-cp38-abi3-macosx_11_0_arm64.whl (1.7 MB view details)

Uploaded CPython 3.8+ macOS 11.0+ ARM64

pyqir-0.10.0-cp38-abi3-macosx_10_9_x86_64.whl (1.5 MB view details)

Uploaded CPython 3.8+ macOS 10.9+ x86-64

File details

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

File metadata

  • Download URL: pyqir-0.10.0-cp38-abi3-win_amd64.whl
  • Upload date:
  • Size: 1.4 MB
  • Tags: CPython 3.8+, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for pyqir-0.10.0-cp38-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 c43bcb1a6c874312e89402405458dc544215ce9ea161a8e63944a2c03462b97e
MD5 b15e99f6b8f858551aa65bd0d7b3b274
BLAKE2b-256 f1f871ca79953c00242d4a32ba945de2e5f2ef5eb9d271cd867f8b79f63ab105

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqir-0.10.0-cp38-abi3-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 a862778ff8b40ec4267627605766bbff53d5ccf1b87619dd5bacc8beec0d1cc3
MD5 44fdf0f551b3ac3bc39504282ab417f7
BLAKE2b-256 9eff566fc94a99b1cd753c673dab6a1ed478d9e638a9f6330883616c5fad4b67

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqir-0.10.0-cp38-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 cd4ea16986dd4f776906b9364095d9480f411ba16fec9c558e388ca0be8bfcbc
MD5 28a2f50c7bb3d4d052366080a812cca3
BLAKE2b-256 9cee982201aa1b50aa3dec719f9e72a59e43a549a33761c1542a0f375b6386a7

See more details on using hashes here.

File details

Details for the file pyqir-0.10.0-cp38-abi3-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for pyqir-0.10.0-cp38-abi3-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 b2fd7bb4bd45fa601ac92099c4e82d8f02e092a44d413d1dad7fa555fafa40b8
MD5 475f604c0ff34f4e365e3cad38bf4825
BLAKE2b-256 9dff49984d051674238b512801bd70ee9642b375c1b5fbc723d798518db0e2f5

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