Skip to content

Latest commit

 

History

History
73 lines (49 loc) · 3.75 KB

File metadata and controls

73 lines (49 loc) · 3.75 KB
page_type languages author ms.author ms.date products description urlFragment
sample
python
Maximilian Lucassen
4/13/2021
azure-quantum
azure-qio
Solve the traveling salesperson problem with Azure Quantum optimization service
azure-quantum.traveling-salesperson

Solving the traveling salesperson problem with the Azure Quantum optimization service

Introduction

This sample provides a comprehensive walkthrough of the traveling salesperson problem, from problem definition to formulation of penalty functions and finally solving the problem using the Azure Quantum Optimization Service.

By working through this sample, you will learn:

  • How to solve the traveling salesperson problem with Azure Quantum
  • Model the problem mathematically to design objective and penalty functions
  • Coding of the optimization problem using the Azure Quantum Optimization Python SDK
  • Verifying results returned by the solver
  • Tips and references to help you choose solver settings

Please note this sample is intended to demonstrate how to formulate the cost function for a well-understood problem mathematically and then map it to a binary QUBO/PUBO format. The Traveling Salesperson Problem is not a good example of a problem that scales well in this format, as detailed in this paper.

Prerequisites

  1. Create an Azure Quantum Workspace
  2. Install the azure-quantum Python module
  3. (If you want to run the Jupyter notebook) Install Jupyter Notebook
  4. (Optional) Run the basic ship loading sample

Running the sample

There are two ways to run the sample (.ipynb and .py):

A html file of the Jupyter notebook is attached for improved readability:

Example of html readable format

Running the Jupyter Notebook

To run this sample, use the commandline to navigate to the traveling-salesperson folder and run jupyter notebook

Your web browser should automatically open a new window showing something similar to the below:

Jupyter Notebook landing page

If this doesn't happen, copy the localhost link shown in the terminal window and paste it into your browser's address bar.

Once you see the page above, simply click on the traveling-salesperson.ipynb link to open the sample notebook.

Running the Python script

  • Open up the traveling-salesperson.py script using your favorite IDE or a text editor.
  • Fill in your Azure Quantum workspace details at the beginning of the script.
  • Run the script through your IDE or use the commandline to navigate to the traveling-salesperson folder and then run python ./traveling-salesperson.py or python3 ./traveling-salesperson.py (depending on how your environment is set up).

Manifest