ICFP 2025
Sun 12 - Sat 18 October 2025 Singapore
co-located with ICFP/SPLASH 2025
Wed 15 Oct 2025 13:40 - 14:05 at Orchid West - Types and Specifications Chair(s): Dominic Orchard

Proof assistants based on type theories have been widely successful
from verifying safety-critical software to establishing a new standard
of rigour by formalizing mathematics. But these proof assistants and
even their type-checking kernels are also complex pieces of software,
and software invariably has bugs, so why should we trust such proof
assistants?

In this paper, we describe the McTT (Mechanized Type Theory)
infrastructure to build a verified implementation of a kernel for a
core Martin-Löf type theory (MLTT). McTT is implemented in Rocq and
consists of two main components: In the theoretical component, we
specify the type theory and prove theorems such as normalization,
consistency and injectivity of type constructors of MLTT using an
untyped domain model. In the algorithmic component, we relate the
declarative specification of typing and the model of normalization in
the theoretical component with a functional implementation within
Rocq. From this algorithmic component, we extract an OCaml
implementation and couple it with a front-end parser for
execution. This extracted OCaml code is comparable to what a skilled
human programmer would have written and we have successfully used it
to type-check a series of small-scale examples.

McTT provides a fully verified kernel for a core MLTT with a full
cumulative universe hierarchy. Every step in the compilation pipeline
is verified except for the lexer and pretty-printer. As a result, McTT
serves both as a framework to explore the meta-theory of advanced type
theories and to investigate optimizations of and extensions to the
type-checking kernel.

Wed 15 Oct

Displayed time zone: Perth change

13:40 - 15:20
Types and SpecificationsICFP Papers / JFP First Papers at Orchid West
Chair(s): Dominic Orchard University of Cambridge; University of Kent
13:40
25m
Talk
McTT: A Verified Kernel for a Proof Assistant
ICFP Papers
Junyoung Jang McGill University, Antoine Gaulin McGill University, Jason Z. S. Hu Amazon, Brigitte Pientka McGill University
DOI Media Attached
14:05
25m
Talk
Linear Types with Dynamic Multiplicities in Dependent Type Theory (Functional Pearl)Remote
ICFP Papers
Maximilian Doré University of Oxford
DOI Pre-print
14:30
25m
Paper
Binary search—think positive
JFP First Papers
Alexander Dinges RPTU Kaiserslautern-Landau, Ralf Hinze RPTU Kaiserslautern-Landau
DOI
14:55
25m
Talk
Teaching Software Specification (Experience Report)
ICFP Papers
Cameron Moy Northeastern University, Daniel Patterson Northeastern University
DOI
Hide past events