Phantom types and subtyping

  • Authors:
  • Matthew Fluet;Riccardo Pucella

  • Affiliations:
  • Cornell University, Ithaca, NY 14853, USA (e-mail: fluet@cs.cornell.edu);Northeastern University, Boston, MA 02115, USA (e-mail: riccardo@ccs.neu.edu)

  • Venue:
  • Journal of Functional Programming
  • Year:
  • 2006

Quantified Score

Hi-index 0.00

Visualization

Abstract

We investigate a technique from the literature, called the phantom-types technique, that uses parametric polymorphism, type constraints, and unification of polymorphic types to model a subtyping hierarchy. Hindley-Milner type systems, such as the one found in Standard ML, can be used to enforce the subtyping relation, at least for first-order values. We show that this technique can be used to encode any finite subtyping hierarchy (including hierarchies arising from multiple interface inheritance). We formally demonstrate the suitability of the phantom-types technique for capturing first-order subtyping by exhibiting a type-preserving translation from a simple calculus with bounded polymorphism to a calculus embodying the type system of SML.