23
pages
Français
Documents
Le téléchargement nécessite un accès à la bibliothèque YouScribe Tout savoir sur nos offres
23
pages
Français
Documents
Le téléchargement nécessite un accès à la bibliothèque YouScribe Tout savoir sur nos offres
Chapitre 2
Principes d’implémentation des
métaheuristiques
1Éric D. Taillard
2.1 Introduction
Les métaheuristiques ont changé radicalement l’élaboration d’heuristiques : alors
que l’on commençait par s’interroger sur les caractéristiques et les particularités du
problème à résoudre avant de commencer à programmer une méthode spécifique, les
métaheuristiques ont en quelque sorte inversé le processus, la trame de la méthode de
résolution étant fournie par la métaphore qui a inspiré la métaheuristique. Ayant une
première heuristique, on cherche ensuite à l’améliorer en observant les faiblesses
qu’elle présente pour le problème à résoudre.
Il s’agit là d’une conception que l’on peut qualifier de partisane, liée à l’école
d’une métaheuristique particulière. Jusque vers le milieu des années 90, une question
à laquelle bien des personnes ont cherché à répondre était de savoir si telle ou telle
métaheuristique était meilleure ou moins bonne que telle ou telle autre. La réponse
n’a bien évidemment jamais été trouvée, pour la simple raison que l’efficacité des
méthodes mises au point dépend avant tout des adaptations de la trame de base aux
spécificités du problème (et même des exemples de problèmes que l’on cherche à
1 Institut d’Informatique, École d’Ingénieurs du Canton de Vaud, Haute École Spécialisée de
Suisse Occidentale, Route de Cheseaux 1, 1400 Yverdon Les Bains, Suisse,
eric.taillard@eivd.ch, http://www.eivd.ch/ina/Collaborateurs/etd/default.htm.2 Métaheuristiques et outils nouveaux en R. O.
résoudre pratiquement). Ainsi, plus la trame est riche et complexe, comme par
exemple pour la recherche avec tabous, plus on a de possibilités d’amélioration
d’une méthode de base, mais, par contre, plus il est difficile de sélectionner et
d’assembler les bons principes de la métaheuristique.
Par la suite, la situation s’est notablement compliquée avec l’avènement de
méthodes dites hybrides. Au lieu de faire preuve de sectarisme et de limiter les
principes de construction d’une heuristique à une seule école — génétique, recuit
simulé, etc. —, on s’est rendu compte que la mise en commun des principes de
plusieurs métaheuristiques voire de méthodes exactes pouvait mener à l’élaboration
d’heuristiques encore plus performantes.
Cependant, la mise au point d’une méthode basée sur diverses métaheuristiques
devient difficile, car il faut tout d’abord sélectionner un sous ensemble de principes
qui devront être appropriés au problème à résoudre. On peut donc dire que bien des
heuristiques actuellement développées sont un assemblage plus ou moins judicieux
d’un nombre relativement restreint de principes de base, parfois déguisés pour
pouvoir être exprimés sous la forme d’une métaheuristique « pure ». De plus, la
situation se complique encore par l’apparition de « nouvelles » métaheuristiques, qui
ne sont souvent que le résultat d’un assemblage — particulièrement bien adapté à un
problème donné — de quelques principes de base.
La présentation « d’application des métaheuristiques » en général ne peut donc se
faire qu’en décrivant comment ces quelques principes de base ont été appliqués dans
certains problèmes d’optimisation. L’assemblage de ces principes pour obtenir une
heuristique spécifique pour un problème donné, heuristique inspirée d’une ou de
plusieurs métaheuristiques, fera l’objet de chapitres ultérieurs. Mentionnons encore
que ce chapitre n’aura pas pour objet un passage en revue des problèmes pour
lesquels il existe une méthode efficace basée sur une métaheuristique, cet ensemble
de problème étant bien trop vaste.
Nous terminerons ce chapitre par quelques suggestions en ce qui concerne la
comparaison des heuristiques itératives non déterministes. En effet, les
métaheuristiques mènent souvent à ce type d’heuristiques, qui sont encore beaucoup
trop rarement comparées de manière valable dans la littérature.
2.2 Voisinage
Sans conteste, le principe général le plus largement utilisé dans l’élaboration
d’heuristiques est celui de voisinage. À chaque solution s du problème, on associe un
sous ensemble V(s) de solutions. Ce sous ensemble peut être statique, comme dans le
cas du recuit simulé ou des méthodes de bruitage, mais aussi dynamique et dépendreApplications des métaheuristiques 3
du temps t (ou plus précisément de l’itération à laquelle on se trouve). Notons que la
dépendance du voisinage par rapport au temps est étroitement couplée à d’autres
principes de base contenus dans la métaheuristique, comme par exemple la liste de
tabous ou de candidats dans une recherche avec tabous.
Même dans le cas d’une structure de voisinage statique et très simple, où le seul
but est de trouver un optimum local, on ne connaît que très peu de résultats
théoriques utiles. L’algorithme du simplexe pour la programmation linéaire est un
exemple typique. Pour ce problème, il est bien connu que le nombre d’itérations pour
arriver à une solution optimale peut être exponentiel en la taille du problème.
Pourtant, en pratique, on observe que le nombre d’itérations croît bien plus
lentement, ce qui en fait un algorithme efficace et très largement utilisé.
L’algorithme du simplexe est basé sur un voisinage statique : pour toute solution s,
V(s) est constitué des solutions qui diffèrent de s par l’échange de deux variables,
l’une sortant de la base et l’autre y entrant (à cela s’ajoute bien évidemment d’autres
considérations, comme l’admissibilité de la solution voisine ou le fait que celle ci ne
doit pas être plus mauvaise que la solution de départ).
Pour un problème d’optimisation combinatoire non convexe, pour lequel il est
possible de définir un ensemble de voisinages a priori intéressants, la situation se
complexifie. Il devient alors difficile de se décider pour l’un ou l’autre des
voisinages autrement que par des essais. Comme le voisinage n’est qu’une partie des
principes, tous interdépendants, utilisés dans l’heuristique, le choix d’un (ou de
plusieurs) voisinages devient réellement problématique car on ne dispose que de très
peu de résultats théoriques sur la qualité d’un voisinage pour un problème particulier.
Angel (1998) a cependant proposé et analysé une mesure de l’adéquation des
voisinages appelée rugosité : l’idée consiste à évaluer la variance des coûts de deux
solutions voisines. Cette variance est ensuite normalisée par la variance des coûts de
l’ensemble des solutions et par la taille du problème, afin d’avoir une mesure
indépendante de la valeur absolue de la fonction objectif ou de la taille du problème.
La rugosité donne une indication sur la difficulté à résoudre un problème à l’aide
d’une recherche locale utilisant un voisinage donné. En effet, si cette mesure est
élevée, on peut supposer que le voisinage est peu adapté car les valeurs des solutions
voisines semblent peu corrélées, alors que si cette mesure est faible, on aura un
« paysage » lisse, avec relativement peu d’optima locaux, donc un problème facile à
optimiser à l’aide d'une recherche locale. Naturellement, si la rugosité est une notion
mathématiquement bien définie, l’interprétation donnée ci-dessus n’est qu'une
supposition plausible, étayée seulement par des considérations empiriques (Angel et
Zissimopoulos, 1998).p
q
p
q
p
q
p
q
p
q
p
q
p
„
4 Métaheuristiques et outils nouveaux en R. O.
2.2.1. Voisinage sur une permutation
Illustrons tout d’abord comment des voisinages simples peuvent être définis pour
des problèmes où une solution est une permutation. De nombreux problèmes
d’optimisation combinatoire peuvent s’exprimer sous la forme d’une recherche de
permutations : celui du voyageur de commerce (ordre dans lequel on parcourt les
villes, voir Lawler et al. 1985) celui de l’affectation quadratique (site de chaque unité
à placer, voir chapitre 3, tome 2 du présent ouvrage) ou encore celui de la chaîne de
montage (ordre dans lequel on fait passer les travaux sur la chaîne, voir B•azevicz et
al. 1994).
A priori, tous ces problèmes pourraient utiliser le même voisinage puisque leurs
solutions se représentent sous la même forme. L’inversion de deux éléments contigus
est