Intuitionistic type theory (also known as constructive type theory, or Martin-Löf type theory (MLTT)) is a type theory and an alternative foundation of mathematics.Intuitionistic type theory was created by Per Martin-Löf, a Swedish mathematician and philosopher, who first published it in 1972. There are multiple versions of the type theory: Martin-Löf proposed both intensional and extensional variants of the theory and early impredicative versions, shown to be inconsistent by Girard's paradox, gave way to predicative versions. However, all versions keep the core design of constructive logic using dependent types.
Martin-Löf designed the type theory on the principles of mathematical constructivism. Constructivism requires any existence proof to contain a "witness". So, any proof of "there exists a prime greater than 1000" must identify a specific number that is both prime and greater than 1000. Intuitionistic type theory accomplished this design goal by internalizing the BHK interpretation. A useful consequence is that proofs become mathematical objects that can be examined, compared, and manipulated.
Intuitionistic type theory's type constructors were built to follow a one-to-one correspondence with logical connectives. For example, the logical connective called implication (
A\impliesB
A\toB
Intuitionistic type theory has three finite types, which are then composed using five different type constructors. Unlike set theories, type theories are not built on top of a logic like Frege's. So, each feature of the type theory does double duty as a feature of both math and logic.
If you are unfamiliar with type theory and know set theory, a quick summary is: Types contain terms just like sets contain elements. Terms belong to one and only one type. Terms like
2+2
2 ⋅ 2
There are three finite types: The 0 type contains 0 terms. The 1 type contains 1 canonical term. And the 2 type contains 2 canonical terms.
Because the 0 type contains 0 terms, it is also called the empty type. It is used to represent anything that cannot exist. It is also written
\bot
\negA:=A\to\bot
Likewise, the 1 type contains 1 canonical term and represents existence. It also is called the unit type.
Finally, the 2 type contains 2 canonical terms. It represents a definite choice between two values. It is used for Boolean values but not propositions.
Propositions are instead represented by particular types. For instance, a true proposition can be represented by the 1 type, while a false proposition can be represented by the 0 type. But we cannot assert that these are the only propositions, i.e. the law of excluded middle does not hold for propositions in intuitionistic type theory.
Σ-types contain ordered pairs. As with typical ordered pair (or 2-tuple) types, a Σ-type can describe the Cartesian product,
A x B
A
B
A
B
A\wedgeB
Σ-types are more powerful than typical ordered pair types because of dependent typing. In the ordered pair, the type of the second term can depend on the value of the first term. For example, the first term of the pair might be a natural number and the second term's type might be a sequence of reals of length equal to the first term. Such a type would be written:
\sumn{N}}\operatorname{Vec}({R},n)
Using set-theory terminology, this is similar to an indexed disjoint union of sets. In the case of the usual cartesian product, the type of the second term does not depend on the value of the first term. Thus the type describing the cartesian product
{N} x {R}
\sumn{N}}{R}
It is important to note here that the value of the first term,
n
{R}
Σ-types can be used to build up longer dependently-typed tuples used in mathematics and the records or structs used in most programming languages. An example of a dependently-typed 3-tuple is two integers and a proof that the first integer is smaller than the second integer, described by the type:
\summ{Z}}{\sumn{Z}}((m<n)=True)}
Dependent typing allows Σ-types to serve the role of existential quantifier. The statement "there exists an
n
{N}
P(n)
n
{N}
P(n)
P(n)
n
\sumn{N}}P(n)
Π-types contain functions. As with typical function types, they consist of an input type and an output type. They are more powerful than typical function types however, in that the return type can depend on the input value. Functions in type theory are different from set theory. In set theory, you look up the argument's value in a set of ordered pairs. In type theory, the argument is substituted into a term and then computation ("reduction") is applied to the term.
As an example, the type of a function that, given a natural number
n
n
\prodn{N}}\operatorname{Vec}({R},n)
When the output type does not depend on the input value, the function type is often simply written with a
\to
{N}\to{R}
A\impliesB
A\toB
\prodaA}B
Π-types are also used in logic for universal quantification. The statement "for every
n
{N}
P(n)
n
{N}
P(n)
n
P( ⋅ )
\prodn{N}}P(n)
=-types are created from two terms. Given two terms like
2+2
2 ⋅ 2
2+2=2 ⋅ 2
2+2
2 ⋅ 2
4
2+2=2 ⋅ 2
\operatorname{refl}n{:}\prodaA}(a=a).
It is possible to create =-types such as
1=2
1=2
\bot
1=2\to\bot
\ldots\to\bot
\neg(1=2)
1 ≠ 2
Equality of proofs is an area of active research in proof theory and has led to the development of homotopy type theory and other type theories.
Inductive types allow the creation of complex, self-referential types. For example, a linked list of natural numbers is either an empty list or a pair of a natural number and another linked list. Inductive types can be used to define unbounded mathematical structures like trees, graphs, etc.. In fact, the natural numbers type may be defined as an inductive type, either being
0
Inductive types define new constants, such as zero
0n{:}{N}
Sn{:}{N}\to{N}
S
S0
SSS0
Proofs on inductive types are made possible by induction. Each new inductive type comes with its own inductive rule. To prove a predicate
P( ⋅ )
{\operatorname{{N}-elim}}n{:}P(0)\to\left(\prodn{N}}P(n)\toP(S(n))\right)\to\prodn{N}}P(n)
Inductive types in intuitionistic type theory are defined in terms of W-types, the type of well-founded trees. Later work in type theory generated coinductive types, induction-recursion, and induction-induction for working on types with more obscure kinds of self-referentiality. Higher inductive types allow equality to be defined between terms.
The universe types allow proofs to be written about all the types created with the other type constructors. Every term in the universe type
l{U}0
0,1,2,\Sigma,\Pi,=,
l{U}n
l{U}n
l{n}\inN
To write proofs about all "the small types" and
l{U}0
l{U}1
l{U}0
l{U}1
l{U}2
k
l{U}k+1
Universe types are a tricky feature of type theories. Martin-Löf's original type theory had to be changed to account for Girard's paradox. Later research covered topics such as "super universes", "Mahlo universes", and impredicative universes.
The formal definition of intuitionistic type theory is written using judgements. For example, in the statement "if
A
B
style\suma:AB
style\suma:AB
This second level of the type theory can be confusing, particularly where it comes to equality. There is a judgement of term equality, which might say
4=2+2
A=B
A
B
4=2+2
4
2+2
4
SSSS0
The description of judgements below is based on the discussion in Nordström, Petersson, and Smith.
The formal theory works with types and objects.
A type is declared by:
A Type
an{:}A
a=b
A=B
(xn{:}A)B
B[x/a]
x
a
B
[x]b
b[x/a]
x
a
b
0n{:}N
Sn{:}N\toN
S
S
S
\begin{align} \operatorname{add}&n{:} (N x N)\toN\\ \operatorname{add}(0,b)&=b\\ \operatorname{add}(S(a),b)&=S(\operatorname{add}(a,b))) \end{align}
S
So, objects and types and these relations are used to express formulae in the theory. The following styles of judgements are used to create new objects, types and relations from existing ones:
\Gamma\vdash\sigma Type | σ is a well-formed type in the context Γ. | |
\Gamma\vdashtn{:}\sigma | t is a well-formed term of type σ in context Γ. | |
\Gamma\vdash\sigma\equiv\tau | σ and τ are equal types in context Γ. | |
\Gamma\vdasht\equivun{:}\sigma | t and u are judgmentally equal terms of type σ in context Γ. | |
\vdash\Gamma Context | Γ is a well-formed context of typing assumptions. |
By convention, there is a type that represents all other types. It is called
l{U}
\operatorname{Set}
l{U}
\operatorname{El}
\operatorname{El}
A
l{U}
This is the complete foundation of the theory. Everything else is derived.
To implement logic, each proposition is given its own type. The objects in those types represent the different possible ways to prove the proposition. If there is no proof for the proposition, then the type has no objects in it. Operators like "and" and "or" that work on propositions introduce new types and new objects. So
A x B
A
B
A
B
A
B
A x B
This can be done for other types (booleans, natural numbers, etc.) and their operators.
Using the language of category theory, R. A. G. Seely introduced the notion of a locally cartesian closed category (LCCC) as the basic model of type theory. This has been refined by Hofmann and Dybjer to Categories with Families or Categories with Attributes based on earlier work by Cartmell.[2]
A category with families is a category C of contexts (in which the objects are contexts, and the context morphisms are substitutions), together with a functor T : Cop → Fam(Set).
Fam(Set) is the category of families of Sets, in which objects are pairs of an "index set" A and a function B: X → A, and morphisms are pairs of functions f : A → A' and g : X → X' , such that B' ° g = f ° B – in other words, f maps Ba to Bg(a).
The functor T assigns to a context G a set of types, and for each, a set of terms. The axioms for a functor require that these play harmoniously with substitution. Substitution is usually written in the form Af or af, where A is a type in and a is a term in, and f is a substitution from D to G. Here and .
The category C must contain a terminal object (the empty context), and a final object for a form of product called comprehension, or context extension, in which the right element is a type in the context of the left element. If G is a context, and, then there should be an object final among contexts D with mappings p : D → G, q : Tm(D,Ap).
A logical framework, such as Martin-Löf's, takes the form of closure conditions on the context-dependent sets of types and terms: that there should be a type called Set, and for each set a type, that the types should be closed under forms of dependent sum and product, and so forth.
A theory such as that of predicative set theory expresses closure conditions on the types of sets and their elements: that they should be closed under operations that reflect dependent sum and product, and under various forms of inductive definition.
A fundamental distinction is extensional vs intensional type theory. In extensional type theory, definitional (i.e., computational) equality is not distinguished from propositional equality, which requires proof. As a consequence type checking becomes undecidable in extensional type theory because programs in the theory might not terminate. For example, such a theory allows one to give a type to the Y-combinator; a detailed example of this can be found in Nordstöm and Petersson Programming in Martin-Löf's Type Theory.[3] However, this does not prevent extensional type theory from being a basis for a practical tool; for example, Nuprl is based on extensional type theory.
In contrast, in intensional type theory type checking is decidable, but the representation of standard mathematical concepts is somewhat more cumbersome, since intensional reasoning requires using setoids or similar constructions. There are many common mathematical objects that are hard to work with or cannot be represented without this, for example, integer numbers, rational numbers, and real numbers. Integers and rational numbers can be represented without setoids, but this representation is difficult to work with. Cauchy real numbers cannot be represented without this.[4]
Homotopy type theory works on resolving this problem. It allows one to define higher inductive types, which not only define first-order constructors (values or points), but higher-order constructors, i.e. equalities between elements (paths), equalities between equalities (homotopies), ad infinitum.
Different forms of type theory have been implemented as the formal systems underlying a number of proof assistants. While many are based on Per Martin-Löf's ideas, many have added features, more axioms, or a different philosophical background. For instance, the Nuprl system is based on computational type theory[5] and Coq is based on the calculus of (co)inductive constructions. Dependent types also feature in the design of programming languages such as ATS, Cayenne, Epigram, Agda,[6] and Idris.[7]
Per Martin-Löf constructed several type theories that were published at various times, some of them much later than when the preprints with their description became accessible to specialists (among others Jean-Yves Girard and Giovanni Sambin). The list below attempts to list all the theories that have been described in a printed form and to sketch the key features that distinguished them from each other. All of these theories had dependent products, dependent sums, disjoint unions, finite types and natural numbers. All the theories had the same reduction rules that did not include η-reduction either for dependent products or for dependent sums, except for MLTT79 where the η-reduction for dependent products is added.
MLTT71 was the first type theory created by Per Martin-Löf. It appeared in a preprint in 1971. It had one universe, but this universe had a name in itself, i.e., it was a type theory with, as it is called today, "Type in Type". Jean-Yves Girard has shown that this system was inconsistent, and the preprint was never published.
MLTT72 was presented in a 1972 preprint that has now been published.[8] That theory had one universe V and no identity types (=-types). The universe was "predicative" in the sense that the dependent product of a family of objects from V over an object that was not in V such as, for example, V itself, was not assumed to be in V. The universe was à la Russell's Principia Mathematica, i.e., one would write directly "T∈V" and "t∈T" (Martin-Löf uses the sign "∈" instead of modern ":") without an added constructor such as "El".
MLTT73 was the first definition of a type theory that Per Martin-Löf published (it was presented at the Logic Colloquium '73 and published in 1975[9]). There are identity types, which he describes as "propositions", but since no real distinction between propositions and the rest of the types is introduced the meaning of this is unclear. There is what later acquires the name of J-eliminator but yet without a name (see pp. 94–95). There is in this theory an infinite sequence of universes V0, ..., Vn, ... . The universes are predicative, à la Russell and non-cumulative. In fact, Corollary 3.10 on p. 115 says that if A∈Vm and B∈Vn are such that A and B are convertible then m = n. This means, for example, that it would be difficult to formulate univalence axiom in this theory—there are contractible types in each of the Vi, but it is unclear how to declare them to be equal since there are no identity types connecting Vi and Vj for i ≠ j.
MLTT79 was presented in 1979 and published in 1982.[10] In this paper, Martin-Löf introduced the four basic types of judgement for the dependent type theory that has since become fundamental in the study of the meta-theory of such systems. He also introduced contexts as a separate concept in it (see p. 161). There are identity types with the J-eliminator (which already appeared in MLTT73 but did not have this name there) but also with the rule that makes the theory "extensional" (p. 169). There are W-types. There is an infinite sequence of predicative universes that are cumulative.
Bibliopolis: there is a discussion of a type theory in the Bibliopolis book from 1984,[11] but it is somewhat open-ended and does not seem to represent a particular set of choices and so there is no specific type theory associated with it.