Skip to content

Latest commit

 

History

History
58 lines (47 loc) · 2.64 KB

README.md

File metadata and controls

58 lines (47 loc) · 2.64 KB

Mechanized Metatheory 2

Every now and then, I get nerd sniped by mechanized metatheory. This repository contains some Coq developments formalizing some results based on logical relations.

This development uses raw de Bruijn indices to formalize variable binding. To avoid repeatedly proving boring facts about substitution on de Bruijn representations for each language separately, there is a single, centralized ABT library that is parametrized by the operators in the language and their arity. This is described in slightly more detail below.

Build instructions

make

Guide to files

  • abt.v: The abstract binding tree framework. Defines capture avoiding substitution once and for all.
  • abtutil.v: Makes it convenient to leverage the ABT framework on a client-specific abstract syntax tree by proving an isomorphism to an equivalent ABT representation. The library also provides tactics for proving this isomorphism. Once proved, many theorems about capture avoiding substitution come for free.
  • util.v: Various lemmas that should probably be in the stdlib.
  • stlc.v: Syntax, operational semantics, and type system for the simply typed lambda calculus over booleans. Uses the ABT framework to get facts about substitution essentially for free.
  • stlc_unary.v: A unary logical relation for proving termination of STLC.
  • stlc_binary.v: A binary logical relation for establishing contextual equivalence in STLC.
  • f.v: Syntax, operational semantics, and type system for System F with booleans, universal and existential types, and functions. Again, uses the ABT framework for substitution theorems.
  • f_unary.v: A unary logical relation for proving termination of System F. Also contains some applications to proving "free theorems" for universal types.
  • f_binary.v: A binary logical relation for System F.
  • f_combined.v: A version of System F (without existentials) that uses a single "combined" syntactic category for expressions and types.

References

I found the following references especially helpful:

Coming Soon

I have put some ideas for extensions in TODO.md.