Skip to main content

pyqrack - Pure Python vm6502q/qrack Wrapper

Project description

pyqrack

Downloads Downloads Downloads

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

(PyQrack is just pure Qrack.)

This is the purely CPU-based variant of PyQrack (with module name pyqrack-cpu). This alternate build of PyQrack is provided so that systems that won't use OpenCL or CUDA anyway (such as because they lack any GPUs or other accelerators like the Intel HD) do not need to install the OpenCL library in order to use PyQrack. In this form, both the PyQrack module and the underlying C++ Qrack library are entirely external dependency-free.

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."

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_cpu_complex128-1.74.0.tar.gz (50.0 kB view details)

Uploaded Source

Built Distributions

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

pyqrack_cpu_complex128-1.74.0-py3-none-win_amd64.whl (715.3 kB view details)

Uploaded Python 3Windows x86-64

pyqrack_cpu_complex128-1.74.0-py3-none-manylinux_2_39_x86_64.whl (2.8 MB view details)

Uploaded Python 3manylinux: glibc 2.39+ x86-64

pyqrack_cpu_complex128-1.74.0-py3-none-manylinux_2_35_x86_64.whl (2.8 MB view details)

Uploaded Python 3manylinux: glibc 2.35+ x86-64

pyqrack_cpu_complex128-1.74.0-py3-none-macosx_15_0_x86_64.whl (2.1 MB view details)

Uploaded Python 3macOS 15.0+ x86-64

pyqrack_cpu_complex128-1.74.0-py3-none-macosx_15_0_arm64.whl (1.9 MB view details)

Uploaded Python 3macOS 15.0+ ARM64

pyqrack_cpu_complex128-1.74.0-py3-none-macosx_14_0_arm64.whl (2.0 MB view details)

Uploaded Python 3macOS 14.0+ ARM64

File details

Details for the file pyqrack_cpu_complex128-1.74.0.tar.gz.

File metadata

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

File hashes

Hashes for pyqrack_cpu_complex128-1.74.0.tar.gz
Algorithm Hash digest
SHA256 fe0427a213e79c99c9dd9be1f77b4e5b50e230440df303fb2f7bd41d1c1b7b2d
MD5 75025e647161cada2228f29850c56710
BLAKE2b-256 f6d6992041b3e6c90281d54163b8ce36787ddc9b00c33611a6dde70302e17dfa

See more details on using hashes here.

File details

Details for the file pyqrack_cpu_complex128-1.74.0-py3-none-win_amd64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.74.0-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 5b283e15f28315c698dab27c923547efe2a802070b452e9c9fe3609596cf50bd
MD5 c86744747eaa7b4ebe4f7b2c188c232c
BLAKE2b-256 d58fbe615e1acd9758b27b79debefa00e0f50bd115f40c2fd03b33dbc59f76a7

See more details on using hashes here.

File details

Details for the file pyqrack_cpu_complex128-1.74.0-py3-none-manylinux_2_39_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.74.0-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 2fb50f2a4f9e167fcdb4b691d6b5543fbebf05fd92427f7132689dee6d489e20
MD5 b6512727c06343a555300e416e0206ca
BLAKE2b-256 c5e0bc00b36e661b889343bc5c789ce83d77a154d9deb4b41efbf315d570c77d

See more details on using hashes here.

File details

Details for the file pyqrack_cpu_complex128-1.74.0-py3-none-manylinux_2_35_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.74.0-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 2f327b436394b4f0ebae5171e71008acd74e78cddb14c103e3b1b47157bedcce
MD5 d4de090d9c6bc36eba221f974359f011
BLAKE2b-256 43b27527ad1cfa266c52278e092dd109461592134b624e1094b54a76e0b179b6

See more details on using hashes here.

File details

Details for the file pyqrack_cpu_complex128-1.74.0-py3-none-macosx_15_0_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.74.0-py3-none-macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 8149cc3017e79acae2729beb599efe3a7a47676896565167634f3938017d829c
MD5 cf8e42d14bf90327a9fc51567465addc
BLAKE2b-256 ad767a53d9ca45513398211a5f6a8eac7343281d03af643a74473310e23894ed

See more details on using hashes here.

File details

Details for the file pyqrack_cpu_complex128-1.74.0-py3-none-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.74.0-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 431fb90e9b6356d66a9ceabb8961d2ad64b7fb6123d5fccb6c32005e33cdddaf
MD5 6bcbfbed8f0dfd168dc1f7c5078c59e1
BLAKE2b-256 28643ddec0d9a1fa536d22a6700c55b4505fd4e4c62c025b514b63b6283b3033

See more details on using hashes here.

File details

Details for the file pyqrack_cpu_complex128-1.74.0-py3-none-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.74.0-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 239abdfec69e8d0ce8720602c011438a0f7521fa0c4d57e181e4be55693fc47e
MD5 8f0eeb8c24bb3692596a4ea690f29a5f
BLAKE2b-256 4c9cd8c730c5f88e296e5bdbd5a2a91ad3dc2ebcf9a558017ee9b71856737582

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