Problème du voyageur de commerce

problème d'optimisation qui, étant donné une liste de villes, et des distances entre toutes les paires de villes, détermine un plus court chemin qui visite chaque ville une seule fois et se termine dans la ville de départ

En informatique théorique, le problème du voyageur de commerce, ou problème du commis voyageur[1], est un problème d'optimisation qui consiste à déterminer, étant donné un ensemble de villes, le plus court circuit passant par chaque ville une seule fois.

Le problème de voyageur de commerce : calculer un plus court circuit qui passe une et une seule fois par toutes les villes (ici 15 villes).

C'est un problème algorithmique célèbre, qui a donné lieu à de nombreuses recherches et qui est souvent utilisé comme introduction à l'algorithmique ou à la théorie de la complexité. Il présente de nombreuses applications, que ce soit en planification, en logistique ou dans des domaines éloignés, comme la génétique, les gènes étant les villes et la similarité la distance.

Description modifier

Étant donné n villes et leurs distances par paire, il s'agit de déterminer le chemin le plus petit qui passe exactement une fois par chaque ville et revienne à la ville de départ. On modélise le problème du voyageur de commerce comme un problème sur un graphe non orienté pondéré. Les villes sont les sommets du graphe. Le voyageur emprunte les arêtes du graphe. Le coût d'une arête entre deux sommets est la distance entre les deux villes correspondantes. Souvent, on considère un graphe complet, i.e. il y a une arête entre toutes paires de sommets :   avec   un ensemble de sommets,   un ensemble d'arêtes, et   une fonction de coût sur les arêtes. Le problème est de trouver le plus court cycle hamiltonien dans le graphe G.

Exemple modifier

On considère la liste des villes A, B, C, D et les distances données par le dessin ci-dessous à gauche. Un premier chemin qui part de A, revient en A et qui visite toutes les villes est ABDCA. Un chemin plus court est ACBDA. Ce dernier est optimal. (Attention, les distances dans l'exemple ne respectent pas l'inégalité triangulaire : d(A,B) < d(A,D) +d(D,B))

 
Instance du problème du voyageur de commerce.
 
Le chemin ABDCA de longueur 4+2+5+3 = 14 km.
 
Le chemin ACBDA est le chemin le plus court qui part de A, revient à A et passe par toutes les villes. Il est de longueur 3+1+2+1 = 7 km. Le chemin ADBCA propose également une longueur de 7km.

Explosion combinatoire modifier

Nombre de chemins candidats en fonction du nombre de villes
Nombre de villes   Nombre de chemins candidats  
3 1
4 3
5 12
6 60
7 360
8 2 520
9 20 160
10 181 440
15 43 589 145 600
20 6,082 × 1016
71 5,989 × 1099

Ce problème est plus compliqué qu'il n'y paraît ; on ne connaît pas de méthode de résolution permettant d'obtenir des solutions exactes en un temps raisonnable pour de grandes instances (grand nombre de villes) du problème. Pour ces grandes instances, on devra donc souvent se contenter de solutions approchées, car on se retrouve face à une explosion combinatoire.

Pour un ensemble de   points, il existe au total   chemins possibles (factorielle de  ). Le point de départ ne changeant pas la longueur du chemin, on peut choisir celui-ci de façon arbitraire, on a ainsi   chemins différents. Enfin, chaque chemin pouvant être parcouru dans deux sens et les deux possibilités ayant la même longueur, on peut diviser ce nombre par deux. Par exemple, si on nomme les points,  , les chemins abcd et dcba, cdab et badc, adcb et bcda, cbad et dabc ont tous la même longueur ; seul le point de départ et le sens de parcours changent. On a donc   chemins candidats à considérer[2].

Par exemple, pour 71 villes, le nombre de chemins candidats est supérieur à 5 × 1080 qui est environ le nombre d'atomes dans l'univers connu[3].

Variantes modifier

Orientation modifier

Rien n'interdit au graphe donné en entrée d'être orienté. Dans ce cas, on considère qu'un chemin existe dans un sens mais pas dans l'autre (exemple : routes à sens unique).

Asymétrie modifier

On parle parfois de problème symétrique ou asymétrique.

  • Problème du voyageur de commerce symétrique : Étant donné un ensemble de   nœuds et de distances pour chaque paire de nœuds, trouver un cycle de longueur minimale qui visite chaque nœud exactement une fois. Pour   et   deux nœuds d'une arête, la distance de   à   est la même que celle de   à  .
  • Problème du voyageur de commerce asymétrique : Étant donné un ensemble de   nœuds et de distances pour chaque paire de nœuds, trouver un cycle de longueur minimale qui visite chaque nœud exactement une fois. Cette fois-ci la distance entre deux nœuds   et   d'une arête n'est pas forcément la même qu'on aille de   à   ou bien de   à  .

Aussi, divers problèmes de recherche opérationnelle se ramènent au voyageur de commerce. Un voyageur de commerce peu scrupuleux serait intéressé par le double problème du chemin le plus court (pour son trajet réel) et du chemin le plus long (pour sa note de frais).

Résolution exacte modifier

Complexité du problème modifier

Le problème de décision associé au problème d'optimisation du voyageur de commerce est NP-complet. Il peut notamment être réduit à partir du problème du cycle Hamiltonien, qui fait partie des 21 problèmes NP-complets de Karp[4]. Papadimitriou a démontré en 1977 que le problème reste NP-dur même si les distances sont données par des distances euclidiennes[5]. Ainsi, le problème reste NP-dur même si on supprime la condition "ne passer au plus qu'une seule fois par une ville".

Algorithmes modifier

Une approche de résolution naïve, mais qui donne un résultat exact, est l'énumération de tous les chemins possibles par recherche exhaustive. La complexité en temps de cet algorithme est en   (plus exactement  , ce qui devient vite impraticable même pour de petites instances). Par exemple, si le calcul d'un chemin prend une microseconde, alors le calcul de tous les chemins pour 10 points est de 181 440 microsecondes soit 0,18 seconde, mais pour 15 points, cela représente déjà 43 589 145 600 microsecondes soit un peu plus de 12 heures et pour 20 points de 6 × 1016 microsecondes soit presque deux millénaires (1 901 années). Pour 25 villes, le temps de calcul dépasse l'âge de l'Univers.

Held et Karp ont montré que la programmation dynamique permettait de résoudre le problème en  [6].

Les méthodes d'optimisation linéaire sont à ce jour parmi les plus efficaces pour la résolution du problème de voyageur de commerce et permettent[N 1] désormais de résoudre des problèmes de grande taille (à l'échelle d'un pays[7]), moyennant éventuellement un temps de calcul important.

Cas particuliers modifier

Tournée bitonique dans un graphe euclidien modifier

Dans le cas d'un graphe euclidien, c'est-à-dire lorsque les arêtes ont pour poids les distances entre les   sommets comme c'est par exemple le cas entre des villes sur une carte routière, certaines variantes du problème du voyageur de commerce ont une solution exacte qui peut être déterminée en temps polynomial. C'est le cas lorsque l'on cherche le circuit bitonique le plus rapide, où l'on part du point le plus à l'ouest pour aller toujours vers l'est jusqu'au point le plus à l'est avant de revenir au point de départ en allant toujours vers l'ouest. Dans ce cas particulier introduit pour la première fois par Jon Louis Bentley, une solution optimale peut être déterminée en   par programmation dynamique[8].

Approximation modifier

Dans cette section, nous discutons l'existence ou non d'algorithmes d'approximation. Ce sont des algorithmes d'approximation, qui ne calculent pas forcément un tour optimal, mais un tour qui est suffisamment de bonne qualité. Généralement, on mesure la qualité de l'algorithme avec un facteur d'approximation   : le poids du tour calculé par l'algorithme est au plus petit que   fois le poids d'un tour optimal.

Cas général modifier

Dans le cas général, et en supposant  , il n'existe pas d'algorithme d'approximation de facteur d'approximation constant pour résoudre le problème du voyageur de commerce[9]. Pour le montrer on procède par l'absurde en supposant que pour un certain   il existe un algorithme d'approximation de facteur  . On montre alors que cet algorithme d'approximation permet de résoudre le problème de la recherche de cycle hamiltonien en temps polynomial alors même que celui-ci est NP-complet[9].

On considère un graphe  , on peut supposer sans perte de généralité que toutes ses arêtes sont de poids 1. On le transforme en le graphe complet   en ajoutant à   entre chaque paire de sommets non connectés une arête de poids    est le nombre de sommets de  . Si le graphe   possède un circuit hamiltonien, alors   possède une tournée minimale de poids  , sinon la tournée minimale contient au moins une arête de poids   et son poids vaut donc au moins  . Dans le premier cas, notre algorithme d'approximation trouvera en temps polynomial une tournée de poids au plus  , dans l'autre il trouvera une tournée de poids au moins  . Comme on peut discriminer entre les deux situations en temps polynomial, il s'ensuit que l'existence d'un circuit hamiltonien peut s'effectuer en temps polynomial ce qui aboutit à une contradiction ; il n'existe donc pas d'algorithme générique d'approximation pour résoudre le problème du voyageur de commerce.

Cas métrique modifier

Le cas métrique signifie que les poids des arêtes respectent l'inégalité triangulaire : aller de A à C est toujours plus court qu'aller de A à la ville intermédiaire B, puis de B à C. Dans ce cas, l'algorithme de Christofides est un algorithme d'approximation de facteur 3/2[10]. Dans ce cas, le problème est APX-difficile même avec des poids 1 ou 2[11]. La meilleure borne inférieure pour le facteur d'approximation est 123/122[12].

Un preprint de 2020 améliore le facteur de 3/2 - 10-36[13],[14].

Cas euclidien modifier

Le cas euclidien signifie que les sommets du graphe sont des points dans un espace euclidien, par exemple un plan euclidien. Le poids d'une arêtes entre deux points A et B est la distance euclidienne entre A et B. Dans le cas euclidien, il existe un schéma d'approximation en temps polynomial. Il a été découvert indépendamment par Sanjeev Arora[15] et Joseph S. B. Mitchell[16], et leur a valu le prix Gödel en 2010[17].

Techniques modifier

Formulation par optimisation linéaire modifier

La formalisation du problème qui suit, sous forme d'optimisation linéaire en nombres entiers du problème, est utilisée pour la conception d'algorithmes d'approximation. On note   l'ensemble des arêtes sortant de l'ensemble de sommets S.

 

La relaxation de ce programme pour un problème d'optimisation linéaire (c'est-à-dire sans les contraintes d'intégralité) est appelée relaxation de Held et Karp[18] ou subtour LP. Cette relaxation a un nombre exponentiel de contraintes, mais peut être résolue en temps polynomial en résolvant le problème de séparation, qui se révèle être le calcul d'une coupe minimum[19].

Il est conjecturé que la relaxation de Held et Karp a un trou d'intégralité (integrality gap) de 4/3[18].

Approximation de facteur 2 utilisant des arbres couvrants modifier

L'algorithme de Christofides est basé sur un algorithme simple d'approximation de facteur 2 qui utilise la notion d'arbre couvrant de poids minimal[9]. Comme toute tournée a un poids cumulé supérieur à celui de l'arbre couvrant minimal[9] et comme un parcours préfixe de l'arbre passe deux fois par chacun des nœuds internes une tournée qui suit un parcours préfixe a un poids cumulé inférieur au double de la solution minimale au problème du voyageur de commerce[9]. Il reste à convertir ce parcours en un parcours qui passe une fois et une seule par chacun des sommets du graphe. On exploite alors l'inégalité triangulaire : si entre deux sommets le parcours considéré fait passer par un sommet intermédiaire déjà visité, on le saute pour passer directement au premier sommet non encore visité[9]. L'inégalité triangulaire assure alors que le poids total du trajet n'augmente pas ; par conséquent on obtient un circuit hamiltonien dont le poids est inférieur au double de celui du circuit minimal[9].

Heuristiques modifier

De fait de la complexité initiale du problème ( ), de son importance, et de sa NP-complétude, de nombreuses heuristiques ont été proposées.

Heuristiques de recherche locale modifier

Une heuristique classique, appelée 2-opt est une recherche locale qui consiste à partir d'une solution et à essayer de l'améliorer en échangeant itérativement les sommets de deux arêtes. L'heuristique de Lin-Kernighan en est une amélioration[20].

Une autre heuristique de recherche locale appelée Ruiner et recréer, proche du recuit simulé, consiste à partir d'une solution, de ruiner une région de celle-ci puis de la recréer en l'améliorant[21].

Méta-heuristiques modifier

Les algorithmes génétiques peuvent aussi être adaptés au problème du voyageur de commerce. L'idée a été proposée la première fois par John Holland au début des années 1970[22].

Heuristiques gloutonnes modifier

Pour le problème du voyageur de commerce, une heuristique gloutonne construit une seule solution, par une suite de décisions définitives sans retour arrière, parmi ces méthodes on cite le plus proche voisin, la plus proche insertion, la plus lointaine insertion et la meilleure insertion.

Dans la méthode du plus proche voisin, on part d'un sommet quelconque et à chacune des   itérations on relie le dernier sommet atteint au sommet le plus proche au sens coût, puis on relie finalement le dernier sommet au premier sommet choisi.

Dans les méthodes d'insertion, on part d'un cycle réduit à une boucle au départ, à chaque itération on choisit un sommet libre   puis on cherche la position d'insertion   et   de cycle qui minimise l'augmentation totale des coûts :

  • dans la plus lointaine insertion   est le sommet libre le plus loin du cycle au sens des coûts ;
  • dans la plus proche insertion   est le plus proche du cycle ;
  • enfin dans la meilleure insertion on teste tous les sommets   non encore insérés et on choisit celui qui donne la plus faible augmentation du coût.

Histoire et importance modifier

Origines et cas particuliers modifier

Le principe d'un tel voyage est décrit dès 1832, dans un écrit d'un commis-voyageur et des itinéraires efficaces étaient référencés dans des guides[23]. Plusieurs problèmes anciens peuvent être vus comme des cas particuliers du problème ; par exemple, en 1856, William Rowan Hamilton s'était intéressé à un problème géométrique de ce type sur un dodécaèdre, d'ailleurs le terme cycle hamiltonien désigne un cycle passant par tous les sommets dans un graphe[23].

Terminologie modifier

Le terme problème du voyageur de commerce, vient de la traduction de l'anglais américain Traveling salesman problem, qui est apparu dans les années 1930 ou 40, sans doute à l'université de Princeton où plusieurs chercheurs s'y intéressaient[23]. C'est aussi à cette période que le problème est formulé indépendamment dans plusieurs communautés de chercheurs, notamment autour de Karl Menger[23].

Développements modifier

Le problème a alors intéressé une plus large communauté et a notamment été à l'origine de la découverte de plusieurs techniques, comme l'optimisation linéaire mixte (mixed integer programming), et la méthode de séparation et évaluation (branch-and-bound)[23].

En 1972, Richard Karp montra que le problème de décision associé est NP-complet[4].

Importance dans l'enseignement et la recherche modifier

Le voyageur de commerce est l'un des problèmes algorithmiques ayant le plus été étudiés[23]. De plus, du fait de la simplicité de son énoncé, il est souvent utilisé pour introduire l'algorithmique, d'où une relative célébrité[23].

Variantes modifier

La variante PTSP (pour physical traveler salesman problem) consiste à visiter une et une seule fois un nombre fini dans un environnement 2D avec des obstacles[24]. La variante mTSP (pour multiple traveler salesman problem) généralise le problème à plusieurs voyageurs, lui-même se généralisant en le problème de tournées de véhicules[25].

Applications modifier

Le problème du voyageur du commerce a de nombreuses applications[23], et a d'ailleurs été motivé par des problèmes concrets, par exemple le parcours des bus scolaires[26].

Un premier type d'application classique est bien sûr dans la logistique, par exemple pour la poste, la distribution de repas à domicile, l'inspection d'installations, etc.[26]. On peut aussi optimiser les mouvements de machines, par exemple, pour minimiser le temps total que met une fraiseuse à commande numérique pour percer n points dans une plaque de tôle[27], ou minimiser les mouvements des grands télescopes (qui sont très lents)[26].

On peut citer des applications plus surprenantes, par exemple : en biologie, le problème aide au séquençage du génome (pour relier des petits fragments en des chaînes plus grandes), et en production il est utilisé pour le test des circuits imprimés[26].

Notes et références modifier

Notes modifier

  1. En général par le biais de la méthode du branch and cut.

Références modifier

  1. « TERMIUM Plus, « travelling salesman problem » », sur btb.termiumplus.gc.ca (consulté le ).
  2. Patrick Siarry, Métaheuristiques : Recuits simulé, recherche avec tabous, recherche à voisinages variables, méthodes GRASP, algorithmes évolutionnaires, fourmis artificielles, essaims particulaires et autres méthodes d'optimisation, Eyrolles, , 534 p. (ISBN 978-2-212-26621-4, lire en ligne), p. 182.
  3. On peut estimer l'ordre de grandeur du nombre d'atomes dans l'univers à 1080.
  4. a et b (en) Richard M. Karp, « Reducibility Among Combinatorial Problems », dans Raymond E. Miller et James W. Thatcher, Complexity of Computer Computations, Plenum, (ISBN 978-1-4684-2003-6, DOI 10.1007/978-1-4684-2001-2_9, lire en ligne), p. 85-103.
  5. (en) « The Euclidean travelling salesman problem is NP-complete », Theoretical Computer Science, vol. 4, no 3,‎ , p. 237–244 (ISSN 0304-3975, DOI 10.1016/0304-3975(77)90012-3, lire en ligne, consulté le )
  6. (en) M. Held et R.M. Karp, « A Dynamic Programming Approach to Sequencing Problems », Journal of the Society for Industrial and Applied Mathematics, 1962, 10 (1), 196–210.
  7. (en) Voir par exemple le site de l'université Georgia Tech.
  8. Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest et Clifford Stein (trad. de l'anglais), Algorithmique : Cours avec 957 exercices et 158 problèmes, Dunod, [détail de l’édition], chap. 15 ("Programmation dynamique"), p. 375.
  9. a b c d e f et g Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest et Clifford Stein (trad. de l'anglais), Algorithmique : Cours avec 957 exercices et 158 problèmes, Dunod, [détail de l’édition], chap. 35 : Algorithmes d'approximation.
  10. Nicos Christofides, « Worst-case analysis of a new heuristic for the travelling salesman problem », Technical Report 388, Graduate School of Industrial Administration, Carnegie-Mellon University, Pittsburgh,‎ .
  11. Christos H. Papadimitriou et Mihalis Yannakakis, « The traveling salesman problem with distances one and two », Mathematics of Operations Research, INFORMS, vol. 18, no 1,‎ , p. 1--11.
  12. (en) « New inapproximability bounds for TSP », Journal of Computer and System Sciences, vol. 81, no 8,‎ , p. 1665–1677 (ISSN 0022-0000, DOI 10.1016/j.jcss.2015.06.003, lire en ligne, consulté le ).
  13. Anna R. Karlin, Nathan Klein et Shayan Oveis Gharan, « A (Slightly) Improved Approximation Algorithm for Metric TSP », arXiv:2007.01409 [cs, math],‎ (lire en ligne).
  14. (en) Erica Klarreich, « Computer Scientists Break Traveling Salesperson Record », sur Quanta Magazine (consulté le ).
  15. Sanjeev Arora, « Polynomial time approximation schemes for Euclidean traveling salesman and other geometric problems », Journal of the ACM, vol. 45, no 5,‎ , p. 753–782 (DOI 10.1145/290179.290180).
  16. Joseph S. B. Mitchell, « Guillotine Subdivisions Approximate Polygonal Subdivisions: A Simple Polynomial-Time Approximation Scheme for Geometric TSP, k-MST, and Related Problems », SIAM Journal on Computing, vol. 28, no 4,‎ , p. 1 298–1 309 (ISSN 1095-7111, DOI 10.1137/S0097539796309764).
  17. « The Gödel Prize 2010, Laudatio for S. Arora and J.S.B. Mitchell », sur EATCS.
  18. a et b Robert D. Carr et Santosh Vempala, « On the Held-Karp relaxation for the asymmetric and symmetric traveling salesman problems », Math. Program., vol. 100, no 3,‎ , p. 569-587.
  19. Rene Beier, « The Traveling Salesman Problem, the Subtour LP, and the Held-Karp Lower Bound », sur MPII.
  20. (en) S. Lin et B. W. Kernighan (1973), « An Effective Heuristic Algorithm for the Traveling-Salesman Problem », Operations Res. 21, 498-516.
  21. (en) G. Schrimpf, J. Schneider, H. Stamm-Wilbrandt and G. Dueck, « Record Breaking Optimization Results Using the Ruin and Recreate Principle », Journal of Computational Physics 159, 2000, 139–171.
  22. (en) J. H. Holland, Adaptation In Natural And Artificial Systems, University of Michigan Press (1975).
  23. a b c d e f g et h David L. Applegate, Robert E. Bixby, Václav Chvátal et William J. Cook, chap. 1 « The Problem », dans The traveling Salesman Problem: A Computational Study, Princeton University Press, .
  24. (en-US) « Solving the Physical Traveling Salesman Problem: Tree Search and Macro Actions - IEEE Journals & Magazine », sur ieeexplore.ieee.org (consulté le )
  25. (en) « The multiple traveling salesman problem: an overview of formulations and solution procedures », Omega, vol. 34, no 3,‎ , p. 209–219 (ISSN 0305-0483, DOI 10.1016/j.omega.2004.10.004, lire en ligne, consulté le )
  26. a b c et d David L. Applegate, Robert E. Bixby, Václav Chvátal et William J. Cook, chap. 2 « Applications », dans The traveling Salesman Problem: A Computational Study, Princeton University Press, .
  27. (en) William Timothy Gowers (dir.), chap. VII.5 « The Influence of Mathematics:The Mathematics of Algorithm Design », dans The Princeton Companion to Mathematics, Princeton et Oxford, Princeton University Press, (ISBN 978-0-691-11880-2), p. 871-878.

Voir aussi modifier

Articles connexes modifier

Liens externes modifier