Skip to main content

Python based QIR Evaluation (JIT) library.

Project description

pyqir-evaluator

The pyqir-evaluator package provides an easy way to execute generated QIR for the purpose of:

  1. easily testing and experimenting with QIR code
  2. connecting it to low-level Python-based lab software such as e.g. QCoDeS

It contains the necessary just-in-time compilation infrastructure as well as an extensibility mechanism to define what actions to perform when a gate is applied in Python.

Installation

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

pip install pyqir-evaluator

Examples

There are evaluator examples in the repository.

Let's look at how to log the gate sequence for the Bernstein-Vazirani example.

We can evaluate the generated bitcode with NonadaptiveEvaluator and GateLogger to print out a simple log of the quantum application:

from pyqir.evaluator import NonadaptiveEvaluator, GateLogger

from pathlib import Path
import os

path = Path(__file__).parent
file = os.path.join(path, "bernstein_vazirani.bc")

evaluator = NonadaptiveEvaluator()
logger = GateLogger()

evaluator.eval(file, logger)

print("# output from GateLogger")
logger.print()

This would generate the following output:

# output from GateLogger
qubits[9]
out[9]
x qubit[8]
h qubit[0]
h qubit[1]
h qubit[2]
h qubit[3]
h qubit[4]
h qubit[5]
h qubit[6]
h qubit[7]
h qubit[8]
cx qubit[2], qubit[8]
cx qubit[3], qubit[8]
h qubit[0]
h qubit[1]
h qubit[2]
h qubit[3]
h qubit[4]
h qubit[5]
h qubit[6]
h qubit[7]
measure qubits[0] -> out[0]
measure qubits[1] -> out[1]
measure qubits[2] -> out[2]
measure qubits[3] -> out[3]
measure qubits[4] -> out[4]
measure qubits[5] -> out[5]
measure qubits[6] -> out[6]
measure qubits[7] -> out[7]
measure qubits[8] -> out[8]

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.

Building and Testing

See Building.

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_evaluator-0.4.1a1-cp36-abi3-win_amd64.whl (8.6 MB view details)

Uploaded CPython 3.6+ Windows x86-64

pyqir_evaluator-0.4.1a1-cp36-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (10.8 MB view details)

Uploaded CPython 3.6+ manylinux: glibc 2.17+ x86-64

pyqir_evaluator-0.4.1a1-cp36-abi3-macosx_10_7_x86_64.whl (9.1 MB view details)

Uploaded CPython 3.6+ macOS 10.7+ x86-64

File details

Details for the file pyqir_evaluator-0.4.1a1-cp36-abi3-win_amd64.whl.

File metadata

  • Download URL: pyqir_evaluator-0.4.1a1-cp36-abi3-win_amd64.whl
  • Upload date:
  • Size: 8.6 MB
  • Tags: CPython 3.6+, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.8.2 requests/2.22.0 setuptools/57.0.0 requests-toolbelt/0.9.1 tqdm/4.64.0 CPython/3.8.10

File hashes

Hashes for pyqir_evaluator-0.4.1a1-cp36-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 d621c1613bfdaae3e1f1a90fd2a07e2906640b34c4b693364efe955ddb9b266c
MD5 246f8182a315a7ce1d6e3c6405322c05
BLAKE2b-256 07c0d28376396634741a31580f38372a1c145ae5f183880fbd9531b30a29a61e

See more details on using hashes here.

File details

Details for the file pyqir_evaluator-0.4.1a1-cp36-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pyqir_evaluator-0.4.1a1-cp36-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 f7093d0419d9a0c43ed7d4eb82d4ff70f8b1c65ec8c9a8ccd9e6671170ca173e
MD5 562aaf12ea1e8df33d8355bed0a569f2
BLAKE2b-256 2178f958443bcb9e2be5fd1da8b1a6230c3b6fd5e47244d97dc20ed131ba1dad

See more details on using hashes here.

File details

Details for the file pyqir_evaluator-0.4.1a1-cp36-abi3-macosx_10_7_x86_64.whl.

File metadata

  • Download URL: pyqir_evaluator-0.4.1a1-cp36-abi3-macosx_10_7_x86_64.whl
  • Upload date:
  • Size: 9.1 MB
  • Tags: CPython 3.6+, macOS 10.7+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.8.2 requests/2.22.0 setuptools/57.0.0 requests-toolbelt/0.9.1 tqdm/4.64.0 CPython/3.8.10

File hashes

Hashes for pyqir_evaluator-0.4.1a1-cp36-abi3-macosx_10_7_x86_64.whl
Algorithm Hash digest
SHA256 7d6f15f5dda036df94f532b2cb4b05f84760ba76548f60b5df4cea7909f71ca8
MD5 6d3cf11ffc45fe688ad4d42e29b543db
BLAKE2b-256 5d5e00f9253abd3a07cc7757d321cf573dfd4a650aacde32e1d81992f093b129

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