A framework for defining computational higher-order logics

Abstract : The main aim of this thesis is to make formal proofs more universal by expressing them in a common logical framework. More specifically, we use the lambda-Pi-calculus modulo rewriting, a lambda calculus equipped with dependent types and term rewriting, as a language for defining logics and expressing proofs in those logics. By representing propositions as types and proofs as programs in this language, we design translations of various systems in a way that is efficient and that preserves their meaning. These translations can then be used for independent proof checking and proof interoperability. In this work, we focus on the translation of logics based on type theory that allow both computation and higher-order quantification as steps of reasoning. Pure type systems are a well-known example of such computational higher-order systems, and form the basis of many modern proof assistants. We design a translation of functional pure type systems to the lambda-Pi-calculus modulo rewriting based on previous work by Cousineau and Dowek. The translation preserves typing, and in particular it therefore also preserves computation. We show that the translation is adequate by proving that it is conservative with respect to the original systems. We also adapt the translation to support universe cumulativity, a feature that is present in modern systems such as intuitionistic type theory and the calculus of inductive constructions. We propose to use explicit coercions to handle the implicit subtyping that is present in cumulativity, bridging the gap between pure type systems and type theory with universes à la Tarski. We also show how to preserve the expressivity of the original systems by adding equations to guarantee that types have a unique term representation, thus maintaining the completeness of the translation. The results of this thesis have been applied in automated proof translation tools. We implemented programs that automatically translate the proofs of HOL, Coq, and Matita, to Dedukti, a type-checker for the lambda-Pi-calculus modulo rewriting. These proofs can then be re-checked and combined together to form new theories in Dedukti, which thus serves as an independent proof checker and a platform for proof interoperability. We tested our tools on a variety of libraries. Experimental results confirm that our translations are correct and that they are efficient compared to the state of the art.
Document type :
Theses
Complete list of metadatas

Cited literature [119 references]  Display  Hide  Download

https://pastel.archives-ouvertes.fr/tel-01235303
Contributor : Ali Assaf <>
Submitted on : Wednesday, December 16, 2015 - 1:13:26 AM
Last modification on : Wednesday, January 23, 2019 - 10:29:31 AM
Long-term archiving on : Saturday, April 29, 2017 - 3:48:55 PM

Identifiers

  • HAL Id : tel-01235303, version 4

Citation

Ali Assaf. A framework for defining computational higher-order logics. Computer Science [cs]. École polytechnique, 2015. English. ⟨tel-01235303v4⟩

Share

Metrics

Record views

762

Files downloads

780