Type theory can be seen as a programming language with a powerful type system, where you start from simple types and gradually add more expressivity, such as dependent types and inductive types, to reach systems like Martin-Löf Type Theory. It’s a framework where logic and computation are unified, allowing for rigorous reasoning and bug-free programming.
The Curry-Howard isomorphism establishes a direct correspondence between logic and computation. It shows that logical proofs can be interpreted as programs, and vice versa. This allows for reasoning about programs in a logical framework and ensures that programs can be proven correct within the type system itself.
Decidability of type checking ensures that the type system can be implemented in a proof assistant, allowing for formal verification of proofs. It also provides a foundational guarantee that the system is consistent and that proofs are objective, as the type checker serves as a concrete, finite oracle for verifying truth.
Consistency means that not everything is provable in the system, while equational consistency ensures that specific equations, like true not being equal to false, hold. Equational consistency is crucial for computer scientists as it guarantees that the computational behavior of the system is well-defined and not degenerate.
Canonicity ensures that terms in the type theory have well-defined normal forms, which is essential for computation. It guarantees that, for example, a closed term of type natural number will reduce to a concrete numeral, making the system predictable and reliable for both mathematicians and computer scientists.
Turing completeness is generally undesirable in Type Theory because it conflicts with the decidability of type checking. Type theories like Martin-Löf Type Theory avoid Turing completeness to maintain properties like termination and consistency, which are essential for formal verification and foundational purposes.
Martin-Löf Type Theory typically includes at least one universe, a hierarchy of universes, and type formers like natural numbers, pi types, sigma types, equality, unit, and falsity. It is not strictly defined, allowing for various extensions and modifications, but it fundamentally provides a framework for dependent types and rigorous logical reasoning.
The Franco-Dutch school, which includes systems like the Calculus of Constructions (CoC), often embraces impredicativity, where types can be defined in terms of themselves. The Scottish-Swedish school, influenced by Martin-Löf, avoids impredicativity due to philosophical and foundational concerns, leading to different approaches to type theory design.
Category theory provides a language for discussing denotational models of type theory, focusing on equational properties rather than computational dynamics. While it offers elegant formulations of concepts like adjunctions, it can be seen as obfuscating simpler syntactic ideas, especially in the context of dependent type theory.
Pierre-Marie argues that properties like decidability of type checking, equational consistency, and canonicity are essential because they ensure that the type theory is implementable, reliable, and foundational. Without these properties, the system risks becoming impractical, inconsistent, or overly complex, making it difficult to use for formal verification and computation.
In this episode Pierre-Marie Pédrot who is one of the main Coq/Rocq developers joins us to talk about what is Type Theory, what is Martin-Löf Type Theory, what are the properties we should care about in our type theory and why.
If you enjoy the show please consider supporting us at our ko-fi: https://ko-fi.com/typetheoryforall