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-2.2.1.tar.gz (56.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_cpu_complex128-2.2.1-py3-none-win_amd64.whl (812.5 kB view details)

Uploaded Python 3Windows x86-64

pyqrack_cpu_complex128-2.2.1-py3-none-manylinux_2_39_x86_64.whl (3.0 MB view details)

Uploaded Python 3manylinux: glibc 2.39+ x86-64

pyqrack_cpu_complex128-2.2.1-py3-none-manylinux_2_35_x86_64.whl (3.1 MB view details)

Uploaded Python 3manylinux: glibc 2.35+ x86-64

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

Uploaded Python 3macOS 15.0+ x86-64

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

Uploaded Python 3macOS 15.0+ ARM64

pyqrack_cpu_complex128-2.2.1-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_cpu_complex128-2.2.1.tar.gz.

File metadata

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

File hashes

Hashes for pyqrack_cpu_complex128-2.2.1.tar.gz
Algorithm Hash digest
SHA256 f1468a6c6283abc8d71169b6d72957ff61a3c1530d304caa3b18d68205072363
MD5 2afc443f4b2539254986e5af24fb7993
BLAKE2b-256 5f0432f2307d7d56e97c0fcae466a6b12be27a87102e20a628affec19aa9e708

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-2.2.1-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 84ee5e7237ff43340f5ad4ee5b3cc58f504db7a79f4c32b25b13d7f45f42cdc4
MD5 9591c8693fb68e439a289df4b8b014a4
BLAKE2b-256 0cce071d4935ffbb60967443f77db8b899824d5918b79a7ab5faf392757fff85

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-2.2.1-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 9bf4c8a8741ddfdb4af82a86f15fe294cf7400eb025c39e7369e7d795db201a9
MD5 f0d6b985110ea407a5d64558669006fc
BLAKE2b-256 5c3888242a811bdb26bc4fbb798b066e5c93049068fb747e1547ae0ca79c8f1e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-2.2.1-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 ad00c1b29380e2dd037cca3bd583bfe94a0ba3eb75b11b1d7bcb7e248cdefceb
MD5 5620645552a54d49cdf8d88a09c9ad6d
BLAKE2b-256 5173f9d4e5004502440c343bd151020c33693c6e4567f965d19eaba9c392256a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-2.2.1-py3-none-macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 63a77088e312b8e81178ef7f7e164fc288a6b2f385ca3546635c0cd86f116678
MD5 432e2b032822def745413bb83ebf5c72
BLAKE2b-256 57f5082059fb0a4260c07864565f8c9fc21d48fac451ff9ecd3ca8ffb6eec6d1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-2.2.1-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 62a8710d53c31f866ca0aba90455eb47838ddb2b5e2616778c7941f1857d9a15
MD5 3e4be9d2d71c8bbb8a42698e92e8ce9b
BLAKE2b-256 7d7515c0c65d7fe8aa3753f54412f613874812fb1674c9992052bc4d028b12bd

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-2.2.1-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 01622424fac7a06b712379a6c5cd940914b785620e2eddbf9087272e8e7462cb
MD5 7ec3235280370e02dfaa28b64648b09d
BLAKE2b-256 37f6373ea4d3e8e45dd36f1b0a77cdf1ebffacdb3a324f4e08a66321c6d512cb

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