Skip to main content

pyqrack - Pure Python vm6502q/qrack Wrapper

Project description

pyqrack

Downloads Downloads Downloads

Pure Python bindings for the pure C++11/OpenCL Qrack quantum computer simulator library

(PyQrack is just pure Qrack.)

Note: You must also install OpenCL to use this version of Qrack. (There are also CPU-only and CUDA version.)

If you're looking for Mac ARM support, use the package pyqrack, not pyqrack-cpu. Mac officially "deprecated" OpenCL years ago. Hence, accelerator support is not included in ARM-based Mac wheels, and OpenCL installation is not required on these systems, but, if you have a CUDA accelerator on ARM-based Mac, you could try the package pyqrack-cuda instead.

Performance can benefit greatly from following the Qrack repository "Quick Start" and "Power user considerations."

If you use an integrated graphics accelerator, like the Intel HD, setting environment variable PYQRACK_HOST_POINTER_DEFAULT_ON=1 (or to any "truthy" value) will automatically set the default of isHostPointer option of QrackSimulator to True, to engage "zero-copy" mode by default.

Import and instantiate QrackSimulator instances. This simulator can perform arbitrary single qubit and controlled-single-qubit gates, as well as other specific gates like SWAP.

Any 2x2 bit operator matrix is represented by a list of 4 complex floating point numbers, in row-major order.

Single and array "b" parameters represent Pauli operator bases. They are specified according to the enumeration of the Pauli class.

MC[x] and MAC[x] methods are controlled single bit gates, with as many control qubits as you specify via Python list c argument. MCX is multiply-controlled Pauli X, and MACX is "anti-"controlled Pauli X, i.e. "anti-control" activates the gate if all control bits are specifically off, as opposed to on.

To load the required unitaryfund/qrack libraries from a different location, set the PYQRACK_SHARED_LIB_PATH environment variable.

PyQrack has experimental support for PyZX Circuit definitions as an intermediate representation for QrackSimulator. To try this, load a Circuit in PyZX, (use that module to optimize your circuit, as you like,) and create a QrackSimulator() instance using the pyzxCircuit named argument of the constructor, like so:

sim = QrackSimulator(pyzxCircuit=c)

where c is a PyZX circuit object. The circuit will automatically be simulated in the constructed QrackSimulator instance. This also allows loading from QASM and other intermediate representations supported by PyZX.

See https://pyqrack.readthedocs.io/en/latest/ for an API reference.

For custom Qrack build floating-point precision, where options are half, float, double, and quad, set an environment variable via export QRACK_FPPOW=[n] (or as appropriate to your shell) where [n] is the logarithm base 2 of the number of bits in the systemic floating point type (4, 5, 6, or 7, with 5 or float as default, i.e. 2**5=32 for 32-bit float). Your Qrack installation floating-point build option must match this specific value, which might require a custom Qrack build.

Please feel welcome to open an issue, if you'd like help. 😃

Special thanks go to Zeeshan Ahmed, for bug fixes and design suggestions, Ashish Panigrahi, for documentation and design suggestions, WingCode, for documentation, and to the broader community of Qrack contributors, for years of happy Qracking! You rock!

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyqrack_complex128-1.58.0.tar.gz (47.8 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

pyqrack_complex128-1.58.0-py3-none-win_amd64.whl (895.8 kB view details)

Uploaded Python 3Windows x86-64

pyqrack_complex128-1.58.0-py3-none-manylinux_2_39_x86_64.whl (2.9 MB view details)

Uploaded Python 3manylinux: glibc 2.39+ x86-64

pyqrack_complex128-1.58.0-py3-none-manylinux_2_35_x86_64.whl (2.9 MB view details)

Uploaded Python 3manylinux: glibc 2.35+ x86-64

pyqrack_complex128-1.58.0-py3-none-macosx_15_0_arm64.whl (1.6 MB view details)

Uploaded Python 3macOS 15.0+ ARM64

pyqrack_complex128-1.58.0-py3-none-macosx_14_0_arm64.whl (1.6 MB view details)

Uploaded Python 3macOS 14.0+ ARM64

pyqrack_complex128-1.58.0-py3-none-macosx_13_0_x86_64.whl (1.8 MB view details)

Uploaded Python 3macOS 13.0+ x86-64

File details

Details for the file pyqrack_complex128-1.58.0.tar.gz.

File metadata

  • Download URL: pyqrack_complex128-1.58.0.tar.gz
  • Upload date:
  • Size: 47.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for pyqrack_complex128-1.58.0.tar.gz
Algorithm Hash digest
SHA256 6c1bd2be2d089c2cdd77993ab7c51f1398f7af2b5e6a877cc5549493d410b6e7
MD5 76b006547d0be07be8ce074fd33e39f5
BLAKE2b-256 0d42b9d308280851cd4ff15c54901a6564c91d902c8a44220debfbc59427ca5d

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.58.0-py3-none-win_amd64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.58.0-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 a876075c89fd4dcf553973f59037d60d22fc50a9557dda51da30bb909a04cae6
MD5 41492267bea980a51b8988a13ac4328b
BLAKE2b-256 d0076ddd9edd46b7b6283b7da7b1bbb9b8cfb6c96cae8dec9c48e237c9765904

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.58.0-py3-none-manylinux_2_39_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.58.0-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 821c8ec150d685ced2c8f6bbb8fb90b23c9cf4bf82ba1ca6dd0224bb0eff3ec5
MD5 7be756716dae83049fbab213cacfd4e2
BLAKE2b-256 df16255cecde9b4ddefd9280571149d5359d8d785d7bb47e9a8e969e9153e31e

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.58.0-py3-none-manylinux_2_35_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.58.0-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 7a8697e71c6a2c6a611688177a09c40922e606f60bc99bffce3e7186b5165659
MD5 52bbdd2f044c6abc6e52d3d87f383cb0
BLAKE2b-256 9978e077cbdd8c1fdb05fa31afa0d3c4918268e3400581353ca4cf2d2faa9d12

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.58.0-py3-none-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.58.0-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 5ee0c4101207676e735a1ee09aec42fba33b799580a9af2d491491ebbb5b71de
MD5 9d2b496ee93970b39ed372005af8a8a0
BLAKE2b-256 b4b4f8680aee2f01038dbe7e04cdb280da45604af5537832e5c5a0edb2c850bb

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.58.0-py3-none-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.58.0-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 9fa93718bd1f4159df889772a7cf76431a59dc5920f2cac88d1ddf0085a84282
MD5 f2a5f379e27cce199a0b5090c466d0e0
BLAKE2b-256 8107800184a69fcaeada39706cb4974b74d496c279a8085cd61051f7f4afa9c6

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.58.0-py3-none-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.58.0-py3-none-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 968cfa591db3c18e6c3ce6542c2b44f3b7bb3b6e761ba00f214bbf37998a7e9a
MD5 16e86501b24997e2fbbabc5691e56790
BLAKE2b-256 948c764400e37869df923ed92ed6a6ec82561694b8f0207ecc8ad02189cd091e

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