Programmation linéaire en nombres entiers

Documents pareils
Programmation linéaire

Programmation linéaire

Souad EL Bernoussi. Groupe d Analyse Numérique et Optimisation Rabat http ://

Programmation Linéaire - Cours 1

La programmation linéaire : une introduction. Qu est-ce qu un programme linéaire? Terminologie. Écriture mathématique

Exemples de problèmes et d applications. INF6953 Exemples de problèmes 1

Cours de Recherche Opérationnelle IUT d Orsay. Nicolas M. THIÉRY. address: Nicolas.Thiery@u-psud.fr URL:

Nouvelles propositions pour la résolution exacte du problème de sac à dos bi-objectif unidimensionnel en variables binaires

Optimisation Combinatoire (Méthodes approchées) II. Recherche Locale simple (Les bases)

Info0804. Cours 6. Optimisation combinatoire : Applications et compléments

Annexe 6. Notions d ordonnancement.

Exercices du Cours de la programmation linéaire donné par le Dr. Ali DERBALA

Optimisation Discrète

Cours des Méthodes de Résolution Exactes Heuristiques et Métaheuristiques

Programmation linéaire et Optimisation. Didier Smets

Objectifs du cours d aujourd hui. Informatique II : Cours d introduction à l informatique et à la programmation objet. Complexité d un problème (2)

Cours Optimisation Partie Optimisation Combinatoire. Année scolaire Gérard Verfaillie ONERA/DCSD/CD, Toulouse

Résolution d équations non linéaires

Apprentissage Automatique

Communications collectives et ordonnancement en régime permanent pour plates-formes hétérogènes

CHAPITRE 5. Stratégies Mixtes

Jean-Philippe Préaux

L exclusion mutuelle distribuée

Chapitre 5 : Flot maximal dans un graphe

Plus courts chemins, programmation dynamique

Probabilités sur un univers fini

(51) Int Cl.: H04L 29/06 ( ) G06F 21/55 ( )

Sujet 4: Programmation stochastique propriétés de fonction de recours

Excel Avancé. Plan. Outils de résolution. Interactivité dans les feuilles. Outils de simulation. La valeur cible Le solveur

Cours d Analyse. Fonctions de plusieurs variables

Objectifs. Clustering. Principe. Applications. Applications. Cartes de crédits. Remarques. Biologie, Génomique

Algorithmes pour la planification de mouvements en robotique non-holonome

Programmation mathématique Discrète et Modèles Linéaires

MATHS FINANCIERES. Projet OMEGA

Exercices types Algorithmique et simulation numérique Oral Mathématiques et algorithmique Banque PT

Nouvelles propositions pour la résolution exacte du sac à dos multi-objectif unidimensionnel en variables binaires

Modèles à Événements Discrets. Réseaux de Petri Stochastiques

Optimisation non linéaire Irène Charon, Olivier Hudry École nationale supérieure des télécommunications

= constante et cette constante est a.

«Cours Statistique et logiciel R»

Cours de Master Recherche

Chapitre 3. Les distributions à deux variables


Cours de recherche opérationnelle I

Principe d optimisation. Optimisation technico-économique. Coût. Isolation thermique. Isolation optimale

Optimisation for Cloud Computing and Big Data

Cours d analyse numérique SMI-S4

OUTILS EN INFORMATIQUE

La NP-complétude. Johanne Cohen. PRISM/CNRS, Versailles, France.

Projet de Traitement du Signal Segmentation d images SAR

Introduction à l étude des Corps Finis

Système binaire. Algèbre booléenne

Lagrange, où λ 1 est pour la contrainte sur µ p ).

L ANALYSE EN COMPOSANTES PRINCIPALES (A.C.P.) Pierre-Louis GONZALEZ

Cours 02 : Problème général de la programmation linéaire

Algèbre binaire et Circuits logiques ( )

Quelques tests de primalité

Evaluation des performances de programmes parallèles haut niveau à base de squelettes

Programmation linéaire

Annexe commune aux séries ES, L et S : boîtes et quantiles

Capacité d un canal Second Théorème de Shannon. Théorie de l information 1/34

Introduction au Data-Mining

Laboratoire d informatique Gaspard-Monge UMR Journée Labex Bézout- ANSES

Logique binaire. Aujourd'hui, l'algèbre de Boole trouve de nombreuses applications en informatique et dans la conception des circuits électroniques.

Théorèmes de Point Fixe et Applications 1

Probabilités sur un univers fini

De même, le périmètre P d un cercle de rayon 1 vaut P = 2π (par définition de π). Mais, on peut démontrer (difficilement!) que

Analyse stochastique de la CRM à ordre partiel dans le cadre des essais cliniques de phase I

Concurrence imparfaite

Application de K-means à la définition du nombre de VM optimal dans un cloud

Arbres binaires de décision

1 de 46. Algorithmique. Trouver et Trier. Florent Hivert. Mél : Florent.Hivert@lri.fr Page personnelle : hivert

La classification automatique de données quantitatives

Une nouvelle approche de détection de communautés dans les réseaux sociaux

Calcul intégral élémentaire en plusieurs variables

EXERCICE 4 (7 points ) (Commun à tous les candidats)

CARTE DE VOEUX À L ASSOCIAEDRE

Transmission d informations sur le réseau électrique

Feuille TD n 1 Exercices d algorithmique éléments de correction

Cours 7 : Utilisation de modules sous python

Ordonnancement. N: nains de jardin. X: peinture extérieure. E: électricité T: toit. M: murs. F: fondations CHAPTER 1

OPTIMISATION À UNE VARIABLE

ESSEC. Cours «Management bancaire» Séance 3 Le risque de crédit Le scoring

Théorie des Graphes Cours 3: Forêts et Arbres II / Modélisation

3. Caractéristiques et fonctions d une v.a.

Data Mining. Vincent Augusto École Nationale Supérieure des Mines de Saint-Étienne. Data Mining. V. Augusto.

Gestion réactive des opérations de maintien et d actualisation réglementaire et technologique des systèmes complexes.

INTRODUCTION A L ELECTRONIQUE NUMERIQUE ECHANTILLONNAGE ET QUANTIFICATION I. ARCHITECTURE DE L ELECRONIQUE NUMERIQUE

Programmation Par Contraintes

Théorie et Codage de l Information (IF01) exercices Paul Honeine Université de technologie de Troyes France

Programmation par contraintes. Laurent Beaudou

Capital économique en assurance vie : utilisation des «replicating portfolios»

Baccalauréat ES Antilles Guyane 12 septembre 2014 Corrigé

Optimisation des fonctions de plusieurs variables

Analyse en Composantes Principales

Les équations différentielles

Mathématique et Automatique : de la boucle ouverte à la boucle fermée. Maïtine bergounioux Laboratoire MAPMO - UMR 6628 Université d'orléans

Baccalauréat ES Pondichéry 7 avril 2014 Corrigé

Baccalauréat ES Polynésie (spécialité) 10 septembre 2014 Corrigé

de calibration Master 2: Calibration de modèles: présentation et simulation d

Transcription:

Programmation linéaire en nombres entiers Formulation Hugues Talbot Laboratoire A2SI 20 mars 2009

Plan Introduction Programmation en nombres entiers Exemples de problèmes et formulations Variables booléennes et MP Conditions logiques Combinaisons de variables Optimisation combinatoire Conclusion

Nombres entiers vs. nombres réels Jusqu à présent, nous avons vu des problèmes de PL avec contraintes et des variables en nombres réels (positifs pour le simplexe) Une manière d étendre le problème est d exiger qu un ou l autre de ces aspects du problème s exprime en nombres entiers. Dans le cas où les contraintes et les variables sont toutes deux entières, on parle de programmation linéaire en nombre entiers (ou simplement programmation en nombres entiers - IP en anglais). Dans le cas ou seulement un de ces aspects s exprime en nombre entiers, ou même seulement certaines des variables, on parle de programmation linéaire mixte (MP en anglais).

Exemple Maximiser z = x 1 + x 2 avec 2x 1 + 2x 2 1 8x 1 + 10x 2 13 et x 1, x 2 0 Avec le simplexe, en nombres réels, on trouve l optimum {x 1 = 4, x 2 = 9/2}. Si le problème est contraint en nombres entiers (x i sont des unités indivisibles), alors l optimum est {x 1 = 1, x 2 = 2}! Comment passer de la solution continue à la solution entière? Ici prendre l entier le plus proche n est pas faisable...

Catégories de problèmes en IP 1. Problèmes avec entrées/sorties discrètes : production d objets, etc. 2. Problèmes avec conditions logiques : ajout de variables entières avec des contraintes supplémentaires. (par exemple : si le produit A est fabriqué alors produire également B ou C)... 3. Problèmes combinatoires : séquençage, allocation de ressources, emplois du temps, TSP : formulables en IP. 4. Problèmes non linéaires : souvent formulables en IP. C est utile en particulier quand la région réalisables est non-convexe. 5. Problèmes de réseaux, problèmes de graphes exemple : colorier une carte.

Remarques sur la formulation en IP La plupart des modèles sont dans la seconde catégorie (pb avec conditions logiques), la plupart des problèmes sont donc des problèmes mixtes avec quelques variables entières ajoutées ; IP peut être un moyen (avec de l expérience) pour modéliser effectivement une grande classe de problèmes : contrairement à ce qu on pourrait penser, contraindre davantage le problème (IP vs. LP) permet de modéliser plus de problèmes! Cependant, modéliser n est pas résoudre! On verra que IP est en général NP-complet, et donc les méthodes de résolutions sont non-linéaire en complexité... La complexité de la résolution dépend de la formulation!

Variables de décision Parmi les variables entières, il existe la classe des variables booléennes, pouvant prendre comme valeur 0 ou 1. Ces variables sont souvent utilisées en MP pour représenter des décisions : implications, liens entre variables, etc. Exemple des variables d affectation et indicatrices.

Exemple : Choix Soient 4 choix possibles, chacun nécessitant des moyens et donnant un rendement choix moyen rendement 1 5 unités 16 unités 2 7... 22... 3 4... 12... 4 3... 8... Moyens disponibles : 14 unités Maximiser le rendement. Extentions : 1. On doit effectuer au plus 2 choix 2. Choix 2 ne peut être effectué que si 1 est également pris

Affectation : formulation On utilise des variables booléennes (0 et 1), par exemple { 1 Choix effectué X j, j {1,..., 4} = 0 Sinon On cherche à maximiser z = 16x 1 + 22x 2 + 12x 3 + 8x 4 Avec la contrainte Contraintes optionnelles : 1. x 1 + x 2 + x 3 + x 4 2 2. x 1 x 2 x 1 + x 2 0 5x 1 + 7x 2 + 4x 3 + 3x 4 14

Variables indicatrices On suppose que x modèle une quantité (réelle) d un ingrédient à inclure dans un mélange. On cherche à distinguer le cas x = 0 du cas x > 0. On introduit la variable δ, qui prend la valeur 1 lorsque x > 0, avec la contrainte : x Mδ 0, avec M un coefficient connu représentant une valeur maximale possible de x. Avec cette contrainte, on a bien x > 0 δ = 1.

Indicatrices : suite Pour l implication opposée (x = 0 δ = 0), c est plus problématique. Cette implication est équivalente à δ = 1 x > 0. On introduit une implication moins sévère : δ = 1 x > m, avec m un niveau minimum acceptable en dessous duquel on considère x non-utilisé (dépendant de l application). Une contrainte équivalente est alors : x mδ 0.

Problèmes à charge fixe Exemple : unités de production d énergie Cas général de production avec coût initial et coût marginal. La puissance générée vaut soit P i = 0, soit P m i P i P M i. avec un coût : { 0 Unité arrêtée C i = a i + b i P i Sinon Produire une certaine puissance au moindre coût. Ici le coût est non-linéaire et même non-continu. LP n est pas capable de modéliser le problème. Comment faire?

Formulation de la charge fixe en IP On introduit la variable { 0 Unité i arrêtée x i = 1 Sinon Les contraintes avec x i P m i P i x i P M i C i = a i x i + b i P i (et non C i = a i x i + b i P i x i, qui serait non-linéaire). Note : la condition P i = 0, x i = 1 est réalisable mais de coût supérieur au cas P i = 0, x i = 0.

Problèmes d affectation On a n tâches affectée à n personnes ; On veut affecter une et une seule tâche à chaque personne ; Le rendement de l affectation de la tâche i à la personne j est donnée par la matrice C ij ; On veut maximiser le rendement ; Formulation? Formulation étendue : si le nombre de tâches est inférieur au nombres de personnes.

Formulation de l affectation On introduit les variables x ij contraintes : Maximiser { 1 tâche i affectée à la personne j x ij = 0 Sinon n i=1 x ij = 1(une seule tâche affectée à j) n j=1 x ij = 1(chaque tâche affectée une fois) n i=1 j=1 n C ij x ij

Problème d affectation étendu Nombre de personnes > nombre de tâches, i.e n personnes, m tâches, n > m : m i=1 x ij 1, j = 1,...,n Somme des tâches affectées à la personne j est 1 : n j=1 x ij, i = 1,...,m Somme des personnes affectées à la tâche i est = 1 : on ajoute des variables d écart : s j + m i=1 x ij = 1, j = 1,...,n Maximiser n i=1 j=1 n C ij x ij

Autre façon de formuler : pb de transport Nous verrons comment reformuler ce problème dans le dernier cours. (diagramme personne-tâches 4.18). contraintes en entiers, valeurs max de x ij est 1, min = 0, donc solution en nombre entiers.

Conversion algèbre booléenne en algèbre linéaire avec variables binaires on introduit { 1 si xi est vrai δ i = 0 sinon x i vrai δ i = 1 x i faux δ i = 0

Opérations logiques V F négation ET logique OU logique Implication Equivalence OU exclusif VRAI FAUX

Quelques opérations x 1 x 2 = V δ 1 + δ 2 1 x 1 x 2 = F δ 1 = 1,δ 2 = 1 x 1 = 1 δ 1 = 0 x 1 x 2 δ 2 δ 1 x 1 x 2 δ 1 = δ 2 x 1 x 2 = V δ 1 + δ 2 = 1

Combinaison de variables logiques et continues Variable logique = indicateur (e.g. ouvert/fermé, chaud/froid) cas x i = [f(x i ) 0], soit, si δ i = 1 si x i = V. δ i = 1 si f(x i ) 0 δ i = 0 si f(x i ) ε (précision) On considère M > 0, m < 0. M = max xi (f(x i )) m = min xi (f(x i )),

Equations algébriques f(x i ) M(1 δ i ) f(x i ) ε + (m ε)δ i 1. soit δ i = 1, alors f(x i ) 0, f(x i ) ε. 2. soit δ i = 0, alors f(x i ) M, f(x i ) ε. 3. soit f(x i ) 0, alors δ i = 0 (démo tableau) 4. soit f(x i ) 0, alors δ i = 1 (idem)

Produit de variables binaires soit le produit de variables δ 3 = δ 1 δ 2 : contraintes non-linéaires. Pour transformer en série de contraintes linéaires, on pose : On vérifie l équivalence : δ 3 δ 1, δ 3 δ 2 δ 3 δ 1 + δ 2 1 1. δ 1 = 0, δ 2 = 0 δ 3 0 δ 3 = 0 2. δ 1 = 1, δ 2 = 0 δ 3 0, δ 3 0 δ 3 = 0 3. de même pour δ 1 = 0, δ 2 = 1 4. δ 1 = 1, δ 2 = 1 δ 3 1, δ 3 1 δ 3 = 1 5. Inversement : δ 3 = 1 δ 1 1, δ 2 1, δ 1 + δ 2 2, donc δ 1 = δ 2 = 1. 6. δ 3 = 0 δ 1 = 0, δ 2 0, δ 1 + δ 2 1 donc seulement δ 1 ou δ 2 vaut 1 (l autre vaut 0).

Produit d une variable binaire et d une variable continue soit le produit non-linéaire de deux variables, l une continue, l autre booléenne : δf(x), i.e : { 0 si δ = 0 y = f(x) si δ = 1 On impose les contraintes : y Mδ y mδ y f(x) m(1 δ) y f(x) M(1 δ)

Produit booléen-continu, suite 1. soit δ = 0, alors y 0, y 0, donc y = 0. Egalement f(x) M y f(x) m, donc f(x) M 0 et f(x) m 0, ce qui est non-critique. 2. soit δ = 1, alors y y y y M (non-critique) m (non-critique) f(x) f(x) y = f(x) 3. L inverse est également correct : y = f(x) δ = 1.

Applications Systèmes dynamiques et logiques Exemple : { 0.8X(t) +U(t) si X(t) 0 X(t + 1) = 0.8X(t) +U(t) si X(t) < 0 avec 10 X 10, 1 U 1. Systèmes invariants linéaires par morceaux Machines à états finis.

Quelques problèmes en optimisation combinatoire 1. P.L. en nombres entiers : min C T x Ax b x i entiers 2. Cas particulier : variables booléennes min C T x Ax b x i = 0 ou 1, x B

Problèmes-types - I 3. Sac à dos (knapsack) : une seule contrainte max Note : a > 0, sinon, x i = 1 x i. 4. Sacs à dos multiples C T x a T x b x B Note : i, j, A ij 0. max C T x AX b x B

Problèmes-types - II 5. Couplage (set matching) max C T x AX 1( vecteurs de 1s ) X B Note : i, j, A ij B, X B. 6. Recouvrement (set covering) min Note : i, j, A ij B, X B. C T x AX 1( vecteurs de 1s ) X B

Problèmes-types - III 7. Partitionnement (set partitionning) min C T x AX = 1( vecteurs de 1s ) X B Note : i, j, A ij B, X B. Cas particulier : problème d affectation.

Exemple de problème de recouvrement Soit la ville suivante, composée des arrondissements suivants : On doit construire un certain nombre d hôpitaux, qui devront s occuper des urgences médicales provenant de l arrondissement où il est construit et de tous ses voisins immédiats. On cherche à minimiser le nombre hôpitaux. Formulation?

Formulation du problème des hôpitaux On se donne une variable x i booléenne pour chaque arrondissement. Si x i vaut 1, il y aura un hôpital dans l arrondissement i, et si elle vaut 0, il n y en aura pas. On formule de la façon suivante : min P i x i, avec : x 1 + x 2 + x 3 + x 4 1 x 1 + x 2 + x 3 + x 5 1 x 1 + x 2 + x 3 + x 4 + x 5 + x 6 1 x 1 + x 3 + x 4 + x 6 + x 7 1 x 2 + x 3 + x 5 + x 6 + x 8 + x 9 1 x 3 + x 4 + x 5 + x 6 + x 7 + x 8 1 x 4 + x 6 + x 7 + x 8 1 x 5 + x 6 + x 7 + x 8 + x 9 + x 10 1 x 5 + x 8 + x 9 + x 10 + x 11 1 x 9 + x 10 + x 11 1 On demande de recouvrir l ensemble de manière optimale : une solution est x 3 = x 8 = x 9 = 1 et le reste à 0.

Conclusion On peut modéliser de nombreux problèmes par la programmation linéaire en nombres entiers (IP) ou par la programmation linéaire mixte (MP). Problèmes logiques, d affectation, réseau, etc. PI et PM sont donc des outils puissants de modélisation Reste à résoudre ces problèmes : existence d une solution? unicité? algorithme de calcul de la solution? On verra que la plupart des problèmes de PI et PM sont des problèmes difficiles à résoudre (NP-difficile). Deux méthodes principales de résolution : par coupes (Gomorry) et par séparation-évaluation (Branch-and-bound).