Build Your Own Multi-Itinerary Optimisation Services
Blog|by Gabrielle Alvear|3 June 2024
Make Your Own Multi-Itinerary Optimisation (MIO): Streamling Routes with Location Intelligence
When it comes to logistics and route planning, efficiency is paramount. That's where multi-itinerary optimisation comes in. Whether you're managing delivery fleets, organising field service visits, or optimising travel routes, solving the Traveling Salesman Problem (TSP) and the Vehicle Routing Problem (VRP) is central to achieving streamlined operations.
In this comprehensive guide, we'll explore how to build an itinerary optimisation service on Bing Maps and Azure Maps, using an open-source optimiser library and an array of distance matrix between a set of origins and destinations. An http trigger is created using Azure Function to create an API on the Microsoft Azure cloud.
By leveraging distance matrices, Azure Functions and cloud APIs, we'll empower your applications to find the most efficient paths, minimise costs, and enhance overall productivity.
Keep reading to see how you can create your own multi-itinerary optimisation service, whether you're using Bing Maps or Azure Maps.
How to get started
Itinerary optimization is a two-step process that requires a travel cost matrix and an optimization engine to find the best outcome. A cost matrix represents the cost of traveling between every two set of locations in the problem. It can be calculated using the Bing Maps Distance Matrix or Azure Maps Route Matrix service.
When requesting the cost matrix, it is necessary to pass all the waypoints as origins and destinations in the input to get travel times between all locations. The optimizer needs to know the cost to traverse between each node to generate the best outcome. For example, a restaurant has 2 drivers and needs to deliver to 5 locations, you would need to input 7 waypoints as origin and 7 waypoints as destination. The matrix should look like the following:
Agent1 | Agent2 | Stop1 | Stop2 | Stop3 | Stop4 | Stop5 | |
Agent1 | 0 | 2 | 5 | 1 | 3 | 1 | 2 |
Agent2 | 4 | 0 | 5 | 6 | 1 | 7 | 3 |
Stop1 | 1 | 2 | 0 | 7 | 8 | 5 | 1 |
Stop2 | 4 | 6 | 5 | 0 | 4 | 1 | 1 |
Stop3 | 2 | 2 | 2 | 1 | 0 | 1 | 2 |
Stop4 | 1 | 1 | 1 | 4 | 4 | 0 | 3 |
Stop5 | 3 | 8 | 5 | 6 | 2 | 1 | 0 |
Prerequisites
Use of the following software and library is required:
- Google OR tools – The solution uses OR tools for the optimiser. The package can be installed from Install OR-Tools. The library used in the solution is OR Tools for Python. This guide is to help you get started with an open-source library. You could use any open-source solution of your choice that best suits your requirements.
- Distance Matrix – You can use Bing Maps Distance Matrix or Azure Maps Route Matrix based on your preference.
- Azure Tools Extension for VS Code – Can be downloaded from Azure Tools.
- Application Insights (optional) – To write logs and monitor your function app for debugging.
- Python 3.11
- Visual Studio Code
Setup
- Download the package using the provided zipped file.
- Install all the required tools and packages. Refer to requirements.txt in the sample. You can run the following command to install the dependencies using the requirements.txt file. pip install-r requirement.txt
- Open the project folder in VS Code and download the Azure Tools in VS Code
- Create Azure function to build an API that returns the travel itinerary for the given set of agents and stops. The code sample implements the vehicle Routing problem for multiple drivers for the best optimal path.
- In MIO.html, find the string “https://miodemo.azurewebsites.net” and replace “miodemo” with the Function App name. For example, if the app name is “optimize”, then the new string will be “https://optimize.azurewebsites.net”
For Bing Maps
- Under the applications settings of the newly created Function app, add the following key-value pairs.
- BME_KEY = <Bing Maps Developer Key, get one for free on Bing Maps Dev Center>
If you want to use Azure Maps Route Matrix API, you will need to create an Azure Maps account to get the subscription key. You will need to modify the bing_maps_api.py and __init__.py in the sample code for the Route Matrix endpoint.
For Azure Maps
In MIO.html, find the string "your-key" and replace it with the Azure Maps subscription key for the app authentication.
- Under the applications settings of the newly created Function app, add the following key-value pairs. To access App settings, login to Microsoft Azure portal >your function app > Settings > Environment variables.
- API_KEY = <Azure Maps Subscription Key> You will need to create an Azure Maps account to get the subscription key if you don’t have an account. This API_KEY will be used to make a request to the Azure Maps Route Matrix API.
- (Optional) MIO_APPINSIGHT_CONN_STRING=<Connection String of Application Insight, you need to create an Application Insights resource on Azure and get the connection string>
MIO_APPINSIGHT_CONN_STRING helps to write logs of your Azure function for debugging. This step is an optional step and if you don't want to create it, you can modify the init_log() function under utils/log.py to comment the part about Azure Application Insights.
- In VS Code, open the Azure workspace, select the Azure Functions option, and select Deploy to Function App to deploy your solution to Azure.
Note: The sample supports assigning stops to multiple agents delivering multiple stops, but you can add additional constraints such as capacity, pickups and deliveries and resource constraints to your solution. There are additional VRP examples added to this project that you can refer to. You can find more samples on the OR tools webpage.
Usage
The code sample contains an html page that you can use to request the endpoint and visualize the results on a map. To see the results:
- Browse https://<your function app name>.azurewebsites.net/mioui for the sample html and use https://<your function app name>.azurewebsites.net/api/mio to access the endpoint.
- If you're using Bing Maps:
- In the sample application, enter your Bing Maps dev key.
- Note - The sample uses Bing Maps base map data and Route service to get route for the agents.
- In the app, enter the request body for the custom optimizer API which is the vehicle and location information in a GeoJson format. Refer to the examples in the sample code for template. For a quick start, the application is prepopulated with a sample request body.
- Click Get Routes.
- The results will be displayed on a table sorted by the agent vehicles and the order in which they will visit the stops. The routes will be drawn on the map and color coded to match the corresponding agent in the results table.
Now you have the tools and knowledge to create an itinerary optimisation service. Microsoft has also put together a helpful blog on solving TSP with Azure Maps and NVIDIA cuOpt.
By harnessing the power of Azure Functions and distance matrices, you can transform complex waypoint data into optimal routes. So go ahead - implement your solution, fine-tune those parameters, and see your logistics operations thrive.
For additional support or if you're looking to evaluate other Microsoft Mapping solutions, speak to our Mapping Experts today!
Contact Grey Matter
If you have any questions or want some extra information, complete the form below and one of the team will be in touch ASAP. If you have a specific use case, please let us know and we'll help you find the right solution faster.
By submitting this form you are agreeing to our Privacy Policy and Website Terms of Use.
Gabrielle Alvear
Related News
JavaScript Day 2024
Thu 24 October 2024 2:00 pm - 6:00 pm GMT
Are you ready to dive deep into the world of JavaScript and TypeScript? Mark your calendars for 24 October 2024 because JetBrains JavaScript Day 2024 is back for its fourth year, and it’s going to be bigger and better than...
JetBrains GameDev Days 2024
9 - 10 October 2024
A Must-Attend Event for Game Developers Are you passionate about game development? Then attend JetBrains GameDev Days 2024, a free, live virtual event dedicated to all things game development. This hybrid event will take place on 9-10 October 2024 and...
.NET Days Online 2024
25 - 26 September 2024 10:30 am - 5:45 pm BST
.NET Developer Event Hosted by JetBrains Mark your calendars for 25-26 September 2024, as JetBrains hosts the highly anticipated .NET Days Online 2024. This free, two-day virtual event promises to be a treasure trove of knowledge and networking for .NET...
SPECIAL OFFER: 20% Off Embarcadero
Embarcadero offer To celebrate the upcoming 12.2 version update, Embarcadero is offering 20% off RAD Studio, Delphi and C++Builder. After the release, if you are on Update Subscription, your licence will be automatically updated to 12.2. Terms and conditions: This...