No project description provided
Project description
MatchCake
Description
MatchCake is a Python package that provides a new PennyLane device for simulating a specific class of quantum circuits called Matchgate circuits or matchcircuits. These circuits are made with matchgates, a class of restricted quantum unitaries that are parity-preserving and operate on nearest-neighbor qubits. These constraints lead to matchgates being classically simulable in polynomial time.
Additionally, this package provides quantum kernels made with scikit-learn API allowing the use matchcircuits as kernels in quantum machine learning algorithms. One way to use these kernels could be in a Support Vector Machine (SVM).
Note that this package is built on PennyLane and PyTorch. This means that only the NumPy and PyTorch backends are compatible. Other backends provided by Autoray, such as JAX and TensorFlow, are not supported. We highly recommend using PyTorch as the backend when working with MatchCake.
Installation
| Method | Commands |
|---|---|
| poetry | poetry add matchcake |
| uv | uv add matchcake |
| PyPi | pip install MatchCake |
| source | pip install git+https://github.com/MatchCake/MatchCake |
Last unstable version
To install the latest unstable version, download the latest version from https://github.com/MatchCake/MatchCake@dev.
CUDA installation
To use MatchCake with cuda, you can add --extra cu128 to the installation commands above.
This will install pytorch with CUDA 12.8.
Extra options:
--extra cpu: Install MatchCake with PyTorch CPU only.--extra cu128: Install MatchCake with PyTorch CUDA 12.8.--extra cu130: Install MatchCake with PyTorch CUDA 13.0.
Quick Usage Preview
Quantum Circuit Simulation with MatchCake
import matchcake as mc
import pennylane as qml
import numpy as np
from pennylane.ops.qubit.observables import BasisStateProjector
# Create a Non-Interacting Fermionic Device
nif_device = mc.NonInteractingFermionicDevice(wires=4)
initial_state = np.zeros(len(nif_device.wires), dtype=int)
# Define a quantum circuit
def circuit(params, wires, initial_state=None):
qml.BasisState(initial_state, wires=wires)
for i, even_wire in enumerate(wires[:-1:2]):
idx = list(wires).index(even_wire)
curr_wires = [wires[idx], wires[idx + 1]]
mc.operations.CompRxRx(params, wires=curr_wires)
mc.operations.CompRyRy(params, wires=curr_wires)
mc.operations.CompRzRz(params, wires=curr_wires)
for i, odd_wire in enumerate(wires[1:-1:2]):
idx = list(wires).index(odd_wire)
mc.operations.fSWAP(wires=[wires[idx], wires[idx + 1]])
projector: BasisStateProjector = qml.Projector(initial_state, wires=wires)
return qml.expval(projector)
# Create a QNode
nif_qnode = qml.QNode(circuit, nif_device)
qml.draw_mpl(nif_qnode)(np.array([0.1, 0.2]), wires=nif_device.wires, initial_state=initial_state)
# Evaluate the QNode
expval = nif_qnode(np.random.random(2), wires=nif_device.wires, initial_state=initial_state)
print(f"Expectation value: {expval}")
Data Classification with MatchCake
from matchcake.ml.kernels import FermionicPQCKernel
from matchcake.ml.visualisation import ClassificationVisualizer
from sklearn import datasets
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import MinMaxScaler
from sklearn.pipeline import Pipeline
from sklearn.svm import SVC
# Load the iris dataset
X, y = datasets.load_iris(return_X_y=True)
x_train, x_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=0)
# Create and fit the model
pipeline = Pipeline([
('scaler', MinMaxScaler(feature_range=(0, 1))),
('kernel', FermionicPQCKernel(n_qubits=4, rotations="X,Z").freeze()),
('classifier', SVC(kernel='precomputed')),
])
pipeline.fit(x_train, y_train)
# Evaluate the model
test_accuracy = pipeline.score(x_test, y_test)
print(f"Test accuracy: {test_accuracy * 100:.2f}%")
# Visualize the classification
viz = ClassificationVisualizer(x=X, n_pts=1_000)
viz.plot_2d_decision_boundaries(model=pipeline, y=y, show=True)
Tutorials
- MatchCake Basics
- Compute Expectation Values with MatchCake
- Iris Classification with MatchCake
- Nystroem Kernel Approximation
Notes
- This package is still in development and some features may not be available yet.
- The documentation is still in development and may not be complete yet.
About
This work was supported by the Ministère de l'Économie, de l'Innovation et de l'Énergie du Québec through its Research Chair in Quantum Computing, an NSERC Discovery grant, and the Canada First Research Excellence Fund.
Important Links
- Documentation at https://MatchCake.github.io/MatchCake/.
- Github at https://github.com/MatchCake/MatchCake/.
Found a bug or have a feature request?
License
Citation
Repository:
@misc{matchcake_Gince2023,
title={MatchCake},
author={Jérémie Gince},
year={2023},
publisher={Université de Sherbrooke},
url={https://github.com/MatchCake/MatchCake},
}
Fermionic Machine Learning Paper
Fermionic Machine Learning is a work presented at the 2024 IEEE International Conference on Quantum Computing and Engineering (QCE). The paper compares unconstrained quantum kernel methods with constraint-based kernels derived from matchgate (free-fermionic) circuits, and benchmarks their performance on supervised classification tasks. All free-fermionic kernels considered in this work were simulated using MatchCake.
@INPROCEEDINGS{10821385,
author={Gince, Jérémie and Pagé, Jean-Michel and Armenta, Marco and Sarkar, Ayana and Kourtis, Stefanos},
booktitle={2024 IEEE International Conference on Quantum Computing and Engineering (QCE)},
title={Fermionic Machine Learning},
year={2024},
volume={01},
number={},
pages={1672-1678},
keywords={Runtime;Quantum entanglement;Computational modeling;Benchmark testing;Rendering (computer graphics);Hardware;Kernel;Integrated circuit modeling;Quantum circuit;Standards;Quantum machine learning;quantum kernel methods;matchgate circuits;fermionic quantum computation;data classification},
doi={10.1109/QCE60285.2024.00195}
}
@misc{gince2024fermionic,
title={Fermionic Machine Learning},
author={Jérémie Gince and Jean-Michel Pagé and Marco Armenta and Ayana Sarkar and Stefanos Kourtis},
year={2024},
eprint={2404.19032},
archivePrefix={arXiv},
primaryClass={quant-ph}
}
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 matchcake-0.2.2.tar.gz.
File metadata
- Download URL: matchcake-0.2.2.tar.gz
- Upload date:
- Size: 105.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
402e6b477f74a97717a6658c1af7984b6d434a4ab0bbd2b9dc528a3a10cc274b
|
|
| MD5 |
cb289f8e71baed986df8496b42938fbe
|
|
| BLAKE2b-256 |
c709a09598a4a7095c4ba271ff46245fcbaef9e942e6b9f60235624cf61c8158
|
Provenance
The following attestation bundles were made for matchcake-0.2.2.tar.gz:
Publisher:
build_dist.yml on MatchCake/MatchCake
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
matchcake-0.2.2.tar.gz -
Subject digest:
402e6b477f74a97717a6658c1af7984b6d434a4ab0bbd2b9dc528a3a10cc274b - Sigstore transparency entry: 972054144
- Sigstore integration time:
-
Permalink:
MatchCake/MatchCake@11d68775b0addc5ec8d2f9c1ee6ce56a33678b1d -
Branch / Tag:
refs/heads/main - Owner: https://github.com/MatchCake
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build_dist.yml@11d68775b0addc5ec8d2f9c1ee6ce56a33678b1d -
Trigger Event:
push
-
Statement type:
File details
Details for the file matchcake-0.2.2-py3-none-any.whl.
File metadata
- Download URL: matchcake-0.2.2-py3-none-any.whl
- Upload date:
- Size: 141.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
217417150927671fe1ff48132b1e90053dc018385c371217731efff52cb68acf
|
|
| MD5 |
47d1a27e06d226f646bb30ded3054e1b
|
|
| BLAKE2b-256 |
30f86ec1850f87f0bfeb8e402eb64b5af5a5e8551fa30a8648268d0ef119771a
|
Provenance
The following attestation bundles were made for matchcake-0.2.2-py3-none-any.whl:
Publisher:
build_dist.yml on MatchCake/MatchCake
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
matchcake-0.2.2-py3-none-any.whl -
Subject digest:
217417150927671fe1ff48132b1e90053dc018385c371217731efff52cb68acf - Sigstore transparency entry: 972054196
- Sigstore integration time:
-
Permalink:
MatchCake/MatchCake@11d68775b0addc5ec8d2f9c1ee6ce56a33678b1d -
Branch / Tag:
refs/heads/main - Owner: https://github.com/MatchCake
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build_dist.yml@11d68775b0addc5ec8d2f9c1ee6ce56a33678b1d -
Trigger Event:
push
-
Statement type: