Logic, Types and Spaces

Towards homotopy type theory

Homotopy Type Theory

In homotopy type theory , we interpret a type A as a space |A|, and a term a:A as a point |a||A| in the corresponding space. Here space means topological space, but we do not actually need to know what this means. All we need of spaces is:

  • Subsets of a Euclidean space are spaces.
  • For spaces X and Y, it is meaningful to talk about continuous functions between them.
  • For spaces X and Y, continuous functions between X and Y also form a space C(X,Y).
  • Currying and uncurrying are continuous.

The interpretation.

As mentioned above types and terms are interpreted as spaces and points. For types A and B, we interpret AB as the space of continuous functions C(|A|,|B|). We can similarly interpret dependent functions, but we shall not go into details here.

The most crucial ingredient in our interpretation is that of an equality type. For x,y:A, the type x=y is interpreted as the space of paths in |A| from |x| to |y|, i.e., the space of continuous functions α:[0,1]|A| so that α(0)=|x| and α(1)=|y|.

It is a result of Voevodsky and Awodey-Warren that we do have a consistent interpretation of type theory, in the sense we have seen it so far, in which types, terms, (dependent) function types and equality types are mapped in the above fashion.

Given such an interpretation, various topological notions can be defined purely in type theoretic terms. The first of these arises when we ask when functions are equality.

Equality of functions.

Let A,B be types and f,g:AB be functions. Then f and g must be equal if and only if there is a path between |f| and |g| in C(|A|,|B|). Such a path is a function [0,1]|A||B|, which after Uncurrying corresponds to a function ([0,1]×|A|)|B|. Flipping the coordinates in the domain and Currying gives a function |A|([0,1]|B|), i.e., a function mapping points of |A| to paths in |B|. Indeed, using that the path we started with is from |f| to |g|, it is easy to deduce that a point |a| is mapped to a path from |f(a)| to |g(a)|. Such a path corresponds to a term of the type f(a)=g(a)!

Thus, we see that if we have a consistent homotopical interpretation, then the equality type f=g must equal the type Πa:A(f(a)=g(a)).

Function extensionality was the postulate that these types were equal. We shall not postulate this, but instead introduce and study homotopy type fg corresponding to such equality. We see this in Agda code. Firstly, we see the definitions for functions and dependent functions.

1
2
3
4
5
__ : {X Y : Type}  (f g : X  Y)  Type
__ {X} {_} f g = (x : X)  (f(x) == g(x))

_~_ : {X : Type}  {Y : X  Type}  (f g : ((x : X)  (Y x)))  Type
_~_ {X} {_} f g = (x : X)  (f(x) == g(x))

It is easy to see that this gives an equivalence relation.

1
2
3
4
5
6
7
8
rfl : {X Y : Type}  (f : X  Y)  (f  f)
rfl {X} {_} f = λ x  (refl (f x))

symm : {X Y : Type}  (f g : X  Y)  (f  g)  (g  f)
symm {X} {_} f g pf = λ x  (sym (pf x))

_trans_ : {X Y : Type}  (f g h : X  Y)  (f  g)  (g  h)  (f  h)
_trans_ {X} {_} f g h fg gh = λ x  (fg x) && (gh x)

While these are simple inductive constructions, in topological terms they are more interesting. Given paths α,β:[0,1]X, for a space X, if α(1)=β(0) we can define a path αβ which is the path α followed by the path β. This is the path corresponding to transitivity. Reflexivity corresponds to constant paths. Finally symmetry corresponds to the map associating to a path α the path ˉα:tα(1t).

Comments