Problème d'affectation

attribuer au mieux des tâches à des agents informatiques

En informatique, plus précisément en recherche opérationnelle et d'optimisation combinatoire, le problème d'affectation consiste à attribuer au mieux des tâches à des agents. Chaque agent peut réaliser une unique tâche pour un coût donné et chaque tâche doit être réalisée par un unique agent. Les affectations (c'est-à-dire les couples agent-tâche) ont toutes un coût défini. Le but est de minimiser le coût total des affectations afin de réaliser toutes les tâches.

L'affectation optimale entre le groupe d'agent et de tâche est représenté ici par les arcs rouges.

Plus formellement, l'objectif est de déterminer un couplage d'une taille égale au nombre de tâches, de poids minimum dans un graphe biparti valué. Si il y a autant d'agents que de tâches, il s'agit de déterminer un couplage parfait de poids minimum dans un graphe biparti valué. Le problème d'affectation peut être résolu en temps polynomial par l'algorithme hongrois, il appartient par conséquent à la classe de complexité P.

Définition formelle modifier

Le problème peut être énoncé de la manière suivante[1]. Étant donné un ensemble d'agents   et un ensemble de tâches  , On modélise le problème par un graphe biparti  , avec une fonction de poids sur les arêtes  . Le problème d'affectation consiste donc à trouver un couplage  , avec  , et minimisant la somme   des poids des arêtes de  .

Algorithmes modifier

L'algorithme hongrois, parfois appelé algorithme de Kuhn-Munkres, résout le problème en temps polynomial. On peut aussi écrire le problème sous forme d'un problème d'optimisation linéaire. Sa solution sera entière car la matrice ainsi définie est totalement unimodulaire.

Applications modifier

L'application la plus classique de ce problème est, en ordonnancement de tâches, l'affectation de   machines à   tâches. Chaque machine ne peut être affectée qu'à une seule tâche et chaque couple (tâche;machine) a un coût. Le but est de minimiser le coût total d'exécution des tâches.

Lien avec d'autres problèmes modifier

L'algorithme d'Edmonds pour les couplages traite le problème du couplage de cardinal maximum dans tous les graphes en temps polynomial.

Le problème d'affectation est aussi lié au problème du flot de coût minimum.

Notes et références modifier

Articles connexes modifier