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, Or Golan, for CI build pipeline tooling, 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.82.1.tar.gz (51.7 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.82.1-py3-none-win_amd64.whl (1.0 MB view details)

Uploaded Python 3Windows x86-64

pyqrack_complex128-1.82.1-py3-none-manylinux_2_39_x86_64.whl (3.4 MB view details)

Uploaded Python 3manylinux: glibc 2.39+ x86-64

pyqrack_complex128-1.82.1-py3-none-manylinux_2_35_x86_64.whl (3.4 MB view details)

Uploaded Python 3manylinux: glibc 2.35+ x86-64

pyqrack_complex128-1.82.1-py3-none-macosx_15_0_x86_64.whl (2.1 MB view details)

Uploaded Python 3macOS 15.0+ x86-64

pyqrack_complex128-1.82.1-py3-none-macosx_15_0_arm64.whl (1.9 MB view details)

Uploaded Python 3macOS 15.0+ ARM64

pyqrack_complex128-1.82.1-py3-none-macosx_14_0_arm64.whl (1.9 MB view details)

Uploaded Python 3macOS 14.0+ ARM64

File details

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

File metadata

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

File hashes

Hashes for pyqrack_complex128-1.82.1.tar.gz
Algorithm Hash digest
SHA256 e271a3665548bfde0a072fc07291d41a336f6df76a72e88308869497b8e790f9
MD5 d2a3efbe92080a3d33b9abd1abe1896e
BLAKE2b-256 16c8fbd02b8664030b3fddeff686b3df46cc8f7be4fae79b911ae1912810dbcf

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.82.1-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 9d75ac433ef1b4116a0d3d0465136c1707c34fd63fff2a4f405f0983f24835f0
MD5 b3e82c8638607fee540a05ea8e7e88a7
BLAKE2b-256 14a71158b8b5d78551191b036fe0af710daeeb741a4d6468f159aebdc4a40c34

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.82.1-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 e6fa4c8b871b847425197e0b83e8c7f2711dbe22d82f3d9c58c7e3bc0b79ad13
MD5 967236fdad0589776345f8a8d837aa81
BLAKE2b-256 24e88d752ec9f003a3f1d19cdf700c4c21474091f631c0898c417aa70984b834

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.82.1-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 f8564c2bc1b35c0418f4ea184ea2797b689cf183b44768d6d1daf78c2fe1c603
MD5 c2cdb74c24a597d681b88c468aa76c49
BLAKE2b-256 6508a04b2f3bfc46392fd082c9ecd666cd8da38dcd9fdbaa763a361200e8f0c0

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.82.1-py3-none-macosx_15_0_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.82.1-py3-none-macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 e7a060a9df7d3e9efe78674e68e22c2b4fe70e313b3c12f16b9a5f6be4c9c1c0
MD5 eeacbe701da7980a634653102893f87e
BLAKE2b-256 0eb68be233b6435283178db76822b02edd19a5313e16b25b52531c49d27e8c02

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.82.1-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 86e23db75b059cff8af0d5609fc321b7ced795f4e4a8b2d8d5b797b2f171283c
MD5 e3c3b3637d4522a76acbb98dffab816c
BLAKE2b-256 3e0a97b00c72fab97f784cc9436e4cb55a626e61e1d915d443e4fce8808b9c59

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.82.1-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 5f9e8142ddede6120b6e951e16361ca0aaff6ac086ac44dc2f5ed3ce409b040f
MD5 6f4d18c2ccc5ce2a302bc2878d6154c5
BLAKE2b-256 4188c7e6ae6ed41a3c1dd0fa1d1e98a69a2a026ff89bb48a38101f42a6c3df74

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