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.84.10.tar.gz (52.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.84.10-py3-none-win_amd64.whl (846.3 kB view details)

Uploaded Python 3Windows x86-64

pyqrack_cpu_complex128-1.84.10-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.84.10-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.84.10-py3-none-macosx_15_0_x86_64.whl (2.1 MB view details)

Uploaded Python 3macOS 15.0+ x86-64

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

Uploaded Python 3macOS 15.0+ ARM64

pyqrack_cpu_complex128-1.84.10-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.84.10.tar.gz.

File metadata

  • Download URL: pyqrack_cpu_complex128-1.84.10.tar.gz
  • Upload date:
  • Size: 52.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.84.10.tar.gz
Algorithm Hash digest
SHA256 1858daf7592855bb33e9fa221b4bf721c4affab893cdfa3ea2d42084df3697e9
MD5 67cb7c0bf37f424469885e93a2fe6c1e
BLAKE2b-256 7adb78590196a4e185033e931499fb6155bffd23ac7d4b603228537c54c9ae60

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.84.10-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 1fc9b8bb4d0ed88177fafc60bb15aef287ebd4cacd64cac9faca675c9af9a321
MD5 6c23ddfe8ec4f0333c76f3c19c66a2b4
BLAKE2b-256 8f504c98984041e4874e89a201d628b897d43db013a5d854d3b0e3c1f326ad99

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.84.10-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 35ebe77a1f5618d3309533ea96a299c372bd0c7ae761c64168ae29f7ef36ed81
MD5 207d19986b91bd948801bc18e6be46ff
BLAKE2b-256 f1e4b96371de6977f1257e564928295ae53d6aefb90370e7e0ac9a04919c72b5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.84.10-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 914ad0a1d44eaac95ed40c97854b38415ed25ebede336c51cf86100d6461e74e
MD5 39c00d7a17b15d4c180cc13fe4cfeca5
BLAKE2b-256 d4560fb7eb684a50aeb0cf688ff3a36a995d319b0e870dce55487b309d7cd8f8

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.84.10-py3-none-macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 b788a5599bc1f791ad3d6a1e78ca16a4d655c0e40375bd563a70407397c2d244
MD5 9ec69d0c9e97b646aa08a0acb038c241
BLAKE2b-256 ec56432107b8a37a72e997c3fffddec8f66a275dc82924d993a806e531159a48

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.84.10-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 eb2f0ab62da069e4c0ecbb2622aefb028d4287227344ee268bd17df4b62f3679
MD5 c8560cb165591c14cd61979a881ccffd
BLAKE2b-256 dade7de36b4a387acf8f5f24b500263bb3be04cfe8d1c1d24026909bcf1968c9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.84.10-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 b937bbe93c7a6babdbc93d49f1f3219e3b671f4b1f7129fed6be0546cd8f5b0f
MD5 f309e573ae0887f3f1c690fb2bd62d8e
BLAKE2b-256 1959084b9f5f371c59bfd33f9a600e8c18c492c2362bd8be120b4dae9c05bd38

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