Skip to main content

pyqrack - Pure Python vm6502q/qrack Wrapper

Project description

pyqrack

Downloads Downloads

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

(PyQrack is just pure Qrack.)

IMPORTANT: You must build and install vm6502q/qrack to use this main branch. CI/CD builds wheels that contain pre-compiled Qrack binaries, and that is the form published on PyPi. You must also install OpenCL.

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 vm6502q/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).

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-1.30.28.tar.gz (33.3 kB view hashes)

Uploaded Source

Built Distributions

pyqrack-1.30.28-py3-none-win_amd64.whl (880.6 kB view hashes)

Uploaded Python 3 Windows x86-64

pyqrack-1.30.28-py3-none-manylinux_2_39_x86_64.whl (2.8 MB view hashes)

Uploaded Python 3 manylinux: glibc 2.39+ x86-64

pyqrack-1.30.28-py3-none-manylinux_2_35_x86_64.whl (2.8 MB view hashes)

Uploaded Python 3 manylinux: glibc 2.35+ x86-64

pyqrack-1.30.28-py3-none-manylinux_2_31_x86_64.whl (2.7 MB view hashes)

Uploaded Python 3 manylinux: glibc 2.31+ x86-64

pyqrack-1.30.28-py3-none-macosx_14_0_arm64.whl (1.5 MB view hashes)

Uploaded Python 3 macOS 14.0+ ARM64

pyqrack-1.30.28-py3-none-macosx_13_0_x86_64.whl (2.2 MB view hashes)

Uploaded Python 3 macOS 13.0+ x86-64

pyqrack-1.30.28-py3-none-macosx_12_0_x86_64.whl (2.1 MB view hashes)

Uploaded Python 3 macOS 12.0+ x86-64

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page