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.
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
- Bernard Fortz, « Recherche opérationnelle et applications », sur Université libre de Bruxelles, .