ebook img

Analyse d'Algorithme PDF

108 Pages·2017·2.95 MB·French
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Analyse d'Algorithme

Analyse d’Algorithme Cyril Gavoille LaBRI Laboratoire Bordelais de Recherche en Informatique, Université de Bordeaux [email protected] 11 novembre 2022 –169pages– ii cbna Ce document est publié sous Licence Creative Commons «Attribution - Pas d’Utilisation Commerciale - Partage dans les Mêmes Conditions 4.0 International (CC BY-NC-SA 4.0)». Cette licence vous autorise une utilisation libre de ce document pour un usage non commercial et à condition d’en conserver la paternité. Toute version modifiée de ce document doit être placée sous la même licence pour pouvoir être diffusée. https://creativecommons.org/ licenses/by-nc-sa/4.0/deed.fr iii Master 2 Cours d’introduction à la complexité paramétrique et aux algorithmes d’approximation Pré-requis: algorithmique; notions de théorie des graphes Quelquesouvragesderéférence: • Kernelization – Theory of Parameterized Preprocessing Fedor V. Fomin, Daniel Lokshtanov, Saket Saurabh, Meirav Zehavi Cambridge 2019 • Invitation to Fixed-Parameter Algorithms Rolf Niedermeier Oxford 2006 • Parameterized Complexity Theory Jörg Flum, Martin Grohe Springer 2006 • Fundamentals of Parameterized Complexity Rodney G. Downey, Michael R. Fellows Springer 2013 • Algorithmes d’approximation Vijay V. Vazirani Springer 2006 • Approximation Algorithms for NP-hard Problems Dorit S. Hochbaum PWS 1995 • Algorithm Design Jon Kleinberg, Éva Tardos Addison Wesley 2006 • Parameterized Algorithms Marek Cygan, Fedor V. Fomin, et al. Springer 2015 • Computational Complexity : A Modern Approach (4th edition) Sanjeev Arora, Boaz Barak Cambridge 2016 iv Table des matières Avant-propos 1 Bibliographie . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 1 Introduction 17 1.1 À quoi sert l’analyse d’algorithme? . . . . . . . . . . . . . . . . . . . . . . 17 1.2 Quelques algorithmes que nous analyserons . . . . . . . . . . . . . . . . . 19 1.3 Des algorithmes pour construire quoi? . . . . . . . . . . . . . . . . . . . . 20 1.4 Existence d’objets spécifiques: les spanners . . . . . . . . . . . . . . . . . . 22 Bibliographie . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 2 Algorithmesexacts 33 2.1 Temps polynomial vs. exponentiel . . . . . . . . . . . . . . . . . . . . . . . 33 2.2 Problèmes jouets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 2.3 Algorithmes exhaustifs (brute force) . . . . . . . . . . . . . . . . . . . . . . 37 2.4 Complexité paramétrique: définition . . . . . . . . . . . . . . . . . . . . . 40 2.5 À propos de Sat . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 2.6 À propos des circuits booléens . . . . . . . . . . . . . . . . . . . . . . . . . 45 2.7 Arbre borné de recherche . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 2.7.1 Couverture par sommets de taille k . . . . . . . . . . . . . . . . . 48 2.7.2 Ensemble indépendant pour les graphes planaires . . . . . . . . . 50 2.7.3 Ensemble dominant pour les graphes planaires . . . . . . . . . . . 53 2.7.4 Améliorations : raccourcissement de l’arbre . . . . . . . . . . . . . 59 2.8 Réduction à un noyau : «kernelisation» . . . . . . . . . . . . . . . . . . . 62 2.8.1 Principe et propriété . . . . . . . . . . . . . . . . . . . . . . . . . . 62 2.8.2 Exemple de noyau . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 vi 2.8.3 Couverture par sommets . . . . . . . . . . . . . . . . . . . . . . . 66 2.8.4 Noyau et approximation . . . . . . . . . . . . . . . . . . . . . . . . 71 2.8.5 À propos des noyaux . . . . . . . . . . . . . . . . . . . . . . . . . . 72 2.9 Théorie des mineurs de graphes . . . . . . . . . . . . . . . . . . . . . . . . 73 2.9.1 Définition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73 2.9.2 Théorème des mineurs de graphes . . . . . . . . . . . . . . . . . . 75 2.9.3 Applications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76 2.10 Réduction aux graphes de tree-width bornée . . . . . . . . . . . . . . . . . 80 2.10.1 Décomposition arborescente . . . . . . . . . . . . . . . . . . . . . . 81 2.10.2 Calcul de décomposition arborescente . . . . . . . . . . . . . . . . 84 2.10.3 Un exemple simple: 3-Coloration . . . . . . . . . . . . . . . . . . 90 2.10.4 Ensemble dominant pour tree-width bornée . . . . . . . . . . . . . 93 2.10.5 Application aux graphes planaires . . . . . . . . . . . . . . . . . . 96 2.10.6 Amélioration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 2.11 Remarques finales . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104 2.12 Algorithme progressif pour Ensemble dominant . . . . . . . . . . . . . . 105 2.12.1 L’algorithme . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 2.12.2 Graphes nul part denses . . . . . . . . . . . . . . . . . . . . . . . . 109 2.12.3 Performances . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 2.13 Technique de coloration (color coding) . . . . . . . . . . . . . . . . . . . . . 112 Bibliographie . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 123 3 Algorithmesd’approximation 125 3.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125 3.1.1 Définition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126 3.1.2 Problème inapproximable . . . . . . . . . . . . . . . . . . . . . . . 128 3.1.3 Certificat positif, négatif . . . . . . . . . . . . . . . . . . . . . . . . 129 3.2 Problèmes bien caractérisés . . . . . . . . . . . . . . . . . . . . . . . . . . 130 3.2.1 Couplage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130 3.2.2 Les problèmes min-max . . . . . . . . . . . . . . . . . . . . . . . . 134 3.2.3 Comment concevoir un algorithme d’approximation? . . . . . . . 136 3.3 Couverture par sommets de taille minimum . . . . . . . . . . . . . . . . 138 vii 3.3.1 Un premier algorithme . . . . . . . . . . . . . . . . . . . . . . . . . 138 3.3.2 Un second algorithme . . . . . . . . . . . . . . . . . . . . . . . . . 139 3.3.3 Technique de pré-calcul (color coding) . . . . . . . . . . . . . . . . 140 3.3.4 Technique par programmation linéaire (LP) . . . . . . . . . . . . . 143 3.4 Couverture par ensembles . . . . . . . . . . . . . . . . . . . . . . . . . . . 146 3.4.1 Algorithme glouton . . . . . . . . . . . . . . . . . . . . . . . . . . . 148 3.4.2 Un second algorithme . . . . . . . . . . . . . . . . . . . . . . . . . 154 3.4.3 Plus encore . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156 3.4.4 Un algorithme exact . . . . . . . . . . . . . . . . . . . . . . . . . . 158 Bibliographie . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161 viii Avant-propos Ces notes retranscrivent deux cours de Master 2. L’un intitulé «Analyse d’Algo- ff rithme»etl’autre«AlgorithmiqueAppliquée»dontlesobjectifssontunpeudi érents. Pourlecoursd’AlgorithmiqueAppliquée,lechapitre1n’estpasnécessaireavecl’Avant- propos. Pour le cours d’Analyse d’Algorithme peut commencer dès le chapitre 1. Objectifs Il y a deux objectifs pour le cours d’ Algorithmique Appliquée : • Balayer quelques techniques/approches algorithmiques pour résoudre des pro- blèmes rencontrés en «Recherche et Développement» (R&D). Analyser ces tech- niques pour comprendre pourquoi elles marchent, identifier leurs points forts et leurs faiblesses. Car en algorithmique tout est question de compromis : tel algo- ffi rithme sera e cace pour tel type de données. Et c’est à l’algorithme de s’adapter aux données. • Programmer ces approches et les tester sur un problème en grandeur réelle. Cela se traduira par un projet, dont quelques uns sont décrits page 12, qui s’étalera pendant la durée du cours soit un semestre. Exemples d’applications et de problèmes R&D En règle générale on est confronté à plein de données, beaucoup de contraintes et le problème n’est pas bien défini. Les contraintes principales étant : il faut produire rapidementunesolutionetquecelamarchesurlesexemplesfournisparleclient.Voici ffi quelques exemples, que l’on espère su samment bien définis. Ex1. Reconstruction de code génétique à partir de fragments. On dispose d’un ensemble de gènes, chacun codé par des mots, disons sur l’alpha- bet {A,C,G,T}, et l’on cherche une façon de les ordonner de sorte que i-ème gène dans cet ordre, disons g , matche éventuellement avec g sur un segment et que le nombre i i+1 2 total de lettres matchantes des segments entre gènes successifs soit le plus grand pos- sible. On donne aussi des contraintes sur les ordres possibles, comme le fait que deux gènes donnés ne doivent pas se suivre. Autrement dit toutes les permutations (ordres) possibles ne sont pas permises. PouruneentreprisequidéveloppedestestsouprofilsADN,unetechniquealgorith- ffi mique plus e cace que les entreprises concurrentes peut mener à des gains substan- tiels. Ex2. Simulateur de vol réaliste (stage M2, 2017). Une entreprise de jeu vidéo veut développer en partenariat avec Microsoft™ un si- mulateur de vol basé sur les cartes de la terre, cartes basées sur des images satellites de Bing Maps. Le problème est donc de synthétiser ces cartes de façon à pouvoir déduire lesaltitudesetdepouvoirchangerainsiàvolonté(dujoueuretdusimulateur)lespers- pectives, l’éclairage, l’ombrage, la visibilité, etc. Ce travail existe déjà pour les cartes urbaines, mais pas pour les paysages. Les images satellites sont des tuilages bitmaps et il convient de détecter les textures (végétation, eau, ...) malgré les ombres. L’extraction ffi desombrespermettentaussidedéduirelesaltitudes.Leproblèmeestdi cileenparti- culier pour les montagnes enneigées où l’identification des ombres et des rochers n’est pas facile. Il a fallu développer de nombreuses solutions algorithmiques, après une re- cherche bibliographique sur le sujet, et faire des compromis (vitesse de calcul, qualité ffi durésultat,di cultéàprogrammerl’algorithmeetdoncàmaintenirlecoderésultant). Ex3. Collecte d’ordure. Il s’agit de produire un logiciel permettant d’optimiser la collecte des ordures in- cluantdenombreusescontraintes:sensinterdits,horairesetjourdemarcher,planning des équipes et des tournées, vidage des camions. Bien sûr, utiliser les cartes de l’IGN nécessite des droits et licences que les entreprises ne peuvent pas toutes se payer. Il y a doncunsystème«maison»derécoltedescartesàbasedeGPSdanslescamionspourla reconstruction des routes. La reconstruction des routes est un problème à part entière. Aprèsunemodélisationsnontriviale,celarevientàrésoudreunproblèmeduVoya- geur de commerce (ou une de ces variantes). Seméfierdel’optimisationduprogrammeenfonctiond’unjeud’essailimité(parfois à un seul exemple). Via des paramètres que l’on optimise au fur et à mesure des essais, on peut, sans s’en apercevoir, coder en dure la solution optimale. On le voit parfois : des constantes arbitraires apparaissent, et elles permettent de meilleures solutions. Si leproblèmeestprochedeceluiduVoyageurdecommerce,onpeutparexemplemettre despoidssurlessommetspourquel’algorithmedéveloppéprivilégiecertainspoints,et ne pas se rendre compte qu’on est en train de coder la solution. C’est aussi le problème du «sur-apprentissage» (overfitting) que l’on observe dans les algorithmes d’apprentis- sages (machine learning) où il y a trop de paramètres par rapport aux données.

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.