Problème d'affectation

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 parfait de poids minimum (ou de poids maximum) 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

Le problème peut être énoncé de la manière suivante[1]. Étant donné un ensemble d'agents et un ensemble de tâches , il est possible de modéliser 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 parfait minimisant la somme des poids des arêtes de .

Algorithmes

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

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

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

Articles connexes

  • Portail de l'informatique théorique
Cet article est issu de Wikipedia. Le texte est sous licence Creative Commons - Attribution - Partage dans les Mêmes. Des conditions supplémentaires peuvent s'appliquer aux fichiers multimédias.