The algorithm is demonstrated majorly on two files:
- PopulationQCI.py
- QuantumInspiredGeneticAlgorithm.py
Within the QuantumInspiredGeneticAlgorithm there exists a modified version of GeneticAlgorithm.py that aims to implement QuantumInspired algorithm into the system. The language used for coding is Python. The implementation is majorly overhauling the algorithm to utilize Qubits-like structures for storing information.
Unlike traditional classic bits, Qubits can store up to multiple information simultaneously. The implementation of the algorithm is with 3 bits and 2 states, enabling an individual qubit to store up to 8 information simultaneously.
Within PopulationQCI, there exists the observation feature, which quantized qubits into states of ones and zeros to obtain classical information relevant to be used for comparison and finding best fitness.
Unlike traditional Genetic Algorithm method of crossover or mutation, Quantum-Inspired algorithm utilizes Quantum Gates and able to manipulate information states, or quantum angles, to more likely to shift to a different states during observation. This enables variety and preserves the algorithm from falling into local optimum.
When selecting Qubits for crossover, a tournament stage was held to select two Individuals, likely to have the best fitness (not yet implemented), for crossover. A mutation operator which utilizes a CNOT-quantum gate is also implemented for the mutation factor.
For each iteration, the system takes the all of the solution from the qubits and identify the best fit. If it does not satisfy the requirement. Run one more iteration.
The code within the files shows all the necessary feature for implementing a Quantum-Inspired Evolutionary Algorithm. However, due to the lack of skills to accomplish the project within the given time frame, a redesign is likely required to get it operable.
Platform used: Google Colab. File used for testing: basic_vrps_qci_test.ipynb
PyVRP is an open-source, state-of-the-art vehicle routing problem (VRP) solver. It currently supports VRPs with:
- Pickups and deliveries between depots and clients (capacitated VRP, VRP with simultaneous pickup and delivery, VRP with backhaul);
- Vehicles of different capacities, costs, shift durations, routing profiles, and maximum distance and duration constraints (heterogeneous fleet VRP, site-dependent VRP);
- Time windows, client service durations, and release times (VRP with time windows and release times);
- Multiple depots (multi-depot VRP);
- Reloading along routes at different reload depots (multi-trip VRP);
- Optional clients with prizes for visiting (prize collecting, team orienteering problem);
- Client groups imposing additional restrictions on multiple clients jointly (generalised VRP, VRP with multiple time windows).
PyVRP is available on the Python package index as pyvrp.
It may be installed in the usual way as
pip install pyvrp
This also resolves the few core dependencies PyVRP has. The documentation is available here.
Tip
If you are new to vehicle routing or metaheuristics, you might benefit from first reading the introduction to VRP and introduction to HGS pages.
We provide some example notebooks that show how PyVRP may be used to solve vehicle routing problems. These include:
- A short tutorial and introduction to PyVRP's modelling interface, here. This is a great way to get started with PyVRP.
- A notebook solving classical VRP variants, here. In this notebook we solve several benchmark instances of the CVRP and VRPTW problems. We also demonstrate how to use the plotting tools available in PyVRP to visualise the instance and statistics collected during the search procedure.
- A notebook implementing a solvemethod using PyVRP's components, here. This notebook is a great way to dive deeper into how PyVRP works internally.
Feel free to open an issue or a new discussion thread here on GitHub. Please do not e-mail us with questions, modelling issues, or code examples. Those are much easier to discuss via GitHub than over e-mail. When writing your issue or discussion, please follow the instructions here.
While we are very grateful for any contributions you are willing to make, reviewing and maintaining third-party code takes a significant amount of our time. Before you start working on your contribution, please have a look here to get started. Make sure to discuss the change first in a GitHub issue. Feel free to open a new one if no appropriate issue already exists!
If you use PyVRP in your research, please consider citing the following paper:
Wouda, N.A., L. Lan, and W. Kool (2024). PyVRP: a high-performance VRP solver package. INFORMS Journal on Computing, 36(4): 943-955. https://doi.org/10.1287/ijoc.2023.0055
Or, using the following BibTeX entry:
@article{Wouda_Lan_Kool_PyVRP_2024,
  doi = {10.1287/ijoc.2023.0055},
  url = {https://doi.org/10.1287/ijoc.2023.0055},
  year = {2024},
  volume = {36},
  number = {4},
  pages = {943--955},
  publisher = {INFORMS},
  author = {Niels A. Wouda and Leon Lan and Wouter Kool},
  title = {{PyVRP}: a high-performance {VRP} solver package},
  journal = {INFORMS Journal on Computing},
}A preprint of this paper is available on arXiv. Since PyVRP extends HGS-CVRP, please also consider citing Vidal (2022).