A python-to-quantum compiler
Project description
Qlasskit
Qlasskit is a Python library that allows quantum developers to write classical algorithms in pure Python and translate them into unitary operators (gates) for use in quantum circuits, using boolean expressions as intermediate form.
This tool will be useful for any algorithm that relies on a 'blackbox' function and for describing the classical components of a quantum algorithm.
Qlasskit implements circuit / gate exporters for Qiskit, Cirq, Qasm, Sympy and Pennylane.
Qlasskit also support exporting to Binary Quadratic Models (bqm, ising and qubo) ready to be used in quantum annealers, ising machines, simulators, etc.
pip install qlasskit
For a quickstart, read the quickstart and examples notebooks from the documentation: https://dakk.github.io/qlasskit.
from qlasskit import qlassf, Qint
@qlassf
def h(k: Qint[4]) -> bool:
h = True
for i in range(4):
h = h and k[i]
return h
Qlasskit will take care of translating the function to boolean expressions, simplify them and translate to a quantum circuit.
Then, we can use grover to find which h(k) returns True:
from qlasskit.algorithms import Grover
algo = Grover(h, True)
qc = algo.circuit().export("circuit", "qiskit")
And that's the result:
Qlasskit also offers type abstraction for encoding inputs and decoding results:
counts_readable = algo.decode_counts(counts)
plot_histogram(counts_readable)
You can also use other functions inside a qlassf:
@qlassf
def equal_8(n: Qint[4]) -> bool:
return equal_8 == 8
@qlassfa(defs=[equal_8])
def f(n: Qint[4]) -> bool:
n = n+1 if equal_8(n) else n
return n
Qlasskit supports complex data types, like tuples and fixed size lists:
@qlassf
def f(a: Tuple[Qint[8], Qint[8]]) -> Tuple[bool, bool]:
return a[0] == 42, a[1] == 0
@qlassf
def search(alist: Qlist[Qint[2], 4], to_search: Qint[2]):
for x in alist:
if x == to_search:
return True
return False
Qlasskit function can be parameterized, and the parameter can be bind before compilation:
@qlassf
def test(a: Parameter[bool], b: bool) -> bool:
return a and b
qf = test.bind(a=True)
Contributing
Read CONTRIBUTING for details.
License
This software is licensed with Apache License 2.0.
Cite
@software{qlasskit2023,
author = {Davide Gessa},
title = {qlasskit: a python-to-quantum circuit compiler},
url = {https://github.com/dakk/qlasskit},
year = {2023},
}
About the author
Davide Gessa (dakk)
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
Built Distribution
File details
Details for the file qlasskit-0.1.34.tar.gz
.
File metadata
- Download URL: qlasskit-0.1.34.tar.gz
- Upload date:
- Size: 62.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bacae7fc7f44184fdf031a97f952fe213b7f12eadc720cd2b382d012a034218f |
|
MD5 | 88f5d76aaa781021d96a77727109f8a3 |
|
BLAKE2b-256 | 9ac7c00fbaa3faaebf21a02e622a0d8956a25024b1cee0c70ee650448a42b34c |
File details
Details for the file qlasskit-0.1.34-py3-none-any.whl
.
File metadata
- Download URL: qlasskit-0.1.34-py3-none-any.whl
- Upload date:
- Size: 95.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 69c749b2660868995b2ed3dde2aa587ab338466ff897a4810dec078fd6b84034 |
|
MD5 | f284f395a7a80a6d2df3edd9094aa219 |
|
BLAKE2b-256 | 6920334ce0d9a8435df4c41ad8f25c3b9c4ae03372eadfa40ff26776c7ed3844 |