Capacitated Vehicle Routing Problem formulation
There is a library in AIMMS that solves a Capacitated Vehicle Routing Problem (CVRP). It contains different options of formulating the problem. The difference between these articles is how subtours are eliminated. The objective function and most of the constraints are the same for all four options and will be explained in this article.
Linear Integer Programming Model
A CVRP can be formulated as a linear integer programming model. The total distance of the route, where all costumers demands are met, should be minimized.
The binary variable \(x_{ijk}\) has a value of \(1\) if the arc from node \(i\) to node \(j\) is in the optimal route and is driven by vehicle \(k\).
Whereby, there is no travel from a node to itself:
The parameter \(d_{ij}\) describes the distance from node \(i\) to node \(j\). There are \(n\) nodes (depot = 1) and \(p\) vehicles. The objective function can be formulated as follows:
Every node should be entered and left once (expect for the depot) and by the same vehicle. The depot should be left and entered once by each vehicle. \(q_{i}\) describes the demand of each costumer and \(Q\) is the capacity of the vehicles. The sum of the demands of all costumers that vehicle \(k\) will serve, should not exceed the capacity of vehicle \(k\). All these constraints can be formulated as follows:
1. Vehicle Leaves Node that it Enters
Ensure that the number of times a vehicle enters a node is equal to the number of times it leaves that node:
2. Ensure that Every Node is Entered Once
Together with the first constraint, it ensures that the every node is entered only once, and it is left by the same vehicle.
3. Every Vehicle Leaves the Depot
Together with constraint 1, we know that every vehicle arrives again at the depot.
4. Capacity Constraint
Respect the capacity of the vehicles. Note that all vehicles have the same capacity.
The above constraints are formulated in the Common Constraints and Variables
section in the CVRP Library.
Eliminating Subtours
However, a solution that satisfies the above constraints can still be infeasible to the actual problem; namely when the solution contains a subtour, as illustrated by the subtour through nodes 3, 4, and 5 below:
The different formulations in the library are different ways of eliminating these subtours, and are discussed in detail in the following articles:
Time Windows (provided non-zero travel times)