This paper considers direct encodings of generalized algebraic data types (GADTs) in a minimal suitable lambda-calculus. To this end, we develop an extension of System $F_\omega$ with recursive types and internalized type equalities with injective constant type constructors. We show how GADTs and associated pattern-matching constructs can be directly expressed in the calculus, thus showing that it may be treated as a highly idealized modern functional programming language. We prove that the internalized type equalities in conjunction with injectivity rules increase the expressive power of the calculus by establishing a non-macro-expressibility result in $F_\omega$, and prove the system type-sound via a syntactic argument. Finally, we build two relational models of our calculus: a simple, unary model that illustrates a novel, two-stage interpretation technique, necessary to account for the equational constraints; and a more sophisticated, binary model that relaxes the construction to allow, for the first time, formal reasoning about data-abstraction in a calculus equipped with GADTs.
Wed 17 JanDisplayed time zone: London change
| 10:30 - 11:50 | |||
| 10:3020m Talk | Generating Well-Typed Terms that are not "Useless" POPL Justine Frank University of Maryland, College Park, Benjamin Quiring University of Maryland, Leonidas Lampropoulos University of Maryland, College Park | ||
| 10:5020m Talk | Indexed Types for a Statically Safe WebAssembly POPL Adam T. Geller Computer Science, University of British Columbia, Justine Frank University of Maryland, College Park, William J. Bowman University of British ColumbiaDOI Pre-print | ||
| 11:1020m Talk | The Essence of Generalized Algebraic Data TypesRemote POPL Filip Sieczkowski Heriot-Watt University, Sergei Stepanenko Aarhus University, Jonathan Sterling University of Cambridge, Lars Birkedal Aarhus University | ||
| 11:3020m Talk | Ill-Typed Programs Don't Evaluate POPL | ||



