Skip to main content

pyqrack - Pure Python vm6502q/qrack Wrapper

Project description

pyqrack

Downloads Downloads Downloads

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

(PyQrack is just pure Qrack.)

Note: You must also install OpenCL to use this version of Qrack. (There are also CPU-only and CUDA version.)

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

If you use an integrated graphics accelerator, like the Intel HD, setting environment variable PYQRACK_HOST_POINTER_DEFAULT_ON=1 (or to any "truthy" value) will automatically set the default of isHostPointer option of QrackSimulator to True, to engage "zero-copy" mode by default.

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_complex128-1.76.0.tar.gz (50.7 kB view details)

Uploaded Source

Built Distributions

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

pyqrack_complex128-1.76.0-py3-none-win_amd64.whl (1.0 MB view details)

Uploaded Python 3Windows x86-64

pyqrack_complex128-1.76.0-py3-none-manylinux_2_39_x86_64.whl (3.4 MB view details)

Uploaded Python 3manylinux: glibc 2.39+ x86-64

pyqrack_complex128-1.76.0-py3-none-manylinux_2_35_x86_64.whl (3.4 MB view details)

Uploaded Python 3manylinux: glibc 2.35+ x86-64

pyqrack_complex128-1.76.0-py3-none-macosx_15_0_x86_64.whl (2.1 MB view details)

Uploaded Python 3macOS 15.0+ x86-64

pyqrack_complex128-1.76.0-py3-none-macosx_15_0_arm64.whl (1.9 MB view details)

Uploaded Python 3macOS 15.0+ ARM64

pyqrack_complex128-1.76.0-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_complex128-1.76.0.tar.gz.

File metadata

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

File hashes

Hashes for pyqrack_complex128-1.76.0.tar.gz
Algorithm Hash digest
SHA256 ec5f4c40c4b47542cf2009cb26e249a181514913b91c9fc375771aaa6ea6c40b
MD5 7b8980a77e0011cb94f601bcf1dde23d
BLAKE2b-256 1c8d792ca4292d221d04b539840d227e805fff67d218826d80ceffd8ba0fff41

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.76.0-py3-none-win_amd64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.76.0-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 e76a7161863df33a27e3144de3d4843fbf50c413658056cfe956dbe5db67cd93
MD5 f033116bce6da7156c2386a342d3e527
BLAKE2b-256 e06219cbdac5f7c3e3e39404504eeb5551832c84b3a19f884ee7b2f9704b7758

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.76.0-py3-none-manylinux_2_39_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.76.0-py3-none-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 fb3f012a5df436f41c2bba225576bdf19672b250dba898cf2a8b3f2df4908ebf
MD5 27834f62fc4f900c2af79499797674f8
BLAKE2b-256 377d01b60ac57efd743565a2ec1b76e612f443cf96a7b97ca6065a32cfc0dd50

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.76.0-py3-none-manylinux_2_35_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.76.0-py3-none-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 4dfa49d2d6b401070f931140d12d9c57678c58683d433f6bff683fe1e9631079
MD5 97250e8103c663d22350d451a2393800
BLAKE2b-256 a778ff11b4c3558ba059d281c1b484105909318b7e1c8f9a2785169f3535c795

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.76.0-py3-none-macosx_15_0_x86_64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.76.0-py3-none-macosx_15_0_x86_64.whl
Algorithm Hash digest
SHA256 1a5b07d2e67bcc79059df9615ca38e2e63a553e08b39cb21fd9cdae703eb96ff
MD5 7ed8849fa24b73fb67cfe6b72c53e57d
BLAKE2b-256 1bf587e96b856c41fae26bc56de58ec51a2c2c84404426c84cb18a80e8e80d97

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.76.0-py3-none-macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.76.0-py3-none-macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 f175b72ca338c2c588bcb1af7e9c6b86c23d07e85f186c9a96f129571bc30a6a
MD5 82b6a1598c705cf5db033071019f0325
BLAKE2b-256 5011d0340597ad287a6466d5a54e2c8ba0dd1e46d26886e33a9292cea9e1037b

See more details on using hashes here.

File details

Details for the file pyqrack_complex128-1.76.0-py3-none-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for pyqrack_complex128-1.76.0-py3-none-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 55337f62eeabb7b6dc1dc78c2eec960368eba3b6e69c331127345c788a592506
MD5 7cf2784f66ecbd6111483cf258146c1f
BLAKE2b-256 f8d665884b0b8f68473eabe0bab476112d013664c8ba43790b9171e64e559a68

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