en fr Erasable coercions: a unified approach to type systems Coercions effaçables : une approche unifiée des systèmes de types Report as inadecuate




en fr Erasable coercions: a unified approach to type systems Coercions effaçables : une approche unifiée des systèmes de types - Download this document for free, or read online. Document in PDF available to download.

1 GALLIUM - Programming languages, types, compilation and proofs Inria Paris-Rocquencourt

Abstract : Functional programming languages, like OCaml or Haskell, rely on the lambda calculus for their core language. Although they have different reduction strategies and type system features, their proof of soundness and normalization in the absence of recursion should be factorizable. This thesis does such a factorization for theoretical type systems featuring recursive types, subtyping, bounded polymorphism, and constraint polymorphism. Interestingly, soundness and normalization for strong reduction imply soundness and normalization for all usual strategies. Our observation is that a generalization of existing coercions permits to describe all type system features stated above in an erasable and composable way. We illustrate this by proposing two concrete type systems: first, an explicit type system with a restricted form of coercion abstraction to express subtyping and bounded polymorphism; and an implicit type system with unrestricted coercion abstraction that generalizes the explicit type system with recursive types and constraint polymorphism-but without the subject reduction property. A side technical result is an adaptation of the step-indexed proof technique for type-soundness to calculi equipped with a strong notion of reduction.

Résumé : Les langages de programmation fonctionnels, comme OCaml ou Haskell, reposent sur le lambda calcul en tant que langage noyau. Bien qu-ils aient des stratégies de réduction et des caractéristiques de système de types différentes, leur preuve de correction et de normalisation en l-absence de réduction devrait être factorisable. Cette thèse établit une telle factorisation pour des systèmes de types théoriques présentant des types récursifs, du sous-typage, du polymorphisme borné et du polymorphisme contraint. Il est intéressant de remarquer que la correction et la normalisation en réduction forte, implique la correction et la normalisation pour toutes les stratégies usuelles. Notre travail montre qu-une généralisation des coercions actuelles permet de décrire toutes les caractéristiques de systèmes de types citées plus haut de manière effaçable et composable. Nous illustrons ceci en présentant deux systèmes de types concrets : tout d-abord, un système de types explicite avec une forme restreinte d-abstraction sur les coercions pour exprimer le sous-typage et le polymorphisme borné ; puis un système de types implicite sans restriction sur l-abstraction de coercions et qui étend le système explicite avec des types récursifs and du polymorphisme contraint - mais sans le propriété de préservation du typage. Un résultat annexe est l-adaptation des techniques de step-indexing pour la correction à des calculs en réduction forte.

en fr

Keywords : type system polymorphism

Mots-clés : coercion système de types polymorphisme eta-expansion





Author: Julien Cretin -

Source: https://hal.archives-ouvertes.fr/



DOWNLOAD PDF




Related documents