Lambda-calcul simplement typé

De testwiki
Aller à la navigation Aller à la recherche

Le lambda-calcul simplement typé est une variante du lambda-calcul qui se différencie de ce dernier par la présence de types. Il a été développé par Alonzo Church pour pallier l'incohérence du lambda-calcul non typé, due au paradoxe de Curry, et servir de fondements aux mathématiques.

Le lambda-calcul simplement typé partage un lien fort avec la logique propositionnelle minimale au travers de l'isomorphisme de Curry-Howard[1]. Il peut également être vu comme une version simplifiée d'un langage de programmation fonctionnelle. De plus, toutes les fonctions définissables dans le lambda-calcul simplement typé terminent : le lambda-calcul simplement typé est fortement normalisant.

Introduction

Modèle:Article général Le lambda-calcul pose comme primitive la notion de fonction. Si M est une expression, λx.M représente la fonction f définie par l'équation f(x)=M, et si M et N sont deux expressions, MN désigne l'application de M à N[2]. Enfin, le lambda-calcul possède une notion dite de réduction qui correspond à effectuer une étape de calcul[3].

Par analogie, λx.x2 pourrait désigner la fonction qui renvoie le carré de son argument, et (λx.x2)55225 est la suite des étapes de calcul pour calculer cette fonction en 5[2]. On peut définir et utiliser des types de données dans le lambda-calcul, notamment les entier naturels, les paires ou les listes[4]. Néanmoins, tous les calculs ne terminent pas : Ω=(λx.xx)(λx.xx) présente la propriété que ΩΩ, donc que le calcul de Ω ne termine pas[5], et de plus, si F est un terme, il existe un terme M tel que FM*M[6]. Pour reprendre l'analogie précédente, pour F=λx.x+1, un tel M vérifierait M=M+1, ce qui est impossible pour un entier naturel. L'introduction d'une discipline de types permet de résoudre ces deux problèmes, au prix d'une expressivité moindre[5].

Syntaxe

Il y a deux sortes d'objets dans le lambda-calcul simplement typé : les types, qui correspondent à des types de donnée en informatique et à des propositions en logique, et les termes qui correspondent à des programmes ou à des démonstrations. On notera λ ce système.

Types

On suppose donné un ensemble de variables de types, qu'on note par des lettres grecques α,β, Les types du lambda-calcul simplement typé sont désignés par les lettres T,U, et sont formés par[7]Modèle:,[8] :

  • les variables de types α,β, ;
  • si T et U sont des types, TU est le type des fonctions de T vers U.

Termes

Les variables seront notées par des lettres minuscules x,y, tandis que les termes seront notés M,N, Les termes sont formés ainsi[7]Modèle:,[8] :

  • Les variables x,y, sont des termes ;
  • Si A est un type et M un terme, λxA.M est un terme qui représente la fonction qui à x de type A associe l'expression M. On peut voir ça comme l'abstraction de x dans l'expression M ;
  • Si M et N sont des termes, MN est un terme qui correspond à l'application de la fonction M à l'expression N.

De plus, on considèrera que l'application est associative à gauche, c'est-à-dire qu'on notera MNO pour (MN)O.

Règles de typage

On introduit la notation ΓM:A[7], où Γ est une liste de paires de la forme x:Bx est une variable et B un type, M est un terme et A un type. Elle se lit « dans le contexte Γ, le terme M a pour type A ». Par exemple, f:ABλx:A.fx:AB se lit « si f est une variable de type AB, la fonction qui à x de type A associe la valeur fx est une fonction qui envoie les éléments de A dans B ».

Une règle de la forme Γ1M1:A1ΓnMn:AnΓM:A doit se comprendre comme « si Γ1M1:A1, ..., ΓnMn:Analors ΓM:A ». En particulier, ΓM:A signifie que ΓM:A est toujours vrai.

(var)Γ,x:A,Γx:A
(abs)Γ,x:AM:BΓλxA.M:AB (app)ΓM:ABΓN:AΓMN:B

Le lambda-calcul présenté ici correspond, sous la correspondance de Curry-Howard, à la logique minimale.

Typage à la Church et typage à la Curry

La présentation ici donnée correspond au typage à la Church[9], ou typage explicite, c'est-à-dire qu'un terme donné a au plus un seul type. Il existe une autre façon de présenter le lambda-calcul simplement typé, c'est le typage à la Curry[9], ou typage implicite. Les règles de typage restent les mêmes, mais les termes sont ceux du lambda-calcul pur : notamment, l'abstraction se note λx.M. Par exemple, avec un typage à la Church, λxA.x a pour type AA, tandis qu'avec un typage à la Curry, λx.x a tous les types de la forme TT. L'opération qui consiste à trouver le type le plus général qui convient pour un lambda-terme donné, si un tel type existe, s'appelle l'inférence de types[10].

Réduction

Tout comme le lambda-calcul non typé, le lambda-calcul simplement typé identifie les termes [[Lambda-calcul#Substitution_et_α-conversion|Modèle:Nobr]] et définit la substitution de façon similaire. De même, on peut définir pour le lambda-calcul simplement typé une notion de réduction[11], qui correspond à une opération de réécriture représentant une étape de calcul :

  • (λx.M)NβM[x:=N] ;
  • λx.MxηM si x n'est pas libre dans M ;

Une des règles est étiquetée β, elle correspond à une règle de calcul. La réduction associée est nommée Modèle:Nobr. L'autre est étiquetée η, elle correspond à une simplifications : si MηN, M et N se « comportent » pareil. On nomme cette réduction Modèle:Nobr. On note MβηN si MβN ou MηN : c'est la Modèle:Nobr.

Enfin, si R est une réduction, R* est sa clôture réflexive et transitive et =R sa clôture réflexive, symétrique et transitive, c'est-à-dire que MR*N s'il existe M1,,Mn tels que M=M1RRMn=N et M=RN s'il existe M1,,Mn tels que M=M1, Mn=N et pour tout i entre 1 et n1, MiRMi+1 ou MiRMi+1.

Préservation du typage

La Modèle:Nobr possède la propriété de préservation du typage[11] (Modèle:En anglais) : si ΓM:T et MβηN alors ΓN:T.

Normalisation forte

Un terme est dit en forme normale s'il ne peut pas se réduire d'avantage[3]. La Modèle:Nobr possède la propriété de normalisation forte[12], c'est-à-dire que tous les termes sont fortement normalisables : il n'y a pas de suite infinie de réductions M0M1 Ainsi tout terme peut, en un nombre fini (potentiellement nul) d'étapes, être réduit en une forme normale. On dit aussi que la réduction est fortement normalisante. Si MR*N et que N est en forme normale pour R, on dit que N est une Modèle:Nobr normale de M. Comme l’énonce le paragraphe suivant, cette forme est unique pour la Modèle:Nobr et la Modèle:Nobr.

Confluence

Une réduction est dite confluente si pour tous termes M, N1 et N2 tels que M*N1 et M*N2, il existe un terme O tel que N1*O et N2*O. La Modèle:Nobr et la Modèle:Nobr sont confluentes[13].

La confluence assure l'unicité de la forme normale pour la réduction : en effet, supposons M*N1 et M*N2 avec N1 et N2 en forme normale. Si N1*O alors N1=O puisque N1 ne peut pas se réduire. De même, si N2*O alors N2=O. Donc N1=N2.

Cela signifie qu'en partant d'un terme donné, l'ordre des Modèle:Nobr n'importe pas : quel que soit l'ordre de réduction choisi, en un nombre fini d'étapes, on atteindra une forme normale qui ne dépend pas de l'ordre des réductions. En revanche, l'ordre de réduction peut avoir une influence sur le nombre de réductions. Par exemple, si y:A,t:B(λxB.y)((λzB.z)t), alors (λxB.y)((λzB.z)t)y atteint une forme normale en une étape en réduisant d'abord le premier rédex, tandis que (λxB.y)((λzB.z)t)(λxB.y)ty atteint la même forme normale en deux étapes, en réduisant d'abord le deuxième rédex.

De plus, on peut choisir de faire les Modèle:Nobr après les Modèle:Nobr ou bien faire les Modèle:Nobr après les Modèle:Nobr : si MηNβO, alors le Modèle:Nobr réduit dans la deuxième réduction était déjà présent dans M, et si M est en Modèle:Nobr normale, il existe un terme N (non nécessairement unique) en Modèle:Nobr normale tel que Mη*N[13].

Types produits

On peut étendre la présentation précédente du lambda-calcul avec un typé unité et des produits de types[7], on le note alors λ,×,1. On ajoute alors aux types un type unité 1, qui possède un unique élément, et T et U sont des types, on ajoute le type T×U qui représente le produit des types T et U, dont les éléments sont des paires composées d'un élément de T et d'un de U.

De plus, on étend la syntaxe des termes :

  • L'unique terme du type unité, se note * ;
  • Si M et N sont des termes, le terme M,N, représente la paire dont la première composante est M et la deuxième N ;
  • Si M est un terme et i=1ou2, la Modèle:Nobr projection de la paire M se note πi(M).

Les règles de typages correspondantes sont[7] :

(pair)ΓM:AΓN:BΓM,N:A×B (π1)ΓM:A×BΓπ1(M):A (π2)ΓM:A×BΓπ2(M):B
(*)Γ*:1

On peut également ajouter des règles de calcul sur les produits[11], à savoir :

  • π1(M,N)βM ;
  • π2(M,N)βN.

Il est aussi possible d'ajouter des règles η à ce lambda-calcul[11] :

  • π1x,π2xηx ;
  • Mη* si M est de type 1.

Mais celles-ci ne se comportent pas aussi bien que dans le cas sans type unité. En effet, si la Modèle:Nobr reste confluente[13], la Modèle:Nobr ne l'est plus, comme le montre l'exemple suivant[13], où x:A×1 :

  • π1x,π2xηπ1x,* ;
  • π1x,π2xηx ;
  • mais π1x,* et x sont tous deux en forme normale, donc ils ne peuvent pas se réduire vers un terme commun.

En revanche toutes ces réductions continuent à préserver le typage[11] et à être fortement normalisantes[12].

Types sommes

On peut également introduire dans le lambda-calcul simplement typé des types représentant respectivement la proposition toujours fausse ou le type vide, ainsi que la disjonction de deux propositions ou la somme de deux types[14]Modèle:,[15]. Pour cela, on ajoute à la syntaxe le type 0, et si T et U sont deux types, T+U aussi. Le type T+U peut être vu comme des couples (e,M) avec M dans T ou dans U et e une étiquette indiquant la provenance de M : T ou U. Ce système se note λ,×,1,+,0.

De plus, on ajoute à la syntaxe les termes suivants :

  • Si T est un type et M un terme, TM est un terme, qui sera de type T. En effet, si 0 possède un élément, tous les autres types aussi.
  • Si T et U sont des types, et M un terme, inlT,UM et inrT,UM sont des termes correspondant aux injections respectives de T et U dans T+U.
  • Si T et U sont des types, M, N et O des termes, alors caseMofxTNyUO est un terme qui correspond à un filtrage par motif.

Ces nouveaux termes se typent comme suit :

(inl)ΓM:TΓinlT,UM:T+U (inr)ΓM:UΓinrT,UM:T+U (case)ΓM:T+UΓ,x:TN:VΓ,y:UO:VΓcaseMofxTNyUO:V
()ΓM:0ΓTM:T

On peut également ajouter des règles de réduction[15], mais il faut ajouter un nouveau type de règles : les conversions commutatives, notées cc. Elles permettent d'identifier deux termes qui devraient désigner la même preuve, mais sont différents.

Les deux règles β correspondent au calcul du filtrage : si M provient de T, on renvoie Nx est remplacé par M, et on fait de même avec O et y si M provient de U :

  • caseinlT,UMofxTNyUOβN[x:=M] ;
  • caseinrT,UMofxTNyUOβO[y:=M].

Les cinq règles suivantes cc correspondent aux conversions commutatives pour 0 :

  • π1(T×UM)ccTM ;
  • π2(T×UM)ccUM ;
  • (TUM)NccUM ;
  • T(0M)ccTM ;
  • Si N et O sont de type V, caseT+UMofxTNyUOccVM.

Ces cinq règles cc correspondent aux conversions commutatives pour la somme :

  • π1(caseMofxTNyUO)cccaseMofxTπ1(N)yUπ1(O);
  • π2(caseMofxTNyUO)cccaseMofxTπ2(N)yUπ2(O);
  • (caseMofxTNyUO)PcccaseMofxTNPyUOP ;
  • W(caseMofxTNyUO)cccaseMofxTWNyUWO ;
  • case(caseMofxTNyUO)ofx'TNy'UOcccaseMofxT(caseNofx'TNy'UO)yU(caseOofx'TNy'UO).

Enfin, on peut aussi définir des règles η : la première règle η correspond à 0, la deuxième à la somme.

  • 0MηM ;
  • caseMofxTinlT,UxyUinrT,UηM.

Les réductions βcc et βccη préservent le typage et sont fortement normalisantes. De plus, βcc est confluente.

Correspondance de Curry-Howard

Modèle:Article général Les règles de typage du lambda-calcul simplement typé correspondent, une pour une, aux règles[16]Modèle:,[17] d'introductions et d'éliminations de la déduction naturelle pour la logique intuitionniste[18]. Cela permet d'établir une correspondance formelle entre preuves et programmes. Par exemple, les règles de l'implication en déduction naturelle sont :

(I)[A]BAB (E)ABAB

[A] signifie que l'on « charge » l'hypothèse A, c'est-à-dire qu'on a le droit de l'utiliser comme hypothèse uniquement au-dessus de la barre.

C'est encore plus flagrant si l'on considère la présentation de la déduction naturelle avec des séquents, qui correspond exactement aux règles du lambda-calcul dans lesquelles on a enlevé les termes et les variables pour ne garder que les types.

(I)Γ,ABΓAB (E)ΓABΓAΓB

En déduction naturelle, il existe une notion de simplification des preuves, appelée élimination des coupures[19]Modèle:,[20]Modèle:,[21]. Une coupure correspond à une règle d'introduction immédiatement suivie de la règle d'élimination correspondante. La procédure d'élimination des coupures correspond exactement à la relation βcc[22], permettant de faire le lien entre un calcul et une simplification de preuves. Ainsi, les résultats précédents Modèle:Incise sont aussi valides pour la déduction naturelle[22]Modèle:,[23].

Par exemple, si t est de type A et u de type B, la règle π1(t,u)t du lambda-calcul simplement typé correspond exactement, dans la déduction naturelle, à la règle :

ABABAA

Sémantique

On peut définir différentes sémantiques pour le lambda-calcul simplement typé, qui permettent à la fois d'étudier le lambda-calcul en tant que tel, ou d'étudier d'autres objets en utilisant le lambda-calcul simplement typé.

Catégorie cartésienne fermée

On peut interpréter un jugement de typage du lambda-calcul simplement typé avec les produits λ,×,1 dans une catégorie cartésienne fermée[24]. Une catégorie cartésienne fermée est une catégorie qui possède un objet terminal, des produits et des objets exponentiels, qui représentent l'ensemble des morphismes d'un objet vers un autre. Cette correspondance entre lambda-calcul typé, déduction naturelle et catégorie cartésienne fermée est parfois connue sous le nom de correspondance de Curry-Howard-Lambek.

Plus généralement, Joachim Lambek et Dana Scott ont mis en évidence[25]Modèle:,[26] l'équivalence entre lambda-théories typées, c'est-à-dire les extensions de λ,×,1 avec éventuellement des constantes et des règles supplémentaires étendant =βη, et catégories cartésiennes fermées.

Si ρ assigne à chaque variable de type un objet d'une catégorie 𝒞, on peut définir une sémantique [[]][24] qui associe à un séquent ΓM:A un morphisme [[ΓM:A]]:[[Γ]][[A]] : l'interprétation des types envoie le type unité 1 sur l'objet terminal 1, le produit de deux types T×U sur le produit catégorique des interprétations de chaque type [[T]]×[[U]] et le type TU est envoyé sur [[[T]],[[U]]], où [A,B] désigne l'objet représentant les morphismes de A vers B dans la catégorie 𝒞. On peut étendre cette définition à un contexte : si Γ=x1:A1,,xn:An, [[Γ]]=[[A1]]×[[An]]. Pour les termes,

  • Si x est une variable et Γ=Γ,x:A,Γ, [[Γx:A]]=πA est la projection de [[Γ]] sur la composante représentée par x ;
  • Γ*:1 est envoyé sur l'unique morphisme de [[Γ]] vers 1 ;
  • ΓM,N:A×B est envoyé sur [[ΓM:A]],[[ΓN:B]], qui désigne l'unique morphisme de Γ vers [[A]]×[[B]] induit par [[ΓM:A]] et [[ΓN:B]] ;
  • Γπi(M) est envoyé sur πi[[ΓM:A×B]], qui désigne la Modèle:Nobr projection du morphisme [[ΓM:A×B]] ;
  • ΓλxA.M:AB doit-être envoyé sur un morphisme [[Γ]][[[A]],[[B]]]. Or [[Γ,x:AM:B]] est un morphisme [[Γ]]×[[A]][[B]] et dans une catégorie cartésienne fermée, pour tout morphisme f:X×YZ, il existe un unique morphisme f*:X[Y,Z] représentant sa version curryfiée. On définit donc [[ΓλxA.M:AB]]=[[Γ,x:AM:B]]*.
  • Pour déterminer ΓMN:B, on remarque que [[ΓM:AB]] est un morphisme [[Γ]][[[A]],[[B]]], et [[ΓN:A]] est un morphisme [[Γ]][[A]]. Or dans une catégorie cartésienne fermée, pour toute paire d'objets X et Y il existe un morphisme d'évaluation ε:[X,Y]×XY, qui est la counité de l'adjonction entre les foncteurs ×X et X. On définit donc [[ΓMN:B]]=ε[[ΓM:AB]],[[ΓN:A]].

Cette sémantique est correcte[24] vis-à-vis de =βη, c'est-à-dire que si M=βηN alors [[M]]=[[N]]. De plus, elle est également complète[24], c'est-à-dire que si [[M]]=[[N]] pour toute interprétation alors M=βηN.

Dans cette sémantique, la substitution correspond à la composition[27] : si

Γ,x:AM:B

et

ΓN:A

,

[[ΓM[x:=N]:B]]=[[Γ,x:AM]]idΓ,[[ΓN:A]]:[[Γ]][[B]].

Ensembles

Les ensembles et les fonctions entre eux forment une catégorie cartésienne fermée, où l'objet terminal 1 est le singleton (il y n'en a qu'un seul à unique isomorphisme près), le produit A×B est le produit cartésien de A et B et l'objet exponentiel [A,B] est l'ensemble des fonctions de A dans B. Harvey Friedman a montré que si ρ n'a pour valeurs que des ensembles infinis, la sémantique induite par ρ est complète[28]Modèle:,[29].

Domaines

La théorie des domaines fournit un certain nombre de catégories cartésiennes fermées, comme celles des dcpo et ω-cpo, ainsi que leurs versions pointées[30]. Cette théorie a notamment permis à Dana Scott de construire un modèle non-trivial D[31]Modèle:,[32] vérifiant D=DD, modèle qui peut servir à interpréter le lambda-calcul non typé[33].

Espace cohérents

Les Modèle:Lien forment également une catégorie cartésienne fermée. Ils ont été introduit par Jean-Yves Girard[34]Modèle:,[35] et c'est la découverte que le type des fonctions usuelles TU pouvait s'écrire (!T)U, où désigne l'implication linéaire et ! une opération de copie, qui lui a inspiré la logique linéaire.

Extensions

Logique classique

Tout comme la logique intuitionniste, le lambda-calcul simplement typé ne démontre pas le tiers exclus P¬P, pas plus que l'élimination de la double négation ¬¬PP ou la loi de Pierce ((PQ)P)P. Il existe plusieurs façons d'étendre le lambda-calcul pour obtenir un système équivalent à la logique classique[36] par la correspondance de Curry-Howard.

Une première méthode est celle de Timothy G. Griffith[37], qui consiste à ajouter une version typée de l'opérateur 𝒞 de Matthias Felleisen[38] : si M est de type ¬¬T, où ¬U est défini comme U, 𝒞M est de type T. Cet opérateur peut aussi être munie de règles de réduction[39] : 𝒞(uv)𝒞(λk.u(λf.k(fv)) et 𝒞(λk.kM)M si k n'est pas libre dans M. La variable k désigne ici une continuation, et 𝒞 est un opérateur proche de l'opérateur call-with-current-continuation du langage Scheme. Cet opérateur peut être traduit dans le lambda-calcul non typé avec une traduction CPS.

La méthode précédente se base sur la déduction naturelle intuitionniste. Michel Parigot a proposé une variante du lambda-calcul basé sur la déduction naturelle classique, dans laquelle il peut y avoir plusieurs formules à droite de  : le Modèle:Lien[40]. Dans son calcul, il y a deux types de termes, les termes nommés qui correspondent aux formules à droite du et les termes innomés, qui correspondent aux termes à gauche du . Un terme innomé peut être nommé par la construction [α]M. Les termes innomés sont les termes du lambda-calcul usuel et ceux de la forme μα.M, qui permette d'abstraire un terme nommé α.

Le lemme de Joyal[41] montre qu'il n'y a pas de correspondance de Curry-Howard-Lambek pour la logique classique : il énonce que si 𝒞 est une catégorie cartésienne fermée munie d'un objet dualisant, c'est-à-dire un objet tel que pour tout A, le morphisme A[[A,],] est un isomorphisme, alors 𝒞 est un préordre. Cela signifie que toutes les preuves d'une même proposition sont égales, et donc que la réduction n'a pas d'intérêt.

Entiers naturels

Il est possible, comme dans le lambda-calcul non typé, de définir les entiers comme les entiers de Church, c'est-à-dire comme le type (αα)(αα) pour α un type de base. Un entier n est alors représenté par n=λfαα.λxα.fnx qui compose la fonction en argument n fois avec elle-même. Mais cette représentation est limitée : en effet, seuls les polynômes généralisés, c'est-à-dire les fonctions obtenues par composition de polynôme et de la fonction if(n,m,i)={nsi i=0msi i0, sont définissables avec cette présentation des entiers[42].

Pour pallier ce problème, on peut utiliser le système T de Gödel[43]. C'est une extension du lambda calcul simplement typé avec les produits λ,×,1 qui possède des booléens et des entiers naturels : il y a deux constantes booléennes T et F et une structure conditionnelle : si M est un booléen et N et O sont de type A, DAMNO est de type A. On a de plus les règles DATNON et DAFNOO. De plus, il y a une constante 0 de type entier, et si M est un entier, SM aussi, qui représente son successeur. Enfin, pour chaque type A, il y a un une construction qui permet de produire une valeur par récurrence sur un entier : si M est un entier, N un terme de type A, O de type AA, RAMNO est de type A vérifiant pour tout M, N et O, RA0MNM et RA(SM)NON(RAMNO)O[44]. Système T a notamment permis de donner une preuve de l'arithmétique de Heyting, de laquelle on peut déduire l'arithmétique de Peano[43]. Notamment, les fonctions entre les entiers définissables dans le système T correspondent exactement aux fonctions prouvablement totales dans l'arithmétique de Peano[45], ou, ce qui revient au même, dans l'arithmétique de Heyting[46].

Combinateurs de points fixes

Le Modèle:Nobr est une extension du lambda-calcul simplement typé avec produits λ,×,1 avec des combinateurs de points fixes, introduit par Dana Scott[47] et étudiée par Gordon Plotkin[48]. On ajoute pour chaque type T une constante YT de type (TT)T et une constante ΩT de type T, et la règle de réduction YTMM(YTM)[49]. Le Modèle:Nobr s'interprète notamment dans la catégorie cartésienne fermée des dcpo pointés et des fonctions continues entre eux. Dans cette catégorie, chaque objet a un plus petit élément (qui sert à interpréter ΩT) et chaque fonction continue d'un dcpo dans lui-même a un plus petit point fixe : YT a alors pour sémantique la fonction qui a f associe son plus petit point fixe.

PCF[48]Modèle:,[50] est une variante du Modèle:Nobr avec les types de fonctions et deux types de bases, les booléens et les entiers naturels, vu comme des domaines plats. Cela signifie que si représente les entiers naturels usuels, les entiers de PCF sont ={}, avec le plus petit élément de , les autres éléments étant incomparables entre eux. Une valeur représente une valeur indéfinie. En plus des constantes Y et Ω pour chaque type, PCF possède également une constante pour chaque entier et pour chaque booléen, une structure conditionnelle ifthenelse, une fonction pour tester si un entier vaut zéro, ainsi que les fonctions successeur et prédécesseur. C'est un exemple minimal de langage de programmation fonctionnel, et il est Turing-complet[48].

Polymorphisme

Il est possible d'étendre le lambda-calcul simplement typé pour qu'il supporte des abstractions et des instanciations de type, c'est-à-dire ajouter du polymorphisme[51]. Le système formel obtenu se nomme le système F[52]. Très expressif, ce système permet de définir les produits, les sommes et le quantificateur existentiel, ainsi que les types inductifs comme les entiers ou les listes. Les fonctions définissables sur les entiers dans le système F sont exactement les fonctions prouvablement totales dans l'arithmétique du second ordre[53], ou de façon équivalente, dans l'arithmétique de Heyting du second ordre.

Types dépendants, types d'ordre supérieurs

On peut également étendre le système de types pour obtenir des types dépendants[54], c'est-à-dire des types qui dépendent de valeur, et des types d'ordre supérieur[55], c'est-à-dire des types qui dépendent d'autre types, formant ainsi le lambda-cube[56]Modèle:,[57]. De plus, on peut également considérer diverses théories des types possédant à la fois du polymorphisme, des types d'ordre supérieur et des types dépendants, comme par exemple la théorie des types de Martin-Löf MLTT[58], le calcul des constructions CoC[59]Modèle:,[60], ou enfin la théorie homotopique des types HoTT[61].

Références

Modèle:Références nombreuses

Bibliographie

Articles connexes

Modèle:Portail

  1. Modèle:Article
  2. 2,0 et 2,1 Modèle:Référence Harvard sans parenthèses
  3. 3,0 et 3,1 Modèle:Référence Harvard sans parenthèses
  4. Modèle:Référence Harvard sans parenthèses
  5. 5,0 et 5,1 Modèle:Référence Harvard sans parenthèses
  6. Modèle:Référence Harvard sans parenthèses
  7. 7,0 7,1 7,2 7,3 et 7,4 Modèle:Référence Harvard sans parenthèses
  8. 8,0 et 8,1 Modèle:Référence Harvard sans parenthèses
  9. 9,0 et 9,1 Modèle:Référence Harvard sans parenthèses
  10. Modèle:Référence Harvard sans parenthèses
  11. 11,0 11,1 11,2 11,3 et 11,4 Modèle:Référence Harvard sans parenthèses
  12. 12,0 et 12,1 Modèle:Référence Harvard sans parenthèses
  13. 13,0 13,1 13,2 et 13,3 Modèle:Référence Harvard sans parenthèses
  14. Modèle:Référence Harvard sans parenthèses
  15. 15,0 et 15,1 Modèle:Référence Harvard sans parenthèses
  16. Modèle:Référence Harvard sans parenthèses règles du fragment conjonctif et implicatif
  17. Modèle:Référence Harvard sans parenthèses règles du fragment disjonctif
  18. Modèle:Référence Harvard sans parenthèses
  19. Modèle:Référence Harvard sans parenthèses pour le fragment conjonctif et implicatif
  20. Modèle:Référence Harvard sans parenthèses pour le fragment disjonctif
  21. Modèle:Référence Harvard sans parenthèses conversions commutatives pour le fragment disjonctif
  22. 22,0 et 22,1 Modèle:Référence Harvard sans parenthèses pour le fragment conjonctif et implicatif
  23. Modèle:Référence Harvard sans parenthèses pour le fragment disjonctif
  24. 24,0 24,1 24,2 et 24,3 Modèle:Référence Harvard sans parenthèses
  25. Modèle:Référence Harvard sans parenthèses
  26. Modèle:Référence Harvard sans parenthèses
  27. Modèle:Référence Harvard sans parenthèses
  28. Modèle:Article
  29. Modèle:Référence Harvard sans parenthèses
  30. Modèle:Référence Harvard sans parenthèses
  31. Modèle:Référence Harvard sans parenthèses
  32. Modèle:Référence Harvard sans parenthèses
  33. Modèle:Référence Harvard sans parenthèses
  34. Modèle:Référence Harvard sans parenthèses
  35. Modèle:Référence Harvard sans parenthèses
  36. Modèle:Référence Harvard sans parenthèses
  37. Modèle:Article
  38. Modèle:Article
  39. Modèle:Lien web
  40. Modèle:Article
  41. Modèle:Chapitre
  42. Modèle:Article
  43. 43,0 et 43,1 Modèle:Article
  44. Modèle:Référence Harvard sans parenthèses
  45. Modèle:Référence Harvard sans parenthèses
  46. Modèle:Article
  47. Modèle:Article
  48. 48,0 48,1 et 48,2 Modèle:Article
  49. Modèle:Référence Harvard sans parenthèses
  50. Modèle:Référence Harvard sans parenthèses
  51. Modèle:Référence Harvard sans parenthèses
  52. Modèle:Référence Harvard sans parenthèses
  53. Modèle:Référence Harvard sans parenthèses
  54. Modèle:Référence Harvard sans parenthèses
  55. Modèle:Référence Harvard sans parenthèses
  56. Modèle:Article
  57. Modèle:Référence Harvard sans parenthèses
  58. Modèle:Article
  59. Modèle:Article
  60. Modèle:Référence Harvard sans parenthèses
  61. Modèle:Ouvrage