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.

(If you installing from source, it doesn't matter whether you use pyqrack or pyqrack-cpu, because the build version of C++ Qrack you intend to use must already be installed locally.)

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, 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-1.36.0.tar.gz (34.6 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-1.36.0-py3-none-win_amd64.whl (679.0 kB view details)

Uploaded Python 3Windows x86-64

pyqrack_cpu-1.36.0-py3-none-manylinux_2_39_x86_64.whl (2.2 MB view details)

Uploaded Python 3manylinux: glibc 2.39+ x86-64

pyqrack_cpu-1.36.0-py3-none-manylinux_2_35_x86_64.whl (2.2 MB view details)

Uploaded Python 3manylinux: glibc 2.35+ x86-64

pyqrack_cpu-1.36.0-py3-none-manylinux_2_31_x86_64.whl (2.1 MB view details)

Uploaded Python 3manylinux: glibc 2.31+ x86-64

pyqrack_cpu-1.36.0-py3-none-macosx_13_0_x86_64.whl (1.7 MB view details)

Uploaded Python 3macOS 13.0+ x86-64

File details

Details for the file pyqrack_cpu-1.36.0.tar.gz.

File metadata

  • Download URL: pyqrack_cpu-1.36.0.tar.gz
  • Upload date:
  • Size: 34.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for pyqrack_cpu-1.36.0.tar.gz
Algorithm Hash digest
SHA256 f34b7d357ab1c5e6699d3c30d07e1435f3bb8a4776396c81ca29cac59e82764e
MD5 5a803f9fd5c3d3b2da2059479f5f1f8f
BLAKE2b-256 b9e3faf05d984fd70a0c30a3ddd36cd63fd83f9976cceb51c6162ef91b9a20c2

See more details on using hashes here.

File details

Details for the file pyqrack_cpu-1.36.0-py3-none-win_amd64.whl.

File metadata

  • Download URL: pyqrack_cpu-1.36.0-py3-none-win_amd64.whl
  • Upload date:
  • Size: 679.0 kB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for pyqrack_cpu-1.36.0-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 79f58c8d30ab196da409d70707c4c0fbe693c85f87eb3fcb833d193f42a69694
MD5 f949d70ddd396a2b7811748aac30498e
BLAKE2b-256 5a5b76fbb01a8752c3cabb36448f5cf61febba5aefa82fbd5ed8663e272a5c5a

See more details on using hashes here.

File details

Details for the file pyqrack_cpu-1.36.0-py3-none-manylinux_2_39_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu-1.36.0-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 ba5c2e2abbdb7974b56c499a789916b052f14a0852011d057e8795660d2e6e22
MD5 cdb697626c0576b6a3a5785b8519b948
BLAKE2b-256 479c98ddaddf629be6e3820925652103b213e7610b40ac2a851d4207f7be9445

See more details on using hashes here.

File details

Details for the file pyqrack_cpu-1.36.0-py3-none-manylinux_2_35_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu-1.36.0-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 9bdc7133af2f6ee4a4a12c3ff4d99e2e7cea6e243c30578f5def9e457e02d748
MD5 ad18177dd4849b8106c6ec8411e317df
BLAKE2b-256 b5d75b7882d4662bb1cd4fb2ecc3ab9555024a1266723fb3baef4f9594e76ada

See more details on using hashes here.

File details

Details for the file pyqrack_cpu-1.36.0-py3-none-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu-1.36.0-py3-none-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 7c1f4a279824d2dc16068bc9f849b1fdad5295219416ddd4c3c63f1fc74b24f6
MD5 374772255ff290455742ff0aae02c4e9
BLAKE2b-256 94e43e4d65b8193ada03e3a9d695412c615c1453e64924f84a8a7720121fc716

See more details on using hashes here.

File details

Details for the file pyqrack_cpu-1.36.0-py3-none-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu-1.36.0-py3-none-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 45e822b2176080f94b81961adeca89f815115d6ad4cc6c60f539ee7afc91edf0
MD5 8d36a61915ed3e56d07f965e562085be
BLAKE2b-256 38b349d33d847c25edf7b4f673407b8e285ccb329df0da1e19434b9f336af768

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