No project description provided
Project description
Q-Alchemy Python SDK
This is the Python-SDK for using the data cybernetics Q-Alchemy API which helps quantum computing researchers to put classical data into the quantum computer. This is all also called: the loading problem, encoding problem, or quantum state preparation. Some people also call it a form of QRAM, or quantum random-access memory.
This SDK builds upon the Hypermedia-Siren API of data cybernetics which uses a document-first approach added with actions. The standardized way makes the API programmatically accessible, which can be explored by the Hypermedia-Test-UI
The SDK builds upon this, so that any software developer planning to integrate with the API and experience the API through the UI and the SDK in a very similar fashion. Also, any GUI around this has similar characteristics.
Installation
We have decided not to go through pypi, but you can install this through pip or poetry nonetheless
pip install q-alchemy-sdk-py
If you want to use the qiskit-integration, please use
pip install q-alchemy-sdk-py[qiskit]
And if you want the PennyLane-integration, please use
pip install q-alchemy-sdk-py[pennylane]
We use python-pdm and have tested this all with Python 3.11 or higher (but less than 4!). So the way to install it after cloning is simply
pdm install
Again, for qiskit- or PennyLane-integrations, please add the groups
pdm install -G qiskit -G pennylane
Or whatever combination you need. Currently, the PennyLane-integration is dependent on the qiskit-integration... what a fallacy! We will -- of course -- fix this soon!
Usage
There are examples under the /examples folder, but for those that are eager to find out, here it is.
First, you will want to get an API key from the Q-Alchemy Portal. You
need to sign up for this, sorry, but this is necessary. Once you have the API key (free of charge of course)
you can test it!
Direct Example
import numpy as np
from sklearn.datasets import fetch_openml
from q_alchemy.initialize import q_alchemy_as_qasm
mnist = fetch_openml('mnist_784', version=1, parser="auto")
zero: np.ndarray = mnist.data[mnist.target == "0"].iloc[0].to_numpy()
filler = np.empty(2 ** 10 - zero.shape[0])
filler.fill(0)
zero = np.hstack([zero, filler])
zero = zero / np.linalg.norm(zero)
qasm, summary = q_alchemy_as_qasm(zero, max_fidelity_loss=0.2, api_key="<your api key>", return_summary=True)
print(summary)
Qiskit Example
import numpy as np
from sklearn.datasets import fetch_openml
from q_alchemy.qiskit_integration import QAlchemyInitialize, OptParams
mnist = fetch_openml('mnist_784', version=1, parser="auto")
zero: np.ndarray = mnist.data[mnist.target == "0"].iloc[0].to_numpy()
filler = np.empty(2 ** 10 - zero.shape[0])
filler.fill(0)
zero = np.hstack([zero, filler])
zero = zero / np.linalg.norm(zero)
instr = QAlchemyInitialize(
params=zero.tolist(),
opt_params=OptParams(
max_fidelity_loss=0.1,
basis_gates=["id", "rx", "ry", "rz", "cx"],
api_key="<your api key>"
)
)
instr.definition.draw(fold=-1)
PennyLane Example
import numpy as np
import pennylane as qml
from sklearn.datasets import fetch_openml
from q_alchemy.pennylane_integration import QAlchemyStatePreparation, OptParams
mnist = fetch_openml('mnist_784', version=1, parser="auto")
zero: np.ndarray = mnist.data[mnist.target == "0"].iloc[0].to_numpy()
filler = np.empty(2 ** 10 - zero.shape[0])
filler.fill(0)
zero = np.hstack([zero, filler])
zero = zero / np.linalg.norm(zero)
dev = qml.device('lightning.qubit', wires=10)
@qml.qnode(dev)
def circuit(state=None):
QAlchemyStatePreparation(
state,
wires=range(10),
opt_params=OptParams(
max_fidelity_loss=0.1,
basis_gates=["id", "rx", "ry", "rz", "cx"],
api_key="<your api key>"
)
)
return qml.state()
print(qml.draw(circuit, level="device", max_length=100)(zero.tolist()))
Broadcasting with PennyLane
PennyLane provides native support for broadcasting, which allows quantum nodes to process batches of inputs efficiently. This is particularly useful in machine learning applications where inputs often come in batches. When broadcasting is used in conjunction with Q-Alchemy, each state in the batch is individually prepared using Q-Alchemy's circuit synthesis capabilities.
⚠️ Note: For simulators or backends that support native state initialization using the
StatePrepgate—such asdefault.qubit, andlightning.qubit—the state vector is injected directly without any decomposition into quantum gates. In this case, Q-Alchemy is not used. This behavior is ideal for rapid prototyping and testing. Switching to a hardware backend (or one without native state prep) will automatically invoke Q-Alchemy for state preparation.
Broadcasting Example with qiskit.aer
import numpy as np
import pennylane as qml
import torch
from q_alchemy.pennylane_integration import AmplitudeEmbedding, OptParams
from sklearn.datasets import make_moons
# Sample data
X, _ = make_moons(n_samples=5, noise=0.1)
X = X / np.linalg.norm(X, axis=1, keepdims=True) # Normalize each row for amplitude embedding
# Create PennyLane device
dev = qml.device("qiskit.aer", wires=1)
@qml.qnode(dev, interface="torch")
def circuit(x):
AmplitudeEmbedding(
x,
wires=[0],
opt_params=OptParams(
max_fidelity_loss=0.0,
api_key="<your api key>"
)
)
return qml.expval(qml.PauliZ(0))
# Run the circuit on a batch of inputs
X_tensor = torch.tensor(X, dtype=torch.float64)
print(qml.draw(circuit, level="device", max_length=100)(X_tensor))
This example demonstrates how batched data can be processed using broadcasting with AmplitudeEmbedding, and how Q-Alchemy is triggered on simulators like qiskit.aer. When moving to real hardware or gate-based backends that lack StatePrep gate, Q-Alchemy will transparently handle the state preparation.
Developer UI
You can play around with this as you please and check out the Hypermedia-Test-UI for more info!
Contributions
We welcome contributions - simply fork the repository of this plugin, and then make a pull request containing your contribution. All contributers to this plugin will be listed as authors on the releases.
We also encourage bug reports, suggestions for new features and enhancements!
Authors
Carsten Blank
License
The q-alchemy-sdk-py is free and open source, released under the Apache License, Version 2.0.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file q_alchemy_sdk_py-0.2.21.tar.gz.
File metadata
- Download URL: q_alchemy_sdk_py-0.2.21.tar.gz
- Upload date:
- Size: 48.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.23.1 CPython/3.11.11 Linux/6.8.0-59-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9818392d9ce6464535469a4182d9eac1744e56ce1352b273964678c344006864
|
|
| MD5 |
8af351ee6b3b1c88229a0e739fc23dcc
|
|
| BLAKE2b-256 |
6cc10254203d0fedbc6505e7955c416d7335fd164a35e5e9e9c08fd10ad3b3a0
|
File details
Details for the file q_alchemy_sdk_py-0.2.21-py3-none-any.whl.
File metadata
- Download URL: q_alchemy_sdk_py-0.2.21-py3-none-any.whl
- Upload date:
- Size: 19.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.23.1 CPython/3.11.11 Linux/6.8.0-59-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5d5dbfc51561c72c32ac8712a33536b3bfa90dc85adc2dbab16b7d76145dd6a6
|
|
| MD5 |
465b7a29fc80415ba62770a2cd8b47e7
|
|
| BLAKE2b-256 |
42ead741ff7466db3400e49522e4f1ee1ca4a285a3531dd0fb55cd4ed95ff0e9
|