Dependent Types \(\Pi\), \(\Sigma\), \(\forall\) & \(\exists\)

2020 James B. Wilson

Colorado State University

 

\(\times\)-type (Pair type)

\[\frac{A,B:type}{A\times B:type}(F_{\times})\]

 

\[\frac{a:A\quad b:B}{(a,b):A\times B}(I_{\times})\]

\[\frac{x:A\times B}{\pi_A(x):A}(E_{\times}A)\]

\[\frac{x:A\times B}{\pi_B(x):B}(E_{\times} B)\]

\[\frac{a:A\quad b:B}{refl_a:\pi_A(a,b)=_A a}(C_{\times}A)\]

 

\[\frac{a:A\quad b:B}{refl_b:\pi_A(a,b)=_B b}(C_{\times}B)\]

Formation Rule

Introduction Rule

Elimination Rule

Computation Rule

\(\times\)-type (Pair type)

\[\frac{A,B:type}{A\times B:type}(F_{\times})\]

 

\[\frac{a:A\quad b:B}{(a,b):A\times B}(I_{\times})\]

\[\begin{array}{rl}x & :A\times B\\ f &:T\to A\\ g &:T\to B\\ \hline f\times g & :T\to A\times B\end{array}\]

Formation Rule

Introduction Rule

Elimination Rule

Computation Rule

\((E_{\times})\)

\[\begin{array}{rl} t & : T\\ f &:T\to A\\ g &:T\to B\\ \hline refl_{f(t)} & :\pi_A((f\times g)(t))=_A f(t)\end{array}\]

\[\begin{array}{rl}t& : T\\ f &:T\to A\\ g &:T\to B\\ \hline refl_{g(t)} & :\pi_B((f\times g)(t))=_B g(t)\end{array}\]

\[\begin{array}{ccccc} A & \overset{\pi_A}{\leftarrow} & A\times B & \overset{\pi_B}{\rightarrow} & B \\ & f\nwarrow & \uparrow h & \nearrow g\\ & & T & & \end{array}\]

\[\begin{array}{ccccc} P & \leftarrow & P\wedge Q & \rightarrow & Q \\ & \nwarrow & \uparrow & \nearrow \\ & & T & & \end{array}\]

Logic

Sets & Types

(Arrows here are "implies", e.g. T implies P.)

(Arrows here are functions, e.g. T maps to A,

also \(h=f\times g\).)

\(\sqcup\)-type (Disjoint union type)

\[\frac{A,B:type}{A\sqcup B:type}(F_{\sqcup})\]

 

\[\frac{a:A}{\iota_A(a):A\sqcup B}(I_{\sqcup}A)\qquad \frac{b:B}{\iota_B(b):A\sqcup B}(I_{\sqcup}B)\]

\[\frac{x:A\sqcup B, f:A\to C, g:B\to C}{f\sqcup g:A\sqcup B\to C}(E_{\sqcup})\]

\[\frac{a:A}{refl_{f(a)}:(f\sqcup g)(\iota_A(a))=_C f(a)}(C_{\sqcup}A)\]

 

\[\frac{b:B}{refl_{g(b)}:(f\sqcup g)(\iota_B(b))=_C g(b)}(C_{\sqcup}B)\]

Formation Rule

Introduction Rule

Elimination Rule

Computation Rule

\[\begin{array}{ccccc} A & \overset{\iota_A}{\rightarrow} & A\sqcup B & \overset{\iota_B}{\leftarrow} & B \\ & f\searrow & \downarrow h & \swarrow g\\ & & R & & \end{array}\]

\[\begin{array}{ccccc} P & \rightarrow & P\vee Q & \leftarrow & Q \\ & \searrow & \downarrow & \swarrow \\ & & R & & \end{array}\]

Logic

Sets & Types

(Arrows here are "implies", e.g. P implies R.)

(Arrows here are functions, e.g. A maps to R,

also \(h=f\sqcup g\).)

Further Important Types

  • \(\Pi\)-types and how it recover \(\forall\)
  • \(\Sigma\)-types and how it recovers \(\exists\)

\(A\times B\times C\) Option 1

Make it from binary products, but which one? \((A\times B)\times C\) or \(A\times (B\times C)\)?

 

\(A\times B\times C\)?

Claim \((A\times B)\times C\) is interchangable with \(A\times (B\times C)\)

Proof. \((x,c)\mapsto (\pi_A(x),(\pi_B(x),c))\)

is a function that can be typed as

\[f:(A\times B)\times C \to A\times (B\times C).\]

Also \((a,y)\mapsto ((a,\pi_B(y)),\pi_C(y))\)

is a function that can be typed as

\[g:A\times (B\times C) \to (A\times B)\times C.\]

\(f\circ g\) is \((x,c)\mapsto (x,c)\) and \(g\circ f\) is \((a,y)\mapsto (a,y)\) (identity functions). \(\Box\)

\(A\times B\times C\)?

Claim \((A\times B)\times C\cong A\times (B\times C)\)

\[\frac{S,T:type}{S\cong T:type}(F_{\cong})\]

\((I_{\cong})\)

\[\begin{array}{l} f:S\to T\\ g:T\to S\\ proof_S: g\circ f=1_S\\ proof_T: g\circ g=1_T\\ \hline iso(f,g):S\cong T\end{array}\]

\[\frac{x:S\cong T}{to_x:S\to T}(E_{\cong}to)\]

 

\[\frac{x:S\cong T}{from_x:T\to S}(E_{\cong}from)\]

\((C_{\cong}S)\)\[\frac{f:S\to T,g:T\to S,\ldots}{proof:to_{iso(f,g)} = f}\]

(details later.)

Formation Rule

Introduction Rule

Elimination Rule

Computation Rule

\(A\times B\times C\) Option 1

"Equate" \((A\times B)\times C\) with \(A\times (B\times C)\) via an isomorphism.

 

Subtle problem is you now need to define a type to "equate" types, and on and on.  Leads to \(\infty\)-categories and hard stuff. (Also we have some holes in isomorphism above.)

\(A\times B\times C\) Option 2

Make a new type for triples.

 

Of course next we will want a type for quadruples, qunituples,....multiples.

\(n\)-Multiples type

\[\frac{A_1,\ldots,A_n:type}{A_1\times\cdots \times A_n:type}(F_{\times})\]

 

\[\frac{a_1:A_1,\ldots,a_n:A_n}{(a_1,\ldots,a_n):A_1\times\cdots\times A_n}(I_{n\times})\]

\[\frac{x:A_1\times\cdots\times A_n}{\pi_1(x):A_1}(E_{n\times}1)\ldots\]

 

\[\cdots\frac{a_1:A_1,\ldots,a_n:A_n}{refl_{a_i}:\pi_i(a_1,\ldots,a_n)=_{A_i} a_i}(C_{n\times}i)\cdots\]

\[\cdots\frac{x:A_1\times\cdots\times A_n}{\pi_n(x):A_n}(E_{n\times}n)\]

Formation Rule

Introduction Rule

Elimination Rule

Computation Rule

\(\prod_{i:I} A_i\)-types

Multiples just need an index set \(I\), perhaps more interesting than \(I=\{1,\ldots,n\}\), but certainly to include those sets.

 

In fact, \(I\) might just be an index type, no sets required.

\(\Pi\)-type

\[\begin{array}{rl}I &:type\\ A&:I\to type\\ \hline \prod_{i:I} A_i&:type\end{array}(F_{\Pi})\]

 

\[\frac{i:I\Rightarrow a_i:A_i}{(i\mapsto a_i):\prod_{i:I} A_i}(I_{\Pi})\]

\[\begin{array}{rl}i&:I\\ a&:\prod_{i:I} A_i\\ \hline \pi_i(a)& :A_i\end{array}(E_{\Pi})\]

\[\begin{array}{l}i:I\\ j:I\Rightarrow a_j:A_j\\ \hline refl_{a_i}: \pi_i(i\mapsto a_i)=_{A_i} a_i\end{array}(C_{\Pi})\]

Terms \(f:\prod_{i:I}A_i\) are called dependent functions, written \(f:(i:I)\mapsto (f(i):A_i)\).

Formation Rule

Introduction Rule

Elimination Rule

Computation Rule

The problem of \(proof_S:g\circ f=1_S\)

Hint of an error: Notice here "=" doesn't have the expected \(=_A\) telling us what type of data we are comparing.

 

What counts as a proof that functions are equal?

 

Real problem of function equals...

There are different meanings.

  • Intentional the intensions of the function are the same, i.e. as computer programs they do the same steps: the "intentions" of \(x\mapsto (x+2)-2)\) is not the same as of \(x\mapsto x\).
  • Extensional function equality extended to the results, rather than the process: "extend" equality to observe \(x\mapsto (x+2)-2\) gives the same result as \(x\mapsto x\).

Function Equality Option

Equal inputs give equal outputs.  Given \(f,g:S\to T\) define

\[(f=g) :\equiv (\forall s:S)(f(s)=g(s))\]

 

Turn "=" premise into data...

\[(f=g) :\equiv (\forall s:S)(refl_{f(s)}: f(s)=_T g(s))\]

Turn "\forall" premise into data...

\[(f=g) :\equiv (s:S)\mapsto (refl_{f(s)}: f(s)=_T g(s))\]

I.e.

\[(f=g) :\equiv \prod_{s:S}(f(s)=_T g(s))\]

Function Equality Option (small(big) gap)

Equal inputs give equal outputs actually should mean:

\[(f=g) :\equiv (\forall s_1,s_2:S)(s_1=_S s_2)\Rightarrow (f(s_1)=_T g(s_2))\]

I.e.

\[(f=g) :\equiv \prod_{s_1,s_2:S}\prod_{pf:(s_1=_S S_2)}f(s_1)=_T g(s_2).\]

It is much harder, but still possible, to work with functions at that level of equality.

 

As evidence of difficulty, even elite programming language like Haskell cannot yet do this.  Though there is a recent prototype called Cubical that can.

\(\forall\) becomes data

When propositions, equations, statements \(P\) are types of data whose data are its proofs, then  \[(\forall x:X)(P(x))\] becomes \[\prod_{x:X}P(x).\]

 

Proof of \((\forall x)(P(x))\) becomes data, a dependent function \[(x:X)\mapsto (evidence_x:P(x)).\]

\(\forall\) becomes data

Surprised?

Recall \(A\times B\) naturally modeled \(P\wedge Q\).

 

\((\forall x:X)(P(x))\) is just a big AND, \(P(x_1)\wedge P(x_2)\wedge\cdots\)

Makes sense that iterating \(\times\) would  be the same as iterating AND, i.e. \(\prod\) and \(\forall\) are linked.

 

\(\Sigma\)-type

  • \(A\sqcup B\) is disjoint union, often written \(A+B\) but we avoid that notation in algebra to avoid confusion.
  • \(A_1\sqcup\cdots\sqcup A_n\) should make sense then, also written \(A_1+\cdots+A_n\).
  • So should \(\bigsqcup_{i:I} A_i\), or what is usually written \(\sum_{i:I} A_i\).
  • In the proposition-as-types mode, \[(\exists x:X)(P(x)) \longrightarrow \bigsqcup_{x:X}P(x)\equiv\sum_{x:X}P(x).\]

\(+\)-type  (use \(\sqcup\) if \(+\) is over used)

\[\frac{A_1,\ldots,A_n:type}{A_1+\cdots+A_n:type}(F_{+})\]

 

\[\frac{a_1:A_1}{\iota_1(a_1):A_1+\cdots+A_n}(I_{+}1)\cdots\]

\[\begin{array}{rl} x&:A_1+\cdots+A_n\\ f_1&:A_1\to B\\ \vdots &\\ f_n&:A_n\to B\\ \hline &(f_1+\cdots+f_n)(x):B\end{array}(E_{+})\]

\[\begin{array}{l}i:\{1,\ldots,n\}\vdash a_i:A_i\\ f_1: A_1\to B,\ldots,f_n:A_n\to B\\ \hline refl_{f(a_i)}: (f_1+\cdots+f_n)(\iota_i(a_i)) =_B f_i(a_i)\end{array}\]

\[\cdots\frac{a_n:A_n}{\iota_n(a_n):A_1+\cdots+A_n}(I_{+}n)\]

\((C_{+})\)

Formation Rule

Introduction Rule

Elimination Rule

Computation Rule

\(\Sigma\)-type  (use \(\sqcup\) if \(\Sigma\) is over used)

\[\begin{array}{rl}I &:type\\ A&:I\to type\\ \hline \sum_{i:I} A_i&:type\end{array}(F_{\Sigma})\]

 

\[\frac{i:I\vdash a_i:A_i}{\iota_i(a_i):\sum_{i:I}A_i}(I_{\Sigma})\]

\[\begin{array}{rl} x&:\sum_{i:I}A_i\\ f &: \prod_{i:I} (A_i\to B)\\[2pt] \hline (\Sigma f)(x)&:B\end{array}(E_{\Sigma})\]

\[\begin{array}{l}i:I \vdash a_i:A_i\\ f:\prod_{i:I} (A_i\to B)\\ \hline refl_{f(a_i)}: (\Sigma f)(\iota_i(a_i)) =_B f(a_i)\end{array}\]

\((C_{+})\)

Formation Rule

Introduction Rule

Elimination Rule

Computation Rule

Dependent types

By James Wilson

Dependent types

Dependent types are defined and their implications in propositions-as-types

  • 493