Système U (mathématiques)

En logique mathématique, le Système U et le Système U sont des systèmes de types purs, c'est-à-dire des formes spéciales d'un calcul lambda typé avec un nombre arbitraire de sortes, d'axiomes et de règles (ou de relations entre les sortes). Ils ont tous deux été prouvés incohérents par Jean-Yves Girard en 1972[1]. Ce résultat conduit alors à ce que la théorie des types de Martin-Löf de 1971 est incohérente car elle permet le même comportement de «type dans le type» que le paradoxe de Girard exploite.

Définition formelle modifier

Le système U est défini [2] :352 comme un système de type pur avec

  • trois sortes  ;
  • deux axiomes  ; et
  • cinq règles  .

Système U est défini de la même manière à l'exception de la règle  .

Les sortes   et   sont classiquement appelés respectivement «Type» et « Genre »; le genre   n'a pas de nom spécifique. Les deux axiomes décrivent "l'inclusion" des types dans les genres (  ) et des genres dans   (  ). Intuitivement, les sortes décrivent une hiérarchie dans la nature des termes.

  1. Toutes les valeurs ont un type, tel qu'un type de base ( par exemple   est lu comme «b est un booléen») ou un type de fonction (par exemple  est lu comme « f est une fonction des nombres naturels aux booléens»).
  2.   est la sorte de tous ces types (  est lu comme « t est un type»). De   nous pouvons créer plus de termes, tels que   qui est le genre d'opérateurs de type niveau unaire (par exemple   se lit : «List est une fonction allant des types aux types», c'est-à-dire un type polymorphe). Les règles limitent la manière dont nous pouvons former de nouveaux genres.
  3.   est la sorte de tous ces genres (  est lu comme « k est un genre»). De même, nous pouvons construire des termes liés, selon ce que les règles permettent.
  4.   est la sorte de tous ces termes.

Les règles régissent les dépendances entre les sortes :   dit que les valeurs peuvent dépendre de valeurs (fonctions),  permet aux valeurs de dépendre des types (polymorphisme),   permet aux types de dépendre des types (opérateurs de type), etc.

Le paradoxe de Girard modifier

Les définitions des systèmes U et U permettent l'attribution de types polymorphes à des constructeurs génériques par analogie avec des types polymorphes de termes dans des calculs lambda polymorphes classiques, tels que le System F. Un exemple d'un tel constructeur générique pourrait être [2] (où k désigne une variable de genre)

 .

Ce mécanisme est suffisant pour construire un terme de type , ce qui implique que chaque type est habité. Par la correspondance de Curry-Howard, cela implique (et est même équivalent à ce) que toutes les propositions logiques soient prouvables, ce qui rend le système incohérent.

Le paradoxe de Girard est l'analogue en théorie des types du paradoxe de Russell en théorie des ensembles .

Notes et références modifier

  1. Jean-Yves Girard, « Interprétation fonctionnelle et Élimination des coupures de l'arithmétique d'ordre supérieur », Université Carnegie-Mellon (thèse),‎ (lire en ligne [PDF])
  2. a et b Morten Heine Sørensen et Paweł Urzyczyn, Lectures on the Curry–Howard isomorphism, Elsevier, (ISBN 0-444-52077-5), « Pure type systems and the lambda cube »

Bibliographie modifier