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.70.1.tar.gz (49.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_complex128-1.70.1-py3-none-win_amd64.whl (841.2 kB view details)

Uploaded Python 3Windows x86-64

pyqrack_cpu_complex128-1.70.1-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.70.1-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.70.1-py3-none-macosx_15_0_arm64.whl (1.9 MB view details)

Uploaded Python 3macOS 15.0+ ARM64

pyqrack_cpu_complex128-1.70.1-py3-none-macosx_14_0_arm64.whl (1.9 MB view details)

Uploaded Python 3macOS 14.0+ ARM64

pyqrack_cpu_complex128-1.70.1-py3-none-macosx_13_0_x86_64.whl (2.2 MB view details)

Uploaded Python 3macOS 13.0+ x86-64

File details

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

File metadata

  • Download URL: pyqrack_cpu_complex128-1.70.1.tar.gz
  • Upload date:
  • Size: 49.6 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.70.1.tar.gz
Algorithm Hash digest
SHA256 04fd2b5f67934280aefa53c4c06842712ef3d16fd7ac77cdf874d5102f9914b2
MD5 d0ff4d0889cdd91751c33d36052c347b
BLAKE2b-256 9d999e871e617ca052a0b16453a700f8ffa9126c3f4fa9f60908b19c3ed0dcc3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.70.1-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 26a6610afe9ee78917fa2b0aecdf90c4dc53c2826db01f91268e56be959aaf73
MD5 bd6046f4cd42f471c6edbcc4a4b8610f
BLAKE2b-256 65eb505d718f6513a11f52513e80bb810aeead91e49bc5b627044c822e79ee2b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.70.1-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 e9bb339ad2848d410d6f885db226291f23800e51434dabb2cf36dce0f54fb3ec
MD5 6c5496143fec09f824c16f3334eeef8a
BLAKE2b-256 9bb314df149e764c9ce030edb27432e10f944b4de2a92e65bf98b44944fcdfa5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.70.1-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 3aa1961ed632364ab616535846dc3e5695f5414c5648a7ff96cbdf3101a11e23
MD5 4eca6e8445801ef28473940ace664d21
BLAKE2b-256 7563693da1dda5a8dca2f152281fcc67ada15652d0a8a7bffbfcd0b6849fe667

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.70.1-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 cd645284c8c5d55f145461d467f21ca06ced4dfa49c027888c7336ff79d559b6
MD5 f2a35d0e365538528eb59686f40b559a
BLAKE2b-256 a50f7dc39395640816baaac1b186fceb094afa04cd0dda2ef95f677eb266061b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.70.1-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 0037a922b71651f7175d89523432870b1d89899918d68626115788da9a51b3a1
MD5 51ea3dd989d1ce598f88bc76d62bc34d
BLAKE2b-256 9a65c4bf59f1ee2e866108d8722de4ce3a21e4bfa975771dfaa838ad40cb77bf

See more details on using hashes here.

File details

Details for the file pyqrack_cpu_complex128-1.70.1-py3-none-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_cpu_complex128-1.70.1-py3-none-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 0fea08a09039a6438665886cd99bfeb3910cbee74f731fe0db2d61669f280836
MD5 1b5c015fa3ac715d4b452fd55d325e20
BLAKE2b-256 a3555eb60a66ced3863466324fc02dc88c055ceff595d75f20712f9fa9c69c09

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