Machines virtuelles fonctionnelles (suite) Compilation ML Java



Documents pareils
Programmer en JAVA. par Tama

Cours de Programmation 2

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère

Classes et Objets en Ocaml.

Java Licence Professionnelle CISII,

TP1 : Initiation à Java et Eclipse

LMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr

Cours 1 : La compilation

Projet de programmation (IK3) : TP n 1 Correction

Chapitre VI- La validation de la composition.

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

Cours No 3 : Identificateurs, Fonctions, Premières Structures de contrôle.

Langage Java. Classe de première SI

Structure d un programme et Compilation Notions de classe et d objet Syntaxe

Une introduction à Java

Gestion mémoire et Représentation intermédiaire

Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre Enrica.Duchi@liafa.jussieu.fr

length : A N add : Z Z Z (n 1, n 2 ) n 1 + n 2

Plan du cours. Historique du langage Nouveautés de Java 7

Java Licence Professionnelle Cours 7 : Classes et méthodes abstraites

TD3: tableaux avancées, première classe et chaînes

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars

Arbres binaires de recherche

Algorithmique et Programmation, IMA

Expression des contraintes. OCL : Object C o n t r a i n t L a n g u a g e

Auto-évaluation Programmation en Java

Licence Bio Informatique Année Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...

Objets et Programmation. origine des langages orientés-objet

Langage et Concepts de ProgrammationOrientée-Objet 1 / 40

as Architecture des Systèmes d Information

Java Licence Professionnelle CISII, Cours 2 : Classes et Objets

Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004

Chapitre 10. Les interfaces Comparable et Comparator 1

Corrigé des exercices sur les références

1. Structure d un programme C. 2. Commentaire: /*..texte */ On utilise aussi le commentaire du C++ qui est valable pour C: 3.

Encapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets.

TD/TP PAC - Programmation n 3

# let rec concat l1 l2 = match l1 with [] -> l2 x::l 1 -> x::(concat l 1 l2);; val concat : a list -> a list -> a list = <fun>

Java 1.5 : principales nouveautés

Héritage presque multiple en Java (1/2)

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile

F. Barthélemy. 17 mai 2005

JADE : Java Agent DEvelopment framework. Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.

Rappel. Analyse de Données Structurées - Cours 12. Un langage avec des déclaration locales. Exemple d'un programme

Recherche dans un tableau

Programmation en Java IUT GEII (MC-II1) 1

modules & compilation

Utilisation d objets : String et ArrayList

Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;

INITIATION AU LANGAGE JAVA

Premiers Pas en Programmation Objet : les Classes et les Objets

Cours de C++ François Laroussinie. 2 novembre Dept. d Informatique, ENS de Cachan

Java c est quoi? Java pourquoi?

Polymorphisme, la classe Object, les package et la visibilité en Java... 1

Tp 1 correction. Structures de données (IF2)

ACTIVITÉ DE PROGRAMMATION

INF 321 : mémento de la syntaxe de Java

Programmation Par Objets

Introduction au langage C

RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION)

Théorie de la Programmation

Classe Interne, Anonyme & Enumération

Présentation du langage et premières fonctions

Compilation (INF 564)

Package Java.util Classe générique

Traduction des Langages : Le Compilateur Micro Java

Certificat Big Data - Master MAthématiques

Arguments d un programme

Quelques patterns pour la persistance des objets avec DAO DAO. Principe de base. Utilité des DTOs. Le modèle de conception DTO (Data Transfer Object)

Initiation à l algorithmique

TP1. Outils Java Eléments de correction

Cours de C. Petits secrets du C & programmation avancée. Sébastien Paumier

TP 1. Prise en main du langage Python

Un ordonnanceur stupide

INITIATION AU LANGAGE C SUR PIC DE MICROSHIP

TD/TP PAC - Programmation n 3

Généralités sur le Langage Java et éléments syntaxiques.

Cours d Algorithmique-Programmation 2 e partie (IAP2): programmation 24 octobre 2007impérative 1 / 44 et. structures de données simples

Info0101 Intro. à l'algorithmique et à la programmation. Cours 3. Le langage Java

Programmation Objet Java Correction

Cours 1: Java et les objets

Langage propre à Oracle basé sur ADA. Offre une extension procédurale à SQL

P r ob lé m a t iq u e d e la g é n é r icit é. Pr in cip e d e la g é n é r icit é e n Ja v a ( 1 /3 )

Java Licence Professionnelle CISII,

PROGRAMMATION PAR OBJETS

Initiation à JAVA et à la programmation objet.

UE Programmation Impérative Licence 2ème Année

Serveur d'application Client HTML/JS. Apache Thrift Bootcamp

Langage et Concepts de Programmation Objet. 1 Attributs et Méthodes d instance ou de classe. Travaux Dirigés no2

Aide mémoire UML & Java 1ère partie : Introduction. marc.lemaire@u-cergy.fr

Programmation. fonctionnelle, impérative, logique et orientée objet

TP3 : Manipulation et implantation de systèmes de fichiers 1

Cours 1 : Introduction. Langages objets. but du module. contrôle des connaissances. Pourquoi Java? présentation du module. Présentation de Java

Programmation Orientée Objet Java

RMI le langage Java XII-1 JMF

Programmation avec des objets : Cours 7. Menu du jour

Exercices sur les interfaces

Programmation MacOSX / ios

Corrigés des premiers exercices sur les classes

Cette application développée en C# va récupérer un certain nombre d informations en ligne fournies par la ville de Paris :

Transcription:

Machines virtuelles fonctionnelles (suite) Compilation ML Java Cours de Compilation Avancée (MI190) Benjamin Canou Université Pierre et Maire Curie Année 2011/2012 Semaine 3

Machines virtuelles fonctionnelles (suite)

La ZAM : machine fonctionnelle stricte Schéma dérivé de la machine de Krivine : Le corps d une instruction commence par GRAB, comme les fonctions ont plusieurs arguments, le code ressemble en fait à : [GRAB;n args ;...;RETURN] les arguments sont passés sur la pile par les instructions APPLY{1,2,3 + compteur extra_args GRAB applique la fonction (évaluation stricte) si elle trouve les arguments nécessaires, sinon, elle crée une fermeture.

La ZAM : application générale Comment s exécute le programme suivant? # open Printf;; # let separe sep = let rec aux i str = if i < String.length str then ( printf "%c%c" str.[i] sep ; aux (i + 1) str ) in aux 0;; val separe : char -> string -> unit = <fun> # separe ',';; - : string -> unit = <fun> # separe ',' "toto";; t,o,t,o, - : unit = () Grâce à CLOSURE, APPLY, GRAB et RETURN

La ZAM : CLOSURE Instruct(CLOSURE): { int nvars = *pc++; int i; if (nvars > 0) *--sp = accu; Alloc_small(accu, 1 + nvars, Closure_tag); Code_val(accu) = pc + *pc; pc++; for (i = 0; i < nvars; i++) Field(accu, i + 1) = sp[i]; sp += nvars; Next;

La ZAM : APPLY Instruct(APPLY2): { value arg1 = sp[0]; value arg2 = sp[1]; sp -= 3; sp[0] = arg1; sp[1] = arg2; sp[2] = (value)pc; sp[3] = env; sp[4] = Val_long(extra_args); pc = Code_val(accu); env = accu; extra_args = 1; goto check_stacks;

La ZAM : GRAB Instruct(GRAB): { int required = *pc++; if (extra_args >= required) { extra_args -= required; else { mlsize_t num_args, i; num_args = 1 + extra_args; /* arg1 + extra args */ Alloc_small(accu, num_args + 2, Closure_tag); Field(accu, 1) = env; for (i = 0; i < num_args; i++) Field(accu, i + 2) = sp[i]; Code_val(accu) = pc - 3; /* Point to the preceding RESTART instr. */ sp += num_args; pc = (code_t)(sp[0]); env = sp[1]; extra_args = Long_val(sp[2]); sp += 3; Next; RESTART effectue la copie environnement pile. Compilation :...RESTART;[GRAB;n args ;...;RETURN]...

La ZAM : RETURN Instruct(RETURN): { sp += *pc++; if (extra_args > 0) { extra_args--; pc = Code_val(accu); env = accu; else { pc = (code_t)(sp[0]); env = sp[1]; extra_args = Long_val(sp[2]); sp += 3; Next;

Compilation ML Java : partie haute

Exemple de code ML compilable let f = function x -> function y -> x + y;; let g = f 3;; let a = g 2;; let q = g, f 7;; let r = ((fst q) 9);; let rec map = function f -> function l -> if l = [] then [] else (f (hd l)) :: (map f (tl l));; let l = 1 :: 2 :: 3 :: [];; let k = map g l;; let k2 = map f l;;

Structure de ml2java util.ml utilitaire types.ml définition des types de mini-ml alex.mll analyseur lexical asyn.mly analyseur syntaxique typeur.ml le typeur env_typeur environnement intertypeur.ml toplevel du typeur * eval.ml évaluateur * env_eval environnement de l évaluateur * intereval.ml toplevel de l évaluateur * env_trans.ml environnement du traducteur lift.ml un pseudo λ-lifting trans.ml le traducteur vers un LI prod.ml le traducteur LI vers java comp.ml le compilateur complet maincomp.ml l analyseur de la ligne de commande

(Retour sur l )analyse lexicale Fichier Suite de lexèmes { open Util ;; open Asyn ;; let keyword_table = Hashtbl.create 100 ;; do_list (fun (str,tok) -> Hashtbl.add keyword_table str tok) [ "else", ELSE; "function", FUNCTION; "if", IF; "in", IN; "let", LET; "rec", REC; ];; "ref", REF; "then", THEN rule main = parse [' ' '\010' '\013' '\009' '\012'] + { main lexbuf ['A'-'Z' 'a'-'z' ] ( '_'? ['A'-'Z' 'a'-'z' '0'-'9' ] ) * { let s = get_lexeme lexbuf in try Hashtbl.find keyword_table s with Not_found -> IDENT s ['0'-'9']+ '0' ['x' 'X'] ['0'-'9' 'A'-'F' 'a'-'f']+ '0' ['o' 'O'] ['0'-'7']+ '0' ['b' 'B'] ['0'-'1']+ { INT (int_of_string(get_lexeme lexbuf))

(Retour sur l )analyse lexicale Fichier Suite de lexèmes "(" { LPAREN ")" { RPAREN "," { COMMA "->" { MINUSGREATER "::" { COLONCOLON ":=" { COLONEQUAL ";" { SEMI ";;" { SEMISEMI "=" { EQUAL "[" { LBRACKET "]" { RBRACKET

(Retour sur l )analyse syntaxique Suite de lexèmes AST Défintion des tokens (utilsés par le lexeur) %token <string> IDENT %token <string> PREFIX %token <string> INFIX %t0oken <int> INT %token <float> FLOAT %token <string> STRING %token EOF %token EQUAL /* "=" */ %token LPAREN /* "(" */ /*... */

(Retour sur l )analyse syntaxique Suite de lexèmes AST Deux niveaux d expressions : simples Simple_expr : Struct_constant { Const $1 IDENT {Var $1 LPAREN RPAREN { Const Unit LBRACKET RBRACKET { Const Emptylist LPAREN Expr RPAREN /* expr -> simple*/ { $2 PREFIX Simple_expr { Unop ( $1,$2)

(Retour sur l )analyse syntaxique Suite de lexèmes AST Deux niveaux d expressions : construites Expr : Simple_expr { $1 Simple_expr Simple_expr_list %prec prec_app {make_apply $1 $2 REF Expr {Ref $2 Simple_expr COMMA Expr {Pair ($1,$3) Simple_expr COLONCOLON Expr {Cons ($1,$3) Simple_expr COLONEQUAL Expr {Binop (":=",$1,$3) IF Expr THEN Expr ELSE Expr { Cond($2, $4, $6) LET IDENT EQUAL Expr IN Expr { Letin (false,$2,$4,$6) FUNCTION IDENT MINUSGREATER Expr { Abs($2,$4)

(Retour sur l )analyse syntaxique Suite de lexèmes AST Résolution des ambiguités avec des priorités %right prec_app Expr : /*... */ Simple_expr Simple_expr_list %prec prec_app {make_apply $1 $2 /*... */ %right prec_if Expr : /*... */ IF Expr THEN Expr ELSE Expr %prec prec_if { Cond($2, $4, $6) IF Expr THEN Expr %prec prec_if { Cond($2, $4, Const Unit) /*... */

(Retour sur l )analyse syntaxique Suite de lexèmes AST Programme : /*... */ %start implementation %type <Types.ml_phrase> implementation %% implementation : Expr SEMISEMI { Expr $1 LET IDENT EQUAL Expr SEMISEMI { Decl (Let(false,$2,$4)) LET REC IDENT EQUAL Expr SEMISEMI { Decl (Let(true,$3,$5)) EOF { raise End_of_file ; /*... */

Arbre de Syntaxe Abstraite type ml_expr = Const of ml_const Var of string Unop of string * ml_expr Binop of string * ml_expr * ml_expr Pair of ml_expr * ml_expr Cons of ml_expr * ml_expr Cond of ml_expr * ml_expr * ml_expr App of ml_expr * ml_expr Abs of string * ml_expr Letin of bool * string * ml_expr * ml_expr Ref of ml_expr Straint of ml_expr * ml_type (* <- après typage *) and ml_const = Int of int Float of float Bool of bool String of string Emptylist Unit type ml_decl = Let of bool * string * ml_expr type ml_phrase = Expr of ml_expr Decl of ml_decl

Typage Types : type vartype = Unknown of int Instanciated of ml_type and consttype = Int_type Float_type String_type Bool_type Unit_type and ml_type = Var_type of vartype ref Const_type of consttype Pair_type of ml_type * ml_type List_type of ml_type Fun_type of ml_type * ml_type Ref_type of ml_type

Typage (ce n est pas le propos de ce cours) typeur.ml : Algorithme de Hindley-Milner : 1. On introduit des inconnues de types dans les expressions, 2. on les spécifie par effet de bord en utilisant le contexte (unification), 3. s il reste des inconnues sous un let, on obtient une valeur polymorphe (généralisation). 4. Erreur de type si l unification ne marche pas. env_typeur.ml : Gestion de l environnement et environnement initial (types des primitives).

Suppression des fonction locales : λ-lifting 1. On part d une déclaration locale, let f x y = let g a = a + x in g y ;; 2. on la remonte au niveau au dessus, let g a = a + x ;; let f x y = g y ;; 3. et on passe l environnement en paramètre explicitement. let g x a = a + x ;; let f x y = g x y ;; Plus compliqué avec les fonctions mutuellement récursives.

Langage intermédiaire Instructions : type li_const = INT of int FLOAT of float BOOL of bool STRING of string EMPTYLIST UNIT type li_instr = CONST of li_const VAR of string * li_type AFFECT of string * li_instr IF of li_instr * li_instr * li_instr PRIM of (string * li_type) * li_instr list APPLY of li_instr * li_instr RETURN of li_instr BLOCK of (string * li_type * li_instr) list * li_instr FUNCTION of string * li_type * int * (string list * li_type) * li_instr

Langage intermédiaire Types : type li_const_type = INTTYPE FLOATTYPE BOOLTYPE STRINGTYPE UNITTYPE type li_type = ALPHA CONSTTYPE of li_const_type PAIRTYPE LISTTYPE FUNTYPE REFTYPE

Schéma de compilation vers LI format des règles [ e ]E -> INSTRUCTION(params) e le motif de code à compiler E l environnement de compilation g : l environnement des noms r : vrai s il faut retourner le résultat d : nom d une éventuelle variable à affecter t : type LI INSTRUCTION le constructeur d instruction params ses paramètres : constantes ou appels de règles

Schéma de compilation vers LI constantes [ c ](g,f,"",t) -> CONST(c,g,t) [ c ](g,t,"",t) -> RETURN(CONST(c,g,t)) [ c ](g,f,d,t) -> AFFECT(D,CONST(c,g,t))

Schéma de compilation vers LI variables [ v ](g,f,"",t) -> VAR(v,g,t) [ v ](g,t,"",t) -> RETURN(VAR(v,g,t)) [ v ](g,f,d,t) -> AFFECT(D,VAR(v,g,t))

Schéma de compilation vers LI conditionnelle [ if v1 then e2 else e3 ](g,r,d,t) -> IF([v1](g,F,"",bool),[e2](g,r,d,t),[e3](g,r,d,t)) [ if e1 then e2 else e3](g,r,d,t) -> [let v1 = e1 in if v1 then e2 else e3](g,r,d,t)

Schéma de compilation vers LI application [ v1 v2 ](g,f,"",t) -> APPLY([v1](g,F,"",_),[v2](g,F,"",_)) [ v1 v2 ](g,t,"",t) -> RETURN(APPLY([v1](g,F,"",_),[v2](g,F,"",_))) [ v1 v2 ](g,f,d,t) -> AFFECT(D,APPLY([v1](g,F,"",_),[v2](g,F,"",_))) [ e1 e2 ](g,r,s,t) -> [let v1 = e1 and v2 = e2 in v1 v2](g,r,s,t)

Schéma de compilation vers LI déclaration locale [let v1 = \x.e1 in e2](g,r,d,t) -> ERREUR!!! [let v1 = e1 in e2](g,r,d,t) -> BLOCK(w1=N(v1),t,[e1](g,F,(w1,t),e2((v1,w1)::g,r,d,t)) PLus de fonction locale (λ-lifting)

Schéma de compilation vers LI déclaration globales [let v1 = \x.e1 ](g,t) -> FUNCTION(w1=N(v1),t,1,[x],[e1](g,T,"",_)) [let rec v1 = \x.e1](g,t) -> FUNCTION(w1=N(v1),t,1,[x],[e1]((x,N(x))::(v1,w1)::g,T,"",_)) [Let v1 = e1](g,t) -> VAR(w1=N(v1),t,[e1](g,false,"w1",t)) [let rec v1 = e1](g,t) -> ERREUR

Compilation ML Java : partie basse

Compilation vers Java On peut utiliser la bibliothèque d exécution de Java pour implanter celle de ML : Gestion mémoire, types primitifs, bibliothèque, exceptions, etc. En contrepartie : il faut coller au système de types.

Définition des valeurs Il faut un typeunique pour les valeurs, qui peut encapsuler différent types. 1. On définit un type abstrait avec les opérations communes à toutes la valeurs, 2. et on dérive une classe pour chaque type ML. abstract class MLvalue extends Object { abstract void print(); /* on pourrait ajouter equals, serialise, etc. */

Types primitifs class MLunit extends MLvalue { MLunit(){ public void print(){system.out.print("()"); class MLbool extends MLvalue { private boolean val; MLbool(boolean a){val=a; public void print(){ if (val) System.out.print("true"); else System.out.print("false"); public boolean MLaccess(){return val;

Types primitifs class MLint extends MLvalue { private int val; MLint(int a){val=a; public void print(){system.out.print(val); public int MLaccess(){return val; class MLdouble extends MLvalue { private double val; MLdouble(double a){val=a; public void print(){system.out.print(val); public double MLaccess(){return val; class MLstring extends MLvalue { private String val; MLstring(String a){val=a; public void print(){system.out.print("\""+val+"\""); public String MLaccess(){return val;

Constructions class MLpair extends MLvalue { private MLvalue MLfst; private MLvalue MLsnd; MLpair(MLvalue a, MLvalue b){mlfst=a; MLsnd=b; public MLvalue MLaccess1(){return MLfst; public MLvalue MLaccess2(){return MLsnd; public void print(){system.out.print("("); MLfst.print(); System.out.print(","); MLsnd.print(); System.out.print(")");

Primitives class MLruntime { public static MLbool MLtrue = new MLbool(true); public static MLbool MLfalse = new MLbool(false); public static MLunit MLlrp = new MLunit(); public static MLlist MLnil = new MLlist(null,null); /*... */ public static MLint MLaddint(MLint x, MLint y) { return new MLint(x.MLaccess()+y.MLaccess()); /*... */

Compilation des fonctions On ne peut pas utiliser le mécanisme de méthodes de Java : Les fonctions sont des valeurs. Application partielle. On utilise alors une méthode Java pour le corps de la fonction, et on l emballe dans une machinerie implantant ces propriétés.

Compilation des fonctions Classe de base des fonctions : abstract class MLfun extends MLvalue { public int MLcounter; protected MLvalue[] MLenv; MLfun(){MLcounter=0; MLfun(int n){mlcounter=0;mlenv = new MLvalue[n]; public void MLaddenv(MLvalue []O_env,MLvalue a) { for (int i=0; i< MLcounter; i++) {MLenv[i]=O_env[i]; MLenv[MLcounter]=a;MLcounter++; abstract public MLvalue invoke(mlvalue x); public void print(){ System.out.print("<fun> ["); for (int i=0; i< MLcounter; i++) MLenv[i].print(); System.out.print("]");

Compilation des fonctions Exemple : let app = function fx -> function x -> fx x;; class MLfun_app 76 extends MLfun { private static int MAX = 2; MLfun_app 76() {super(); MLfun_app 76(int n) {super(n); public MLvalue invoke(mlvalue MLparam){ if (MLcounter == (MAX-1)) { return invoke_real(mlenv[0], MLparam); else { MLfun_app 76 l = new MLfun_app 76(MLcounter+1); l.mladdenv(mlenv,mlparam); return l; MLvalue invoke_real(mlvalue fx 77, MLvalue x 78) { return ((MLfun)fx 77).invoke(x 78);