Skip to main content

MQT Quantum Auto Optimizer: Automatic Framework for Solving Optimization Problems with Quantum Computers

Project description

PyPI OS License: MIT CI CD Documentation codecov

MQT Quantum Auto Optimizer: Automatic Framework for Solving Optimization Problems with Quantum Computers

MQT Quantum Auto Optimizer is a framework that allows one to automatically translate an optimization problem into a quantum-compliant formulation and to solve it with one of the main quantum solvers (Quantum Annealer, Quantum Approximate Optimization Algorithm, Variational Quantum Eigensolver and Grover Adaptive Search)

MQT Quantum Auto Optimizer is part of the Munich Quantum Toolkit (MQT) developed by the Chair for Design Automation at the Technical University of Munich. This framework has been developed in collaboration with the VLSI Lab of Politecnico di Torino.

If you have any questions, feel free to create a discussion or an issue on GitHub.

Getting Started

mqt-qao is available via PyPI.

(venv) $ pip install mqt.qao

The following code gives an example on the usage:

from mqt.qao import Constraints, ObjectiveFunction, Problem, Solver, Variables

# Declaration of the problem variables
var = Variables()
a = var.add_binary_variable("a")
b = var.add_discrete_variable("b", [-1, 1, 3])
c = var.add_continuous_variable("c", -2, 2, 0.25)

# declaration of the objective functions involved in the problem
obj_func = ObjectiveFunction()
obj_func.add_objective_function(a + b * c + c**2)

# Declaration of the constraints
cst = Constraints()
cst.add_constraint("b + c >= 2", variable_precision=True)

# Creation of the problem
prb = Problem()
prb.create_problem(var, cst, obj_func)

# Solve the problem with the Dwave Quantum Annealer
solution = Solver().solve_Dwave_quantum_annealer(prb, token=token)

Detailed documentation and examples are available at ReadTheDocs.

References

In case you are using the MQT Quantum Auto Optimizer in your work, we would be thankful if you referred to it by citing the following publications:

@INPROCEEDINGS{volpe2024towards,
	AUTHOR        = {D. Volpe and N. Quetschlich and M. Graziano and G. Turvani and R. Wille},
	TITLE         = {{Towards an Automatic Framework for Solving Optimization Problems with Quantum Computers}},
	YEAR          = {2024},
	BOOKTITLE     = {IEEE International Conference on Quantum Software (QSW)},
	EPRINT        = {2406.12840},
	PRIMARYCLASS  = {quant-ph},
	ARCHIVEPREXIX = {arxiv},
}

@INPROCEEDINGS{volpe2024predictive,
	AUTHOR        = {D. Volpe and N. Quetschlich and M. Graziano and G. Turvani and R. Wille},
	TITLE         = {{A Predictive Approach for Selecting the Best Quantum Solver for an Optimization Problem}},
	YEAR          = {2024},
	BOOKTITLE     = {IEEE International Conference on Quantum Computing and Engineering (QCE)},
	EPRINT        = {2408.03613},
	PRIMARYCLASS  = {quant-ph},
	ARCHIVEPREXIX = {arxiv},
}

Acknowledgements

The Munich Quantum Toolkit has been supported by the European Research Council (ERC) under the European Union's Horizon 2020 research and innovation program (grant agreement No. 101001318), the Bavarian State Ministry for Science and Arts through the Distinguished Professorship Program, as well as the Munich Quantum Valley, which is supported by the Bavarian state government with funds from the Hightech Agenda Bayern Plus.

TUM Logo Coat of Arms of Bavaria ERC Logo MQV Logo

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

mqt_qao-0.3.0.tar.gz (1.3 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mqt.qao-0.3.0-py3-none-any.whl (763.2 kB view details)

Uploaded Python 3

File details

Details for the file mqt_qao-0.3.0.tar.gz.

File metadata

  • Download URL: mqt_qao-0.3.0.tar.gz
  • Upload date:
  • Size: 1.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for mqt_qao-0.3.0.tar.gz
Algorithm Hash digest
SHA256 512a292aa35ce08521373abeb4168e669e0f76d419656de23a5900e726f814a5
MD5 d291089a3476fb1cd258c85a19239a27
BLAKE2b-256 2b4c6fd49b0b23b5d8fcd05158df6d727ee601190163585f03df8052eb4caac0

See more details on using hashes here.

Provenance

The following attestation bundles were made for mqt_qao-0.3.0.tar.gz:

Publisher: cd.yml on cda-tum/mqt-qao

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mqt.qao-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: mqt.qao-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 763.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for mqt.qao-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2bc4aee78d22098f6892500c692306209bc7d1d612ba766ae2d31bfe195ac544
MD5 21efa34dcd46f1c6c8e5ab11ca9b97a8
BLAKE2b-256 38a597d5bc8d7255494457a6d50c41fa3d007cb3eb31fb26c74eb6086ae629c1

See more details on using hashes here.

Provenance

The following attestation bundles were made for mqt.qao-0.3.0-py3-none-any.whl:

Publisher: cd.yml on cda-tum/mqt-qao

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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