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-2.5.0.tar.gz (60.3 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-2.5.0-py3-none-win_amd64.whl (995.7 kB view details)

Uploaded Python 3Windows x86-64

pyqrack_complex128-2.5.0-py3-none-manylinux_2_39_x86_64.whl (3.7 MB view details)

Uploaded Python 3manylinux: glibc 2.39+ x86-64

pyqrack_complex128-2.5.0-py3-none-manylinux_2_35_x86_64.whl (3.7 MB view details)

Uploaded Python 3manylinux: glibc 2.35+ x86-64

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

Uploaded Python 3macOS 15.0+ x86-64

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

Uploaded Python 3macOS 15.0+ ARM64

pyqrack_complex128-2.5.0-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-2.5.0.tar.gz.

File metadata

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

File hashes

Hashes for pyqrack_complex128-2.5.0.tar.gz
Algorithm Hash digest
SHA256 24c0feaec9a34f0da71073677165d8b77edb3bd2e0d7721cc294d65082e93f10
MD5 80a5154e6df8434019c44cbaefa06671
BLAKE2b-256 714ce2f1e6b31c002b696be91e3b70ddb59748e1fecb88e7397c70cc639ceb33

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-2.5.0-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 51cfd5bf1bfb800b19ed54fe7da13647f1b9ec30648ad9806a3f53f2e6d4062f
MD5 8e76f675631a250d00e78a90565b27b9
BLAKE2b-256 134987fedd21028e8598b20bdf7c1d766e5e12e6378422e386e43965b8c8e18d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-2.5.0-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 b280282dd9bde62fd8f070ceb84a58e9d1aef72706249be7f3d8b26831263f8a
MD5 128f62c67e9d5a3f08bf0cd862121da3
BLAKE2b-256 884c0466765058217abd66309aca9ca33a9ad0ab7323ddd19e8c019872024434

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-2.5.0-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 b729c448a6f4ecffae43eb4ca473cfa93c9b46cfaf143bc23b52a26bdddc2ee5
MD5 ca86c04d02cffc53850ee341f2a11d1f
BLAKE2b-256 c54899d1bbc38cb4e88b1afc3b6bc3f2c35d8b5557ddbe1089de9f8d4e7586b2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-2.5.0-py3-none-macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 ab7339a75df3ec0779d4f8f4831d618cfa0c4deea26a2a902dd16d2a9d1d2e83
MD5 e1906ab731600593c66a179371ea1894
BLAKE2b-256 379200495530dba4bbfb0b384a8cf4f5c23e8a677823348384328a2e9fa857ee

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-2.5.0-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 638bc2828a99b35e1719abf42d3c797dfea697a30d4289eb0f99b4471f4a8713
MD5 03c1c0c971ebe63c07927680ae05008b
BLAKE2b-256 97a5ae9f17e2e6002ac61ad9293a07611d728cb468bb717a6144f576391ef8f4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-2.5.0-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 d76d465c708a4204f6c5e5f99c43916880501d03fccd96bbcb0ac3d40111fde6
MD5 2d87952b9289c19b56f01075d02f8cfe
BLAKE2b-256 0b79ec8ed0ac24592c712bc17001c8217f077a3f702e93892cdd3af378e513ff

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