GADTs are not (Even partial) functors

Pierre Cagne,Enrico Ghiorzi,Patricia Johann
DOI: https://doi.org/10.1017/s0960129524000161
2024-08-29
Mathematical Structures in Computer Science
Abstract:Generalized Algebraic Data Types (GADTs) are a syntactic generalization of the usual algebraic data types (ADTs), such as lists, trees, etc. ADTs' standard initial algebra semantics (IAS) in the category of sets justify critical syntactic constructs – such as recursion, pattern matching, and fold – for programming with them. In this paper, we show that semantics for GADTs that specialize to the IAS for ADTs are necessarily unsatisfactory. First, we show that the functorial nature of such semantics for GADTs in introduces ghost elements, i.e., elements not writable in syntax. Next, we show how such ghost elements break parametricity. We observe that the situation for GADTs contrasts dramatically with that for ADTs, whose IAS coincides with the parametric model constructed via their Church encodings in System F. Our analysis reveals that the fundamental obstacle to giving a functorial IAS for GADTs is the inherently partial nature of their map functions. We show that this obstacle cannot be overcome by replacing with other categories that account for this partiality.
computer science, theory & methods
What problem does this paper attempt to address?