´ UNIVERSITE CATHOLIQUE DE LOUVAIN ´ ´ FACULTE DES SCIENCES APPLIQUEES ´ ´ DEPARTEMENT D’INGENIERIE INFORMATIQUE La programmation en premi`ere ann´ee bas´ee sur l’enrichissement progressif de micromondes multi-agents (Partie II) M´emoire pr´esent´e en vue de l’obtention du grade de Licenci´e en Informatique Promoteur : Peter Van Roy par Gregory de le Vingne Maxime Romain et C´ecile Toint Louvain-la-Neuve 16 aouˆt 2007 Nous souhaitons remercier : Notre promoteur, le professeur Peter Van Roy pour son enthousiasme, sa motivation et son soutien. Nos lecteurs, Manuel Kolp et Kim Mens. Les assistants-chercheurs de l’´equipe de Peter Van Roy, tout particuli`erement Boris Mejias, pour avoir support´e avec le sourire nos incursions r´eguli`ere dans son bureau. Monsieur Vanneck pour nous avoir permis de disposer des salles informatique. Les ´etudiants qui ont particip´e `a nos s´eances de cours, pour leur tol´erance et leurs conseils avis´es. Le professeur Philippe Toint pour ses relectures et ses remarques constructives sans lesquelles nous n’aurions pu optimiser ce m´emoire. Christoph Bastin pour sa relecture orthographique. Nos amis et proches : Adeline, Audrey, Elley, Jade, Jonathan, Manu, Muriel, Rose-Marie, Sarah, le kotmanga 2006-2007, ansi que beaucoup d’autres qui se reconnaˆıtront, pour leur pr´esence. ´ El´ephant pour le transfert incessant de donn´ees. Finalement, nos parents pour leur soutien continu tout au long de nos ´etudes. 1 Table des mati`eres Introduction 12 1 Choix de l’Approche Employ´ee 16 1.1 Les approches classiques . . . . . . . . . . . . . . . . . . . . . 17 1.1.1 La programmation orient´ee objet . . . . . . . . . . . . 17 1.1.2 La programmation fonctionnelle . . . . . . . . . . . . . 19 1.1.3 La programmation orient´ee agent . . . . . . . . . . . . 19 1.2 L’approche par agents dans des micromondes . . . . . . . . . . 21 2 Approche Par Enrichissement de Micromondes 24 2.1 Pr´esentation globale . . . . . . . . . . . . . . . . . . . . . . . 24 2.2 Succession des micromondes . . . . . . . . . . . . . . . . . . . 25 2.3 Premier micromonde : First Steps . . . . . . . . . . . . . . . . 28 2.3.1 Pr´esentation . . . . . . . . . . . . . . . . . . . . . . . . 28 2.3.2 Concepts abord´es . . . . . . . . . . . . . . . . . . . . . 28 2.3.3 Impl´ementation . . . . . . . . . . . . . . . . . . . . . . 29 2.3.4 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . 32 2.4 Deuxi`eme micromonde : Procedures and Recursion . . . . . . 32 2.4.1 Pr´esentation . . . . . . . . . . . . . . . . . . . . . . . . 32 2.4.2 Concepts abord´es . . . . . . . . . . . . . . . . . . . . . 32 2.4.3 Impl´ementation . . . . . . . . . . . . . . . . . . . . . . 33 2.4.4 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . 35 2.5 Troisi`eme micromonde : Multi Agents . . . . . . . . . . . . . . 38 2.5.1 Pr´esentation . . . . . . . . . . . . . . . . . . . . . . . . 38 2.5.2 Concepts abord´es . . . . . . . . . . . . . . . . . . . . . 38 2.5.3 Impl´ementation . . . . . . . . . . . . . . . . . . . . . . 38 2.5.4 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . 42 2.6 Quatri`eme micromonde : Time . . . . . . . . . . . . . . . . . . 42 2.6.1 Pr´esentation . . . . . . . . . . . . . . . . . . . . . . . . 42 2.6.2 Concepts abord´es . . . . . . . . . . . . . . . . . . . . . 42 2.6.3 Impl´ementation . . . . . . . . . . . . . . . . . . . . . . 43 2 2.6.4 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . 44 2.7 Cinqui`eme micromonde : New Agents . . . . . . . . . . . . . . 45 2.7.1 Pr´esentation . . . . . . . . . . . . . . . . . . . . . . . . 45 2.7.2 Concepts abord´es . . . . . . . . . . . . . . . . . . . . . 45 2.7.3 Impl´ementation . . . . . . . . . . . . . . . . . . . . . . 45 2.7.4 Interfaces . . . . . . . . . . . . . . . . . . . . . . . . . 50 2.7.5 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . 50 2.8 Sixi`eme micromonde : Logoz Agent . . . . . . . . . . . . . . . 53 2.8.1 Pr´esentation . . . . . . . . . . . . . . . . . . . . . . . . 53 2.8.2 Concepts abord´es . . . . . . . . . . . . . . . . . . . . . 53 2.8.3 Impl´ementation . . . . . . . . . . . . . . . . . . . . . . 53 2.8.4 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . 54 2.9 Septi`eme micromonde : Network . . . . . . . . . . . . . . . . . 55 2.9.1 Pr´esentation . . . . . . . . . . . . . . . . . . . . . . . . 55 2.9.2 Concepts abord´es . . . . . . . . . . . . . . . . . . . . . 56 2.9.3 Impl´ementation . . . . . . . . . . . . . . . . . . . . . . 56 2.9.4 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . 57 3 Environnement de Programmation : LogOz 2.0 59 3.1 Architecture du logiciel . . . . . . . . . . . . . . . . . . . . . . 60 3.2 Impl´ementation des agents . . . . . . . . . . . . . . . . . . . . 61 3.3 LogOz . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 3.4 L’interface graphique . . . . . . . . . . . . . . . . . . . . . . . 63 3.4.1 Le choix du micromonde . . . . . . . . . . . . . . . . . 63 3.4.2 Le bloc notes (ou notepad) . . . . . . . . . . . . . . . . 65 3.4.3 Le browser . . . . . . . . . . . . . . . . . . . . . . . . . 67 3.4.4 La feuille de dessin ou canvas . . . . . . . . . . . . . . 70 3.4.5 Les menus . . . . . . . . . . . . . . . . . . . . . . . . . 71 3.4.6 Les boutons . . . . . . . . . . . . . . . . . . . . . . . . 80 3.4.7 Le compilateur et l’environnement . . . . . . . . . . . . 81 3.5 Am´eliorations du programme et r´esolution des probl`emes . . . 84 4 Enseignement et P´edagogie 89 4.1 D´emarches . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89 4.2 Organisation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 91 4.3 S´eances de cours . . . . . . . . . . . . . . . . . . . . . . . . . 92 4.3.1 Premi`ere s´eance . . . . . . . . . . . . . . . . . . . . . . 92 4.3.2 Deuxi`eme s´eance . . . . . . . . . . . . . . . . . . . . . 94 4.3.3 Troisi`eme s´eance . . . . . . . . . . . . . . . . . . . . . 97 4.3.4 Quatri`eme s´eance . . . . . . . . . . . . . . . . . . . . . 99 4.3.5 Cinqui`eme s´eance . . . . . . . . . . . . . . . . . . . . . 100 3 4.3.6 Sixi`eme s´eance . . . . . . . . . . . . . . . . . . . . . . 103 4.3.7 Septi`eme s´eance . . . . . . . . . . . . . . . . . . . . . . 106 4.3.8 Huiti`eme s´eance . . . . . . . . . . . . . . . . . . . . . . 109 4.3.9 Neuvi`eme s´eance . . . . . . . . . . . . . . . . . . . . . 111 4.3.10 Dixi`eme s´eance . . . . . . . . . . . . . . . . . . . . . . 112 4.3.11 Onzi`eme, douzi`eme et treizi`eme s´eances . . . . . . . . . 115 4.3.12 Quatorzi`eme s´eance . . . . . . . . . . . . . . . . . . . . 124 4.3.13 Quinzi`eme s´eance . . . . . . . . . . . . . . . . . . . . . 127 4.4 S´eances de cours suppl´ementaires . . . . . . . . . . . . . . . . 138 4.4.1 R´eseau . . . . . . . . . . . . . . . . . . . . . . . . . . . 138 5 R´esultats de la Phase de Test 139 5.1 Remarques et modifications diverses . . . . . . . . . . . . . . . 139 5.2 Avertissement `a destination de l’enseignant . . . . . . . . . . . 142 6 Evaluation 145 6.1 Test de mi-parcours . . . . . . . . . . . . . . . . . . . . . . . . 145 6.1.1 D´efinitions th´eoriques des concepts . . . . . . . . . . . 146 6.1.2 Application des principes basiques de la programmation147 6.1.3 Application du principe de r´ecursion . . . . . . . . . . 147 6.1.4 Concurrence et cr´eation d’agents . . . . . . . . . . . . 148 6.1.5 Identification et r´eparation d’erreurs de compilation et d’ex´ecution . . . . . . . . . . . . . . . . . . . . . . . . 148 6.2 Exercices suppl´ementaires . . . . . . . . . . . . . . . . . . . . 149 6.2.1 Principe . . . . . . . . . . . . . . . . . . . . . . . . . . 149 6.2.2 Motivation . . . . . . . . . . . . . . . . . . . . . . . . . 149 6.3 Projet . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 150 6.3.1 Objectifs . . . . . . . . . . . . . . . . . . . . . . . . . . 150 6.3.2 Modalit´es pratiques . . . . . . . . . . . . . . . . . . . . 151 ´ 6.3.3 Enonc´e . . . . . . . . . . . . . . . . . . . . . . . . . . . 153 6.3.4 Philosophie d’´evaluation . . . . . . . . . . . . . . . . . 154 6.4 Examen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156 6.4.1 Cotation . . . . . . . . . . . . . . . . . . . . . . . . . . 156 6.4.2 Question rempla¸cant le test . . . . . . . . . . . . . . . 158 6.4.3 Questions th´eoriques . . . . . . . . . . . . . . . . . . . 158 6.4.4 Question pratique . . . . . . . . . . . . . . . . . . . . . 158 7 Critiques et Pistes 160 7.1 Une approche ludique . . . . . . . . . . . . . . . . . . . . . . . 161 7.1.1 Le rˆole du jeu vid´eo dans cette approche . . . . . . . . 161 4 7.1.2 Do computer games have a role in the classroom : un r´esum´e . . . . . . . . . . . . . . . . . . . . . . . . . . . 162 7.1.3 Confrontation avec notre approche . . . . . . . . . . . 164 7.2 Etude comparative . . . . . . . . . . . . . . . . . . . . . . . . 166 7.2.1 Squeak . . . . . . . . . . . . . . . . . . . . . . . . . . . 167 7.2.2 ObjectKarel . . . . . . . . . . . . . . . . . . . . . . . . 168 7.2.3 Remarques g´en´erales . . . . . . . . . . . . . . . . . . . 169 7.3 Pistes pour le futur . . . . . . . . . . . . . . . . . . . . . . . . 169 7.3.1 Am´eliorations du programme . . . . . . . . . . . . . . 170 7.3.2 Cours suppl´ementaires . . . . . . . . . . . . . . . . . . 172 A Cours 181 A.1 Premier Cours : Les d´ebutants avec le logiciel - Micromonde 1 181 A.1.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . 181 A.1.2 Les agents . . . . . . . . . . . . . . . . . . . . . . . . . 182 A.1.3 L’interface . . . . . . . . . . . . . . . . . . . . . . . . . 184 A.1.4 Les instructions . . . . . . . . . . . . . . . . . . . . . . 189 A.1.5 Exercices . . . . . . . . . . . . . . . . . . . . . . . . . 190 A.2 Deuxi`eme Cours : Proc´edures - Micromonde 2 . . . . . . . . . 191 A.2.1 Les proc´edures . . . . . . . . . . . . . . . . . . . . . . 191 A.2.2 Les arguments . . . . . . . . . . . . . . . . . . . . . . . 191 A.2.3 Proc´edures et arguments . . . . . . . . . . . . . . . . . 192 A.2.4 Dessins proc´edurals . . . . . . . . . . . . . . . . . . . . 194 A.2.5 Exercice . . . . . . . . . . . . . . . . . . . . . . . . . . 197 A.3 Troisi`eme Cours : Op´erateurs et expressions conditionnelles - Micromonde 2 . . . . . . . . . . . . . . . . . . . . . . . . . . . 199 A.3.1 Les op´erateurs . . . . . . . . . . . . . . . . . . . . . . . 199 A.3.2 Les expressions conditionnelles . . . . . . . . . . . . . . 200 A.3.3 Exercices . . . . . . . . . . . . . . . . . . . . . . . . . 204 A.4 Quatri`eme Cours : Nouvelle structure de donn´ees : Les Listes - Micromonde 2 . . . . . . . . . . . . . . . . . . . . . . . . . . 205 A.4.1 D´efinitions . . . . . . . . . . . . . . . . . . . . . . . . . 205 A.4.2 Op´erations sur les listes . . . . . . . . . . . . . . . . . 206 A.4.3 Exercices . . . . . . . . . . . . . . . . . . . . . . . . . 208 A.5 Cinqui`eme Cours : La R´ecursion - Micromonde 2 . . . . . . . 209 A.5.1 Th´eorie . . . . . . . . . . . . . . . . . . . . . . . . . . 209 A.5.2 Premi`ere Approche . . . . . . . . . . . . . . . . . . . . 212 A.5.3 Seconde Approche . . . . . . . . . . . . . . . . . . . . 216 A.5.4 Exercices . . . . . . . . . . . . . . . . . . . . . . . . . 217 A.6 Sixi`eme Cours : Multi-Turtles - Micromonde 3 . . . . . . . . . 219 A.6.1 Agent : Rappel de le d´efinition . . . . . . . . . . . . . . 219 5 ´ A.6.2 Etat . . . . . . . . . . . . . . . . . . . . . . . . . . . . 219 A.6.3 Cerveau . . . . . . . . . . . . . . . . . . . . . . . . . . 221 A.6.4 Cr´eation d’un nouvel agent tortue . . . . . . . . . . . . 221 A.6.5 Concurrence . . . . . . . . . . . . . . . . . . . . . . . . 223 A.6.6 Exercices . . . . . . . . . . . . . . . . . . . . . . . . . 224 A.7 Septi`eme Cours : Le Temps - Micromonde 4 . . . . . . . . . . 226 A.7.1 Objectif . . . . . . . . . . . . . . . . . . . . . . . . . . 226 A.7.2 L’Agent M´etronome . . . . . . . . . . . . . . . . . . . 226 A.7.3 Exemple . . . . . . . . . . . . . . . . . . . . . . . . . . 228 A.7.4 Exercice . . . . . . . . . . . . . . . . . . . . . . . . . . 228 A.7.5 Exercices de r´evision . . . . . . . . . . . . . . . . . . . 228 A.8 Huiti`eme Cours : Les Agents - Micromonde 5 . . . . . . . . . 229 A.8.1 Objectifs . . . . . . . . . . . . . . . . . . . . . . . . . . 229 A.8.2 Cr´eation d’un nouvel agent . . . . . . . . . . . . . . . . 229 A.8.3 Exercice : une horloge . . . . . . . . . . . . . . . . . . 231 A.8.4 Autres exercices . . . . . . . . . . . . . . . . . . . . . . 232 A.9 Neuvi`eme Cours : Test de mi-parcours et explication du projet 234 A.9.1 Test (20 points) . . . . . . . . . . . . . . . . . . . . . . 234 A.9.2 Projet : Pong . . . . . . . . . . . . . . . . . . . . . . . 237 A.10 Dixi`eme Cours : Introduction aux diagrammes . . . . . . . . . 239 A.10.1 Objectifs . . . . . . . . . . . . . . . . . . . . . . . . . . 239 A.10.2 Diagrammes de s´equence[18] . . . . . . . . . . . . . . . 239 A.10.3 Diagramme d’´etat . . . . . . . . . . . . . . . . . . . . . 241 A.10.4 Un exemple . . . . . . . . . . . . . . . . . . . . . . . . 242 A.10.5 Exercices . . . . . . . . . . . . . . . . . . . . . . . . . 244 A.11 Onzi`eme, Douzi`eme et Treizi`eme Cours : Projet “Space Inva- ders” - Micromonde 5 . . . . . . . . . . . . . . . . . . . . . . 246 A.11.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . 246 A.11.2 Mod´elisation . . . . . . . . . . . . . . . . . . . . . . . 247 A.11.3 Impl´ementation . . . . . . . . . . . . . . . . . . . . . . 249 A.12 Quatorzi`eme Cours : Les threads - Micromonde 5 . . . . . . . 249 A.12.1 Concurrence . . . . . . . . . . . . . . . . . . . . . . . . 249 A.13 Quinzi`eme Cours : Composition d’agents - Micromonde 5 . . . 256 A.13.1 Un exemple : Le distributeur de boissons . . . . . . . . 256 A.14 Cours Suppl´ementaire sur le R´eseau - Micromonde 7 . . . . . 258 A.14.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . 258 A.14.2 Les Turtles en r´eseau dans Logoz . . . . . . . . . . . . 258 A.14.3 Exemples . . . . . . . . . . . . . . . . . . . . . . . . . 259 A.14.4 Exercices . . . . . . . . . . . . . . . . . . . . . . . . . 260 6 B Examen 261 ` B.1 PREMIERE PARTIE . . . . . . . . . . . . . . . . . . . . . . . 261 B.2 SECONDE PARTIE . . . . . . . . . . . . . . . . . . . . . . . 262 B.2.1 Th´eorie . . . . . . . . . . . . . . . . . . . . . . . . . . 262 B.2.2 Pratique . . . . . . . . . . . . . . . . . . . . . . . . . . 264 C Le projet Ping-pong 269 C.1 Notre vision du jeu de ping-pong . . . . . . . . . . . . . . . . 269 C.2 Les ´etats des agents . . . . . . . . . . . . . . . . . . . . . . . . 271 C.3 Fonctions et proc´edures donn´ees . . . . . . . . . . . . . . . . . 271 C.3.1 Fonctions de dessin . . . . . . . . . . . . . . . . . . . . 271 C.3.2 Proc´edure pour d´eplacer une image . . . . . . . . . . . 271 C.3.3 D´eplacement des palettes . . . . . . . . . . . . . . . . . 272 C.3.4 Fonction Random . . . . . . . . . . . . . . . . . . . . . 272 C.3.5 Fonctions sinus, cosinus et conversion nombre entier nombre `a virgule . . . . . . . . . . . . . . . . . . . . . 272 C.3.6 Exemple de fonction de transition . . . . . . . . . . . . 273 D Questionnaire d’E´valuation 276 7 Table des figures ´ 2.1 Diagramme de l’Etat de la tortue . . . . . . . . . . . . . . . . 30 2.2 Tortue `a son initialisation . . . . . . . . . . . . . . . . . . . . 31 2.3 Proc´edure Triangle . . . . . . . . . . . . . . . . . . . . . . . . 33 2.4 Proc´edure Repeat . . . . . . . . . . . . . . . . . . . . . . . . . 34 2.5 Proc´edure illustrant la fonction Repeat . . . . . . . . . . . . . 34 2.6 Autre proc´edure illustrant la fonction Repeat . . . . . . . . . 34 2.7 Arbre r´ecursif . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 2.8 Dessin d’une fractale . . . . . . . . . . . . . . . . . . . . . . . 37 2.9 Fractale utilisant la notion de fonction . . . . . . . . . . . . . 39 2.10 Un dessin“collaboratif” . . . . . . . . . . . . . . . . . . . . . 41 2.11 Diagramme d’´etat de l’agent M´etronome . . . . . . . . . . . . 44 2.12 Interaction entre un agent Metronome et deux tortues . . . . 44 2.13 Prototype d’une fonction de transition . . . . . . . . . . . . . 46 ´ 2.14 Diagramme d’Etat de l’horloge . . . . . . . . . . . . . . . . . 51 2.15 L’interface “horloge” . . . . . . . . . . . . . . . . . . . . . . . 51 2.16 L’interface Pong . . . . . . . . . . . . . . . . . . . . . . . . . 52 2.17 L’interface Space Invaders . . . . . . . . . . . . . . . . . . . . 52 2.18 Repr´esentation des tortues en r´eseau . . . . . . . . . . . . . . 58 3.1 Architecture Logique du Logiciel . . . . . . . . . . . . . . . . 60 3.2 Impl´ementation du port object . . . . . . . . . . . . . . . . . 62 3.3 Le logiciel LogOz sous Windows XP . . . . . . . . . . . . . . 64 3.4 La fenˆetre d’accueil de LogOz . . . . . . . . . . . . . . . . . . 65 3.5 Le Bloc notes et sa fonction de colorisation . . . . . . . . . . . 67 3.6 Le browser . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 3.7 Le code du browser dans User.oz . . . . . . . . . . . . . . . . 69 3.8 Le code du browser dans LogozGraphics.oz . . . . . . . . . . . 70 3.9 La monde de la tortue : un tore . . . . . . . . . . . . . . . . . 71 3.10 Menu File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72 3.11 Sauvegarde de fichier . . . . . . . . . . . . . . . . . . . . . . . 73 3.12 Ouverture de fichier . . . . . . . . . . . . . . . . . . . . . . . . 74 8 3.13 Fermeture de l’application . . . . . . . . . . . . . . . . . . . . 74 3.14 Exemple de l’utilisation de la fonction ’Load Agent’. . . . . . . 76 3.15 Le menu Edit . . . . . . . . . . . . . . . . . . . . . . . . . . . 77 3.16 Le menu Kill . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 3.17 Le menu Help . . . . . . . . . . . . . . . . . . . . . . . . . . . 80 3.18 Les Boutons Run et Clear World . . . . . . . . . . . . . . . . 80 4.1 Proc´edure Carre avec argument . . . . . . . . . . . . . . . . 95 4.2 Dessin d’un oeil de mani`ere proc´edurale . . . . . . . . . . . . 96 4.3 Dessin d’un donut de mani`ere proc´edurale . . . . . . . . . . . 97 4.4 Expression if... else... end en Oz . . . . . . . . . . . . . . . . . 98 4.5 Pattern Matching en Oz . . . . . . . . . . . . . . . . . . . . . 98 4.6 Proc´edure ex´ecutant plusieurs forward utilisant la r´ecursion . 101 4.7 Proc´edure R´ecursive dessinant une spirale . . . . . . . . . . . 102 4.8 Algorithme r´ecursif de construction d’un arbre . . . . . . . . 102 4.9 Dessin r´ecursif d’un arbre . . . . . . . . . . . . . . . . . . . . 103 4.10 Deux tortues ´evoluant dans le mˆeme micromonde . . . . . . . 106 4.11 Code d’un carr´e impl´ement´e de mani`ere concurencielle . . . . 107 4.12 Dessin de carr´e de mani`ere concurrentielle . . . . . . . . . . . 107 4.13 L’Horloge dans LogOz . . . . . . . . . . . . . . . . . . . . . . 111 4.14 Diagramme de s´equence . . . . . . . . . . . . . . . . . . . . . 113 4.15 Diagramme d’´etat d’une porte . . . . . . . . . . . . . . . . . 114 4.16 Un diagramme de s´equence simplifi´e du Space Invaders . . . . 117 4.17 Repr´esentation d’un programme s´equentiel . . . . . . . . . . . 126 4.18 Repr´esentation d’un programme concurrent . . . . . . . . . . 126 4.19 Communicationentreunthreadproducteuretunthreadconsom- mateur . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126 4.20 Communicationentreunthreadproducteur,unthreadconsom- mateur et un thread traducteur . . . . . . . . . . . . . . . . . 127 5.1 Explication du d´eroulement de l’exercice de l’arbre . . . . . . 141 7.1 L’interface de programme Squeak . . . . . . . . . . . . . . . . 168 7.2 Deux tortues `a la recherche de salades . . . . . . . . . . . . . 174 A.1 Diagramme de s´equence . . . . . . . . . . . . . . . . . . . . . 240 A.2 Diagramme d’´etat d’une porte . . . . . . . . . . . . . . . . . 241 A.3 Diagramme de s´equence de l’horloge . . . . . . . . . . . . . . 243 A.4 Diagramme de s´equence de l’horloge . . . . . . . . . . . . . . 244 B.1 Exemple d’arbre binaire r´ecursif . . . . . . . . . . . . . . . . 262 9
Description: