Programming Languages Lunch Colloquia - Ben Delaware/UTCS, "Meta-Theory a la Carte," PAI 3.14

Contact Name: 
John Thywissen
Location: 
PAI 3.14
Date: 
Oct 29, 2012 12:00pm - 1:30pm

Type of Talk: Programming Languages Lunch Colloquium

Speaker/Affiliation: Ben Delaware/UTCS

Talk Audience: UTCS Faculty and Grads

Date/Time: 10/29/2012, 12:00pm - 1:30pm

Location: PAI 3.14

Talk Title: "Meta-Theory a la Carte" 

Talk Abstract: Formalizing meta-theory, or proofs about programming languages, in a proof assistant has many well-known benefits. Unfortunately, the considerable effort involved in mechanizing proofs has prevented it from becoming standard practice.  This cost can be amortized by reusing as much of existing formalizations as possible when building a new language or extending an existing one. One important challenge in achieving reuse is that the inductive definitions and proofs used in these formalizations are closed to extension. This forces language designers to cut and paste existing definitions and proofs in an ad-hoc manner, and to expend considerable effort to patch up the results.

The key contribution of this paper is the development of an induction technique for extensible Church encodings using a novel reinterpretation of the universal property of folds. These encodings provide the foundation for a framework, formalized in Coq, which uses type classes to automate the composition of proofs from modular components. This framework enables a more structured approach to the reuse of meta-theory formalizations through the composition of modular inductive definitions and proofs.

Several interesting language features, including binders and general recursion, illustrate the capabilities of our framework. We reuse these features to build fully mechanized definitions and proofs for a number of languages, including a version of mini-ML. Bounded induction enables proofs of properties for non-inductive semantic functions, and mediating type classes enable proof adaptation for more feature-rich languages.

Tags: