Optimal Circuit Layout Synthesis, CNOT (Re)Synthesis, and Clifford (Re)Synthesis, based on Classical Planning, SAT, and QBF Solving
Project description
Quantum-Circuit Synthesis - Q-Synth v5.1
A state-of-the-art, open-source, optimal quantum circuit synthesis tool. This tool provides three main functionalities:
- Optimal Layout Synthesis,
- Optimal CNOT (Re)Synthesis, and
- Optimal Clifford (Re)Synthesis.
Key Features
- Layout Synthesis with Classical Planning and SAT, optimizing CNOT-count/depth (v1.0, v2.0, v4.0).
- Layout aware CNOT (Re)Synthesis with Planning, SAT and QBF, optimizing CNOT-count/depth (v3.0).
- Layout aware Clifford (Re)Synthesis with SAT, optimizing CNOT-count/depth (v5.0).
- CNOT and Clifford re-synthesis can be applied to slices in a peephole synthesis (v3.0, v5.0)
- Scalable layout synthesis for large platforms via maximal subarchitectures (v4.0).
- All efficient synthesis features based on SAT are available via an API (with simple pip-installation, v5.1).
- Additional features with planning and QBF are available via the command line interface.
Getting started
Q-Synth can be installed using pip:
Recommended: Please use a fresh python virtual environment.
pip install Q-Synth
Layout Synthesis
For layout synthesis through the API, simply call layout_synthesis with your circuit (as a qiskit QuantumCircuit) and a coupling graph as input. For example:
from qsynth import get_coupling_graph, layout_synthesis
from qiskit import QuantumCircuit
# An example bidirectional coupling graph
coupling_graph = get_coupling_graph(coupling_graph=[[0,1],[1,2]], bidirectional=1)
qc = QuantumCircuit(3)
qc.cx(0,1)
qc.s(0)
qc.cx(0,2)
qc.cx(1,2)
mapped_result = layout_synthesis(circuit=qc, coupling_graph=coupling_graph, metric="cx-count", verbose=-1) # silent mode
print(mapped_result.circuit)
print(mapped_result.initial_mapping)
print(mapped_result.final_mapping)
mapped_result.circuit contains the mapped circuit with provably optimal swap count,
mapped_result.initial_mapping contains the initial mapping,
and mapped_result.final_mapping stores the output qubit permutation.
Peephole Synthesis with CNOT and Clifford (Re)Synthesis
Q-Synth can re-synthesize each CNOT/Clifford sub-circuit in a peephole manner to reduce the CNOT count or depth, while still respecting the layout constraints.
For example, we can easily resynthesize our mapped result circuit using peephole synthesis with CNOT slicing using:
from qsynth import peephole_synthesis
opt_result = peephole_synthesis(circuit=mapped_result.circuit, coupling_graph=coupling_graph, slicing="cnot", metric="cx-count")
opt_result.circuit contains the resynthesized circuit with 5 CNOTs instead of 6 without any extra single qubit gates.
Clifford slicing allows resynthesis of even larger sub-circuits with possible further reductions. Simply use slicing="clifford" in peephole_synthesis to enables this.
opt_result = peephole_synthesis(circuit=mapped_result.circuit, coupling_graph=coupling_graph, slicing="clifford", metric="cx-count")
opt_result.circuit now only has 4 CNOTs, but with some additional single qubit gates.
Tutorial and Command-line tools
Q-Synth also supports several other features such as optimizing for CNOT depth, using subarchitectures, qubit permutations, and more. Please refer to tutorials in Jupyter Notebook for more examples.
More features are available via the command line interface, for instance those based on classical planning and QBF solvers.
Please see the Installation Instructions in INSTALL_CLI.md.
Detailed descriptions of the command-line tools are available in README_CLI_layout.md and
README_CLI_cnot.md and
README_CLI_clifford.md.
Publications
Please refer to this publication for Layout-Synthesis based on classical-planning (v1.0):
I. Shaik, J. van de Pol, Optimal Layout Synthesis for Quantum Circuits as Classical Planning.
In: Proc. IEEE/ACM IC on Computer-Aided Design, (ICCAD'23), San Francisco, California, USA, 2023.
@inproceedings{ShaikvdP2023,
author = {Irfansha Shaik and Jaco van de Pol},
title = {Optimal Layout Synthesis for Quantum Circuits as Classical Planning},
booktitle = {{ICCAD'23}},
address = {{San Diego, California, USA}},
organization = {{IEEE/ACM}},
year = {2023}
}
Please refer to this publication for Layout-Synthesis based on SAT encoding (v2.0):
I. Shaik, J. van de Pol, Optimal layout synthesis for deep quantum circuits on NISQ processors with 100+ qubits.
In: Proc. 27th IC on Theory and Applications of Satisfiability Testing (SAT'24), Pune, India, 2024.
@article{shaikvdP2024layoutsynthesis,
author = {Irfansha Shaik and Jaco van de Pol},
title = {Optimal Layout Synthesis for Deep Quantum Circuits on {NISQ} Processors with 100+ Qubits},
booktitle = {27th IC on Theory and Applications of Satisfiability
Testing, {SAT} 2024, August 21-24, 2024, Pune, India},
series = {LIPIcs},
publisher = {Schloss Dagstuhl - Leibniz-Zentrum f{\"{u}}r Informatik},
year = {2024}
}
Please refer to this publication for CNOT synthesis (based on Planning, SAT and QBF) (v3.0):
I. Shaik, J. van de Pol, Optimal Layout-Aware CNOT Circuit Synthesis with Qubit Permutation.
In: Proc. 27th European Conference on Artificial Intelligence, (ECAI'24), Santiago de Compostela, Spain, 2024.
@inproceedings{ShaikvdP2024cnotsynthesis,
author = {Irfansha Shaik and Jaco van de Pol},
title = {Optimal Layout-Aware CNOT Circuit Synthesis with Qubit Permutation},
booktitle = {{ECAI'24}},
address = {{Santiago de Compostela, Spain}},
publisher = {IOS Press},
year = {2024}
}
Please refer to this publication for Depth-Optimal Synthesis (v4.0):
A. B. Clausen, A. B. Jakobsen, J. van de Pol, I. Shaik, Depth-Optimal Quantum Layout Synthesis as SAT.
In: Proc. 28th IC on Theory and Applications of Satisfiability Testing (SAT'25), Glasgow, Scotland, UK, 2025.
@article{Jakobsen2025depthoptimal,
author = {Anna Blume Jakobsen, Anders Benjamin Clausen, Jaco van de Pol and Irfansha Shaik},
title = {Depth-Optimal Quantum Layout Synthesis as SAT},
booktitle = {28th IC on Theory and Applications of Satisfiability
Testing, {SAT} 2025, August 12-15, 2025, Glasgow, Scotland},
series = {LIPIcs},
publisher = {Schloss Dagstuhl - Leibniz-Zentrum f{\"{u}}r Informatik},
year = {2025}
}
Depth-Optimal Synthesis was ported from GitHub repository QuilLS.
Please refer to this publication for Sub-Architectures (v4.0):
K. Milkevych, J. van de Pol, I. Shaik, Practical Subarchitectures for Optimal Quantum Layout Synthesis.
In: arXiv [quant-ph] 2507.12976, 2025.
@techreport{Kostyantin2025,
title = {Practical Subarchitectures for Optimal Quantum Layout Synthesis},
author = {Kostiantyn V. Milkevych and Jaco van de Pol and Irfansha Shaik},
eprint = {2507.12976},
archivePrefix = {arXiv},
primaryClass = {quant-ph},
year = {2025}
}
Please refer to this publication for CNOT-Optimal Clifford synthesis (v5.0):
I. Shaik, J. van de Pol, CNOT-Optimal Clifford Synthesis as SAT. In: Proc. 28th IC on Theory and Applications of Satisfiability Testing (SAT'25), Glasgow, Scotland, UK, 2025.
@article{shaikvdP2025cliffordsynthesis,
author = {Irfansha Shaik and Jaco van de Pol},
title = {CNOT-Optimal Clifford Synthesis as SAT},
booktitle = {28th IC on Theory and Applications of Satisfiability
Testing, {SAT} 2025, August 12-15, 2025, Glasgow, Scotland},
series = {LIPIcs},
publisher = {Schloss Dagstuhl - Leibniz-Zentrum f{\"{u}}r Informatik},
year = {2025}
}
Limitations
Q-Synth has some assumptions about the input circuits:
- The input should only contain unary gates and binary CNOT gates.
- We currently do not handle multiple quantum registers in the input circuit.
The scripts are tested on Linux and macOS.
Copyright
(C) CC-BY Irfansha Shaik, Jaco van de Pol, Aarhus University, 2023, 2024, 2025
Contributors
- Irfansha Shaik (Aarhus University, Kvantify)
- Jaco van de Pol (Aarhus University)
- Anna Blume Jakobsen (depth-optimal layout mapping)
- Anders B. Clausen (depth-optimal layout mapping)
- Kostiantyn Milkevych (subarchitectures, testing)
Project details
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_synth-5.0.19.tar.gz.
File metadata
- Download URL: q_synth-5.0.19.tar.gz
- Upload date:
- Size: 116.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d9730918ca07fa20a8f83c51a0f6853316da7110930d9a90d91659a0e36e088c
|
|
| MD5 |
b105b645e9dd79dbc0685e491c584170
|
|
| BLAKE2b-256 |
96119aefc5df5fe061c48c47c9cb5ed7d6543db40133ccb274a0a07fcd6eb949
|
File details
Details for the file q_synth-5.0.19-py3-none-any.whl.
File metadata
- Download URL: q_synth-5.0.19-py3-none-any.whl
- Upload date:
- Size: 154.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dd2351d3680937fc90f051faf4c004f6619e6e18b84728f06b4dc8ea74ac55c8
|
|
| MD5 |
838ecfaac457904011a6ba8615364ae2
|
|
| BLAKE2b-256 |
39af08449259a1f034dd89d42dec29202329651208ab9821285e927013d1fa95
|