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.73.0.tar.gz (49.9 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.73.0-py3-none-win_amd64.whl (946.0 kB view details)

Uploaded Python 3Windows x86-64

pyqrack_complex128-1.73.0-py3-none-manylinux_2_39_x86_64.whl (3.0 MB view details)

Uploaded Python 3manylinux: glibc 2.39+ x86-64

pyqrack_complex128-1.73.0-py3-none-manylinux_2_35_x86_64.whl (3.0 MB view details)

Uploaded Python 3manylinux: glibc 2.35+ x86-64

pyqrack_complex128-1.73.0-py3-none-macosx_15_0_x86_64.whl (1.8 MB view details)

Uploaded Python 3macOS 15.0+ x86-64

pyqrack_complex128-1.73.0-py3-none-macosx_15_0_arm64.whl (1.7 MB view details)

Uploaded Python 3macOS 15.0+ ARM64

pyqrack_complex128-1.73.0-py3-none-macosx_14_0_arm64.whl (1.7 MB view details)

Uploaded Python 3macOS 14.0+ ARM64

File details

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

File metadata

  • Download URL: pyqrack_complex128-1.73.0.tar.gz
  • Upload date:
  • Size: 49.9 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.73.0.tar.gz
Algorithm Hash digest
SHA256 0819ddad31c85c7fa2edd93551fd03bf5ac915643a4b625b8249766def6a90ee
MD5 842ff3ab4258dfebfb3e76b518fe5159
BLAKE2b-256 b2ec920618caad3e707fa4f9ed1ba24d400a7ecc65534e85bf1ab514d60892c9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.73.0-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 7002335434cc25aa4b6dc7162fbc8cde98bcbcdea7526fb39520121b2ae7c54e
MD5 3b7804d4ea21f98efc5442e827b38466
BLAKE2b-256 8c952c8e20f995ff208660ac2da1cfb0634c87918ff4aed9077d230d26b777b3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.73.0-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 b5f980e614e83835884180eb0e90b3b0a908d3638236a4d8244a7bca7dc33140
MD5 5f0eea77bcef42f597e4a53e8b93a076
BLAKE2b-256 f8a6b2bcf628644863c40b37c7d8826c075d0407ee0e1143549571cb962734f3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.73.0-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 53f00c598dd44c1b7cd118e7a5b32c358d55570fa3a9618a8306d118f0e393c4
MD5 6893ba5fe45510d4ddfd9f078be80700
BLAKE2b-256 0cbb5c5379f2e60598b88d08302ea95ea111cf44a4af540fc21d9b5424e656e7

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.73.0-py3-none-macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 4fc0ebcbbe8af7aacb4a2c615a5e156f6f90d676245535cebd6d3cd398dff790
MD5 5792ebb2e04dfcfe180c870e51911c5b
BLAKE2b-256 0b239d448f9f58e897e5a99684514369db2ce8aeedb6654086dafcd10aafb0e0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.73.0-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 5efb9b9d256d99166fa42a85af16a50c51d0175e43e3d9f94a6491c3888403dd
MD5 8e812ef80aafd0be42963a0509cefb16
BLAKE2b-256 4145655774d6d5fe27130528c3169a147f46b728128e78fd59305d0e1a3ac42c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_complex128-1.73.0-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 c4e2044e6aa5ebb85c4055cacc398519f5ac58d1a296b45762385e6570f25cef
MD5 83f68c8ccf31d6d4931bb93c0f613274
BLAKE2b-256 b707b686621b99e2b87abb49fa6cf021f60322854876d225e639033ea9b7b0cc

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