forked from mikeshulman/catlog
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathintro.tex
549 lines (459 loc) · 49.6 KB
/
intro.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
\chapter{Introduction}
\label{chap:intro}
% [TODO: Introduce the word "connective" somewhere; maybe only for posets?]
In this optional chapter I will attempt to motivate and describe the discipline of categorical logic for the newcomer, and also locate this book within the ecosystem thereof for the expert.
Nothing herein is required for reading the rest of the book; but I hope that it may serve some purpose nevertheless.
\section{Appetizer: inverses in group objects}
\label{sec:intro}
In this section we consider an extended example.
We do not expect the reader to understand it very deeply, but we hope it will give some motivation for what follows, as well as a taste of the power and flexibility of categorical logic as a tool for category theory.
Our example will consist of several varations on the following theorem:
\begin{thm}
If a monoid has inverses (hence is a group), then those inverses are unique.
\end{thm}
When ``monoid'' and ``group'' have their usual meaning, namely sets equipped with structure, the proof is easy.
For any $x$, if $y$ and $z$ are both two-sided inverse of $x$, then we have
\begin{equation}
y = y \cdot e = y \cdot (x \cdot z) = (y\cdot x)\cdot z = e\cdot z = z\label{eq:invuniq-easy}
\end{equation}
However, the theorem is true much more generally than this.
We consider first the case of monoid/group objects in a category with products.
A \emph{monoid object} is an object $A$ together with maps $m:A\times A \to A$ and $e:1\to A$ satisfying associativity and unitality axioms:
\begin{equation}
\vcenter{\xymatrix{
A\times A\times A\ar[r]^-{1\times m}\ar[d]_{m\times 1} &
A\times A\ar[d]^m\\
A\times A\ar[r]_m &
A
}}
\qquad
\vcenter{\xymatrix{ A \ar[r]^-{(1,e)} \ar[dr]_{1} &
A\times A \ar[d]_m & A \ar[l]_-{(e,1)} \ar[dl]^{1} \\
& A }}
\end{equation}
An \emph{inverse operator} for a monoid object is a map $i:A\to A$ such that the following diagrams commute:
\begin{equation}
\vcenter{\xymatrix@C=1pc{& A\times A \ar[rr]^{i\times 1} && A\times A \ar[dr]^m \\
A \ar[ur]^{\Delta} \ar[dr]_{\Delta} \ar[rr]^{!} && 1 \ar[rr]^{e} && A \\
& A\times A \ar[rr]_{1\times i} && A\times A \ar[ur]_{m}}}
\end{equation}
The internalized claim, then, is that \emph{any two inverse operators for a monoid object are equal}.
A standard category-theoretic proof would be to suppose $i$ and $j$ are both inverse operators and draw a large commutative diagram such as that shown in \cref{fig:uniqinv-diagram}.
Here the composite around the top is equal to $i$, the composite around the bottom is equal to $j$, and all the internal polygons commute either by one of the monoid axioms, the inverse axiom for $i$ or $j$, or the universal property of products.
(We encourage the reader to verify this.)
\begin{figure}
\centering
\[\xymatrix{
& A\times A \ar[dr]_-{1\times\Delta} \ar[rr]^{\pi_1}
&& A \ar[dr]_{(1,e)} \ar@/^13mm/[ddrr]^{1}\\
&& A\times A\times A \ar[dr]^{1\times 1\times j}
&& A\times A \ar[dr]^m\\
A \ar[rrr]^{(i,1,j)} \ar[uur]_{(i,1)} \ar[ddr]^{(1,j)} &&&
A\times A\times A \ar[ur]_{1\times m} \ar[dr]^{m\times 1} && A\\
&& A\times A\times A \ar[ur]_{i\times 1\times 1}
&& A \times A \ar[ur]_m\\
& A\times A \ar[ur]_-{\Delta\times 1} \ar[rr]_{\pi_2}
&& A\ar[ur]^{(e,1)} \ar@/_13mm/[uurr]_{1}
}
\]
\caption{Uniqueness of inverses by diagram chasing}
\label{fig:uniqinv-diagram}
\end{figure}
While there is a certain beauty to \cref{fig:uniqinv-diagram}, it takes considerable effort to write it down and arrange it in such a pleasing form (as opposed to a horrid mess on scratch paper), let alone typeset it prettily.
And this is really a fairly simple fact about monoids; for more complicated theorems, the complexity of the resulting diagrams grows accordingly (see \cref{ex:eckmann-hilton,ex:near-ring}).
Nevertheless, there is a sense in which \cref{fig:uniqinv-diagram} is obtained \emph{algorithmically} from the simple proof~\eqref{eq:invuniq-easy}.
Specifically, each expression in~\eqref{eq:invuniq-easy} corresponds to one or more paths through \cref{fig:uniqinv-diagram}, and each equality in~\eqref{eq:invuniq-easy} corresponds to a commuting polygon in \cref{fig:uniqinv-diagram}.\footnote{Not every polygon in \cref{fig:uniqinv-diagram} corresponds to anything in~\eqref{eq:invuniq-easy}, though: the ``universal property'' quadrilaterals on the left are ``invisible'' algebraically.
This is why we said each expression corresponds to ``one or more'' paths: $y\cdot (x\cdot z)$ and $(y\cdot x)\cdot z$ don't care which route we take from $A$ to $A\times A\times A$.}
With experience, one can learn to do such translations without much effort, at least in simple cases.
However, if it really is an algorithm, we shouldn't have to re-do it on a case-by-case basis at all; we should be able to prove a single general ``meta-theorem'' and then appeal to it whenever we want to.
This is the goal of categorical logic.
Specifically, the \emph{type theory for categories with products} allows us to replace \cref{fig:uniqinv-diagram} by an argument that looks almost the same as~\eqref{eq:invuniq-easy}.
The morphisms $m$ and $e$ are represented in this logic by the notations
\begin{mathpar}
x:A,y:A \types x\cdot y :A \and
\types e:A.
\end{mathpar}
Don't worry if this notation doesn't make a whole lot of sense yet.
The symbol $\types$ (called a ``turnstile'') is the logic version of a morphism arrow $\to$, and the entire notation is called a \emph{sequent} or a \emph{judgment}.
The fact that $m$ is a morphism $A\times A \to A$ is indicated by the fact that $A$ appears twice to the left of $\types$ and once to the right; the comma ``$,$'' in between $x:A$ and $y:A$ represents the product $\times$, and the variables $x,y$ are there so that we have a good notation ``$x\cdot y$'' for the morphism $m$.
In particular, the notation $x:A,y:A \types x\cdot y :A$ should be bracketed as
\[ ((x:A),(y:A)) \types ((x\cdot y) :A). \]
Similarly, the associativity, unit, and inverse axioms are indicated by the notations
\begin{mathpar}
x:A,y:A,z:A \types (x\cdot y)\cdot z = x\cdot (y\cdot z) : A \\
x:A \types x\cdot e = x : A \and
x:A \types e\cdot x = x : A \\
x:A \types x\cdot i(x) = e : A \and
x:A \types i(x) \cdot x = e : A
\end{mathpar}
Now~\eqref{eq:invuniq-easy} can be essentially copied in this notation:
\[ x:A \types i(x) = i(x) \cdot e = i(x) \cdot (x \cdot j(x)) = (i(x)\cdot x)\cdot j(x) = e\cdot j(x) = j(x) : A.\]
The essential point is that the notation \emph{looks set-theoretic}, with ``variables'' representing ``elements'', and yet (as we will see) its formal structure is such that it can be interpreted into \emph{any} category with products.
Therefore, writing the proof in this way yields automatically a proof of the general theorem that any two inverse \emph{operators} for a monoid \emph{object} in a category with products are equal.
Before leaving this appetizer section, we mention some further generalizations of this result.
While type theory allows us to use set-like notation to prove facts about any category with finite products, the allowable notation is fairly limited, essentially restricting us to algebraic calculations with variables.
However, if our category has more structure, then we can ``internalize'' more set-theoretic arguments.
As an example, note that for ordinary monoids in sets, the uniqueness of inverses~\eqref{eq:invuniq-easy} is expressed ``pointwise'' rather than in terms of inverse-assigning operators.
In other words, for each element $x\in A$, if $x$ has two two-sided inverses $y$ and $z$, then $y=z$, regardless of whether any other elements of $A$ have inverses.
If we think hard enough, we can express this diagrammatically in terms of the category \bSet.
Consider the following two sets:
\begin{align*}
B &= \setof{(x,y,z)\in A^3 | xy=e, yx=e, xz=e, zx=e}\\
C &= \setof{(y,z)\in A^2 | y=z}
\end{align*}
In other words, $B$ is the set of elements $x$ equipped with two inverses, and $C$ is the set of pairs of equal elements.
Then the uniqueness of pointwise inverses can be expressed by saying there is a commutative diagram
\[ \xymatrix{ B \ar[d] \ar[r] & C \ar[d] \\ A^3 \ar[r]_{\pi_{23}} & A^2 } \]
where the vertical arrows are inclusions and the lower horizontal arrow projects to the second and third components.
This is a statement that makes sense for a monoid object $A$ in any category with finite \emph{limits}.
The object $C$ can be constructed categorically as the equalizer of the two projections $A\times A \toto A$ (which is in fact isomorphic to $A$ itself), while the object $B$ is a ``joint equalizer'' of four parallel pairs, one of which is
\[ \vcenter{\xymatrix{ & A \times A \ar[dr]^m \\
A\times A\times A \ar[ur]^{\pi_{12}} \ar[dr]_{!} && A \\
& 1 \ar[ur]_e }} \]
and the others are similar.
We can then try to \emph{prove}, in this generality, that there is a commutative square as above.
We can do this by manipulating arrows, or by appealing to the Yoneda lemma, but we can also use a \emph{type theory for categories with finite limits}.
This is a syntax like the type theory for categories with finite products, but which also allows us to \emph{hypothesize equalities}.
The judgment in question is
\begin{equation}\label{eq:pointwise-unique-inverses}
x:A, y:A, z:A, (x\cdot y = e), (y\cdot x=e), (x\cdot z = e), (z\cdot x = e) \types (y=z).
\end{equation}
As before, the comma binds the most loosely, so this should be read as
\[ ((x:A), (y:A), (z:A), (x\cdot y = e), (y\cdot x=e), (x\cdot z = e), (z\cdot x = e)) \types (y=z). \]
We can prove this by set-like equational reasoning, essentially just as before.
The ``interpretation machine'' then produces from this a morphism $B\to C$, for the objects $B$ and $C$ constructed above.
Next, note that in the category \bSet, the uniqueness of inverses ensures that if every element $x\in A$ has an inverse, then there is a \emph{function} $i:A\to A$ assigning inverses --- even without using the axiom of choice.
(If we define functions as sets of ordered pairs, as is usual in set-theoretic foundations, we could take $i = \setof{(x,y) | xy=e}$; the pointwise uniqueness ensures that this is indeed a function.)
This fact can be expressed in the type theory of an \emph{elementary topos}.
We postpone the definition of a topos until later; for now we just remark that its structure allows both sides of the turnstile $\types$ to contain \emph{logical formulas} such as $\exis x. \all y. \phi(x,y)$ rather than just elements and equalities.
In this language we can state and prove the following:
\[ \forall x:A. \exists y:A. ((x\cdot y = e) \land (y\cdot x = e)) \types
\exists i:A^A. \forall x:A. ((x\cdot i(x) = e) \land (i(x)\cdot x = e))
\]
As before, the proof is essentially exactly like the usual set-theoretic one.
Moreover, the interpretation machine allows us to actually extract an ``inverse operator'' morphism in the topos from this proof.
Such a result can also be stated and proved using arrows and commutative diagrams, but as the theorems get more complicated, the translation gets more tedious to do by hand, and the advantage of type-theoretic notation becomes greater.
\begin{props}
So much for adding extra structure.
In fact, we can also take structure away!
A monoid object can be defined internal to any \emph{monoidal} category, not just a cartesian monoidal one; now the structure maps are $m:A\tensor A\to A$ and $e:\one\to A$, and the commutative diagrams are essentially the same.
To define an inverse operator in this case, however, we need some sort of ``diagonal'' $\comult:A\to A\tensor A$ and also a ``projection'' or ``augmentation'' $\counit:A\to \one$.
The most natural hypothesis is that these maps make $A$ into a \emph{comonoid} object, i.e.\ a monoid in the opposite monoidal category, and that the monoid and comonoid structures preserve each other; this is the notion of a \emph{bimonoid} (or ``bialgebra'').
(\cref{ex:cartmon-bimon-uniq}: in a cartesian monoidal category, every object is a bimonoid in a unique way.)
Now given a bimonoid $A$, we can define an ``inverse operator'' --- which in this context is usually called an \emph{antipode} --- to be a map $i:A\to A$ such that
\begin{equation}
\vcenter{\xymatrix@C=1pc{& A\tensor A \ar[rr]^{i\tensor 1} && A\tensor A \ar[dr]^m \\
A \ar[ur]^{\comult} \ar[dr]_{\comult} \ar[rr]^{\counit} && \one \ar[rr]^{e} && A \\
& A\tensor A \ar[rr]_{1\tensor i} && A\tensor A \ar[ur]_{m}}}
\end{equation}
commutes, where now $\comult$ and $\counit$ are the comonoid structure of $A$ rather than the diagonal and projection of a cartesian product.
A bimonoid equipped with an antipode is called a \emph{Hopf monoid} (or ``Hopf algebra'').
The obvious question then is, if a bimonoid has two antipodes, are they equal?
In some cases it is possible to apply the previous results directly.
For instance, the category of \emph{(co)commutative} comonoids in a symmetric monoidal category inherits a monoidal structure that turns out to be \emph{cartesian} (\cref{ex:ccmon-cart}), so a cocommutative bimonoid is actually a monoid in a cartesian monoidal category, and we can apply the first version of our result.
Similarly, the category of commutative monoids is cocartesian, so a commutative bimonoid is a comonoid in a cocartesian monoidal category, so we can apply the dual of the first version of our result.
But what if neither the multiplication nor the comultiplication is commutative?
Internal logic is up to this task.
In a monoidal category we can consider judgments with multiple outputs as well as multiple inputs.\footnote{For the benefit of readers who are already experts, I should mention that this is \emph{not} ordinary ``classical linear logic'': the comma represents the same monoidal structure $\tensor$ on both sides of the turnstile, rather than $\tensor$ on the left and $\parr$ on the right.}
This allows us to describe monoids and comonoids in a roughly ``dual'' way; compare the first and second groups of axioms in \cref{fig:intro-prop-moncomon}.
\begin{figure}
\centering
\begin{align*}
x:A, y:A &\types x\cdot y:A\\
&\types e:A\\
x:A,y:A,z:A &\types (x\cdot y)\cdot z = x\cdot (y\cdot z) :A\\
x:A &\types x\cdot e=x:A\\
x:A &\types e\cdot x=x:A\\
\\
x:A &\types (x\s1,x\s2):(A,A)\\
x:A &\types (\,\mid\cancel{x}):()\\
x:A &\types (x\s1{}\s1,x\s1{}\s2,x\s2)=(x\s1,x\s2{}\s1,x\s2{}\s2):(A,A,A)\\
x:A &\types (x\s1\mid\cancel{x\s2}) = x:A\\
x:A &\types (x\s2\mid\cancel{x\s1}) = x:A
\end{align*}
\caption{Monoids and comonoids}
\label{fig:intro-prop-moncomon}
\end{figure}
Don't worry about the precise syntax being used in the comonoid axioms; it will be explained in \cref{sec:prop-smc}.
(But if you are familiar with the informal ``Sweedler notation'' for coalgebras, it should look familiar.)
The main point to make about this syntax is that on the right we have lists such as $(M,N\mid P):(A,B)$, where $M$ and $N$ correspond in some way to $A$ and $B$ respectively, while $P$ and anything else on the right of the divider has ``no type'' (we call it a \emph{scalar}; categorically it represents a morphism to the unit object).
In this syntax, the bimonoid axioms are
\begin{align*}
x:A,y:A &\types (x\s1\cdot y\s1,x\s2\cdot y\s2) = ((x\cdot y)\s1,(x\cdot y)\s2) :(A,A)\\
&\types (e\s1,e\s2)=(e,e):(A,A)\\
x:A,y:A &\types (\,\mid\cancel{x\cdot y}) = (\,\mid\cancel{x},\cancel{y}) : ()\\
&\types (\,\mid\cancel{e})=():()
\end{align*}
And an antipode is a map $x:A \types i(x):A$ such that
\begin{align*}
x:A &\types (x\s1\cdot i(x\s2)) = (e\mid\cancel{x}) :A\\
x:A &\types (i(x\s1)\cdot x\s2) = (e\mid\cancel{x}) :A
\end{align*}
Now if we have another antipode $j$, we can compute
\begin{align*}
x:A \types (i(x))
&= (i(x)\cdot e)\\
&= (i(x\s1)\cdot e\mid\cancel{x\s2})\\
&= i(x\s1)\cdot (x\s2{}\s1 \cdot j(x\s2{}\s2))\\
&= (i(x\s1)\cdot x\s2{}\s1) \cdot j(x\s2{}\s2)\\
&= (i(x\s1{}\s1)\cdot x\s1{}\s2) \cdot j(x\s2)\\
&= (e \cdot j(x\s2)\mid\cancel{x\s1})\\
&= (e\cdot j(x))\\
&= (j(x)) \qquad :A
\end{align*}
yielding the same result $i=j$.
(In fact, as in traditional Sweedler notation, we can also incorporate coassociativity directly into the notation, writing $(x\s1,x\s2,x\s3)$ instead of $(x\s1{}\s1,x\s1{}\s1,x\s2)$ or $(x\s1,x\s2{}\s1,x\s2{}\s2)$; this shortens the above proof by one line.)
So even in a non-cartesian situation, we can use a very similar set-like argument, as long as we keep track of where elements get ``duplicated and discarded''.
\end{props}
This concludes our ``appetizer''; I hope it has given you a taste of what categorical logic looks like, and what it can do for category theory.
In \cref{chap:unary} we will rewind back to the beginning and start with very simple type theories (even simpler than the ones we used in this section).
Before we actually start doing type theory, however, let me prepare the ground a little by explaining how, in principle, the sort of ``interpretation machine'' mentioned above can work.
\subsection*{Exercises}
\begin{ex}\label{ex:cartmon-bimon-uniq}
Prove that in a cartesian monoidal category, every object is a bimonoid in a unique way.
\end{ex}
\begin{ex}\label{ex:ccmon-cart}
Show that the category of cocommutative comonoids in a symmetric monoidal category inherits a monoidal structure, and that this monoidal structure is cartesian.
\end{ex}
\begin{ex}\label{ex:antipode}
Prove, using arrows and commutative diagrams, that any two antipodes for a bimonoid (not necessarily commutative or cocommutative) are equal.
\end{ex}
\begin{ex}\label{ex:eckmann-hilton}
Suppose $A$ is a set with two monoid structures $(m_1,e)$ and $(m_2,e)$ having the same unit element $e$, and satisfying the ``interchange law'' $m_1(m_2(x,y),m_2(z,w)) = m_2(m_1(x,z),m_1(y,w))$.
Then we have
\[ m_1(x,y) = m_1(m_2(x,e),m_2(e,y)) = m_2(m_1(x,e),m_1(e,y)) = m_2(x,y) \]
and also
\[ m_1(x,y) = m_1(m_2(e,x),m_2(y,e)) = m_2(m_1(e,y),m_1(x,e)) = m_2(y,x) \]
so that $m_1=m_2$ and both are commutative.
This is called the \emph{Eckmann-Hilton argument}.
State and prove an analogous fact about objects in any category with finite products having two monoid structures satisfying an ``interchange law''.
\textit{(In \cref{ex:catprod-eckmann-hilton,ex:catprod-ehnr-again} you will re-do this proof using internal logic for comparison.)}
\end{ex}
\begin{ex}\label{ex:near-ring}
A ``distributive near-ring'' is like a ring but without the assumption that addition is commutative; thus we have a monoid structure $(\cdot,1)$ and a group structure $(+,0)$ such that $\cdot$ distributes over $+$ on both sides.
\begin{enumerate}
\item Prove that every distributive near-ring is actually a ring.
\textit{(For this reason, in an unqualified ``near-ring'' only one side of distributivity is assumed.)}
\item Define a ``distributive near-ring object'' in a category with finite products.
Try for a little while to prove that any such is actually a ``ring object'', at least until you can see how much work it would be.
In \cref{ex:catprod-nearring,ex:catprod-ehnr-again} you will prove this using type theory for comparison.
\end{enumerate}
\end{ex}
\section{On syntax and free objects}
\label{sec:syntax}
The way that type theory allows us to prove things about categorical structures is by providing a \emph{syntactic presentation of free objects}.
To explain what this means, let's consider an example that (apparently) has very little to do with type theory or category theory.
The following is a standard result from elementary group theory.
\begin{thm}\label{thm:intro-conjugation}
Recall that for elements $g,h$ of a group $G$, the \textbf{conjugation} of $h$ by $g$ is defined by $h^g = g h g^{-1}$.
For any $g,h,k$ we have $h^g\,k^g = (hk)^g$.
\end{thm}
\begin{proof}
\[ h^g\,k^g = (g h g^{-1})(g k g^{-1}) = g h k g^{-1} = (hk)^g \qedhere \]
\end{proof}
Now this ``proof'' is not, technically, a complete proof from the usual axioms of a group.
In fact, even the definition of conjugation is not, technically, meaningful, because the usual axioms of a group only involve a way to multiply \emph{two} elements, not three.
Technically, we should choose a parenthesization and write, say, $h^g = (g h) g^{-1}$; and then use the associativity and unit axioms explicitly throughout the above proof:
\begin{multline*}
h^g k^g
= ((g h) g^{-1})((g k) g^{-1})
= (g (h g^{-1}))((g k) g^{-1})
= ((g (h g^{-1}))(g k)) g^{-1}\\
= (g ((h g^{-1})(g k))) g^{-1}
= (g (h (g^{-1}(g k)))) g^{-1}
= (g (h ((g^{-1} g) k))) g^{-1}\\
= (g (h (e k))) g^{-1}
= (g (h k)) g^{-1}
= (h k)^g
\end{multline*}
Of course, this would be horrific, so no one ever does it.
But what justifies \emph{not} doing it?
Normally, if mathematicians think about this sort of question at all, they would probably say that technically the extra steps have to be there, but we omit them because the reader could fill them in him- or herself.
There's nothing intrinsically wrong with this (although it does start to become problematic when formalizing mathematics in a computer, since the computer can't fill in the steps itself unless some programmer takes the time to teach it exactly how).
Interestingly, however, there \emph{is} a way to make the nice short proof of \cref{thm:intro-conjugation} completely rigorous on its own.
Consider the \emph{free group} $F_3$ generated by three elements $g,h,k$.
Then the elements of $F_3$ can be represented by finite strings composed of the letters $g,h,k$ and their formal inverses, in which no letter is ever adjacent to its inverse (we call these \textbf{reduced words}).
In particular, $g h g^{-1}$ and $g k g^{-1}$ and $g h k g^{-1}$ are all elements of $F_3$, and the product $(g h g^{-1})(g k g^{-1})$ is equal to $g h k g^{-1}$ by definition of multiplication in $F_3$ (concatenate strings and cancel any elements adjacent to their inverses).
Thus, the calculation in the proof of \cref{thm:intro-conjugation} makes literal sense as a statement \emph{about elements of $F_3$}.
Of course, we want the theorem to be true about \emph{any} three elements of \emph{any} group, not just the generators of $F_3$.
But if we have three such elements $g', h', k'\in G$, the freeness of $F_3$ means there is a unique group homomorphism $\free:F_3 \to G$ such that $\free(g) = g'$, $\free(h)=h'$, and $\free(k)=k'$.
Since $\free$ is a group homomorphism, it preserves conjugation and multiplication.
Thus, since \cref{thm:intro-conjugation} is true about $g,h,k\in F_3$, it must also be true about $g',h',k'\in G$.
This is the basic method of categorical logic: we do a calculation in a free structure, then map it everywhere else using the unique morphisms determined by the universal property of that free structure.
Of course, not much is gained by this in our current fairly trivial example; in particular, no one would ever consider teaching undergraduates group theory that way!
But as we will see, the same principle applies in much more complicated situations, and tends to get more and more useful the more complicated the structures and proofs are.
It's natural, however, to wonder why such an approach gains us \emph{anything at all}!
Why would it be any easier to prove something in a free group than in an arbitrary group?
It almost seems as if it must be false by definition: anything that's true in a free group must be true in all groups, precisely by freeness, so any proof that works in a free group must work in any group.
This ``false by definition'' argument is almost valid.
It \emph{is} valid if the only thing we know about free groups is their universal property.
The crucial ingredient in our simplified proof of \cref{thm:intro-conjugation}, however, is that we knew \emph{more} about free groups than their universal property: we had an explicit description of their elements as reduced words.
Thus, we were able to make use of this knowledge to give a proof in a free group that wouldn't work in an arbitrary group.
I want to emphasize that this explicit description of a free group is \emph{not} a trivial consequence of its universal property.
There is a ``tautological'' way to construct free groups, but it produces a quite different description:
\begin{enumerate}
\item Start with the generators.
\item Successively apply the operations appearing in the definition (binary multiplication, the unary operation of inversion, and the nullary operation of the identity element) without reference to the axioms.
This yields expressions such as $(g h)^{-1}(k^{-1} (k g))$.
\item Define an equivalence relation on these expressions to be the smallest one that forces all the axioms to hold and is respected by all the operations.
Thus, for instance, $(g h)^{-1}(k^{-1} (k g))$ would be identified with $(h^{-1} ((g^{-1} k^{-1}) k)) g$, and also $(g h)^{-1} g$, and also $h^{-1}$.
\item The quotient of this equivalence relation is the free group on our chosen generators.
\end{enumerate}
This sort of method works to construct free algebras for any ``algebraic theory''; but it would not help us justify the short proof of \cref{thm:intro-conjugation}.
The tautological construction produces a free group whose elements are equivalence classes, without any way to choose canonical representatives; in contrast to our explicit description with words, which involved no equivalence classes at all.
Moreover, there are other algebraic theories, such as \emph{abelian} groups, for which there \emph{are} no canonical representatives for elements of free algebras; so something relatively special to do with groups in particular is happening here.
Roughly the same thing is also true for categorical logic: for many kinds of categorical structure, ``something special'' happens, enabling us to give an explicit description of free structures, and thereby simplify many proofs.
Moreover, the ``something special'' that happens is more or less the same thing that happens in the case of groups; so it is worth explaining the latter a bit more.
How do we prove that the free group on a set $X$ can be presented using reduced words, given that it is not the tautological construction?
The very first thing we need to do is prove that the set of reduced words, call it $\F{}X$, \emph{is} a group.
To multiply two reduced words $w_1$ and $w_2$, we have to concatenate them, but then ``cancel all the element-inverse pairs that appear in the middle''.
A very formal way to describe this process is by induction.
Consider the second word $w_2$.
If it has length $0$ (i.e.\ it is the empty word), then we can define the product $w_1\cdot w_2$ to be just $w_1$.
Otherwise, $w_2$ must end with either a generator or its inverse.
Suppose it ends with a generator, so that $w_2 = w_2' g$ for some $g\in X$ (we leave the other case to the reader).
Then $w_2'$ is shorter than $w_2$, so by induction on its length, we may suppose that we have defined how to multiply $w_1$ by $w_2'$, obtaining a new word $w_1 \cdot w_2'$.
Now, since we hope multiplication will be associative, and we expect $w_2$ to actually be the product $w_2' \cdot g$ (not just the concatenation), we should have $w_1 \cdot w_2 = w_1 \cdot (w_2'\cdot g) = (w_1\cdot w_2')\cdot g$.
Thus, since we have inductively defined $w_1\cdot w_2'$, we only need to multiply it on the right by $g$.
We would like to just concatenate $g$ on the end, but this might not result in a reduced word, if it happens that $w_1\cdot w_2'$ ends with $g^{-1}$.
(How could this happen, given that $w_2'$ doesn't end with $g$ (since $w_2 = w_2'g$ is reduced)?
The simplest case is if $w_1$ ends with $g^{-1}$ and $w_2'$ is empty.
More generally, all of $w_2'$ could get canceled by part of $w_1$ to expose a $g^{-1}$ inside $w_1$.)
Thus, we have to inspect $w_1\cdot w_2'$.
If it ends with $g^{-1}$, say $w_1\cdot w_2' = w_3 g^{-1}$, then we define the product $w_1 \cdot w_2$ to be $w_3$.
Otherwise, the concatenated word $(w_1\cdot w_2')g$ is reduced, so we can define it to be $w_1\cdot w_2$.
This completes our formal definition of multiplication of reduced words.
The reason for writing out the proof in such a pedantic way is that essentially the same method works for the rest of the argument.
For instance, how do we prove that multiplication is associative?
Given three reduced words $w_1$, $w_2$, and $w_3$, we induct on the length of $w_3$.
If it is empty, then $(w_1\cdot w_2)\cdot w_3$ and $w_1 \cdot (w_2 \cdot w_3)$ are both $w_1\cdot w_2$ by definition.
Otherwise, $w_3 = w_3'g$ (or $w_3 = w_3'g^{-1}$), and we can use the definitions of multiplication and an inductive hypothesis that $(w_1\cdot w_2)\cdot w_3' = w_1 \cdot (w_2 \cdot w_3')$.
Similarly, how do we extend a function $\pfree:X\to G$ to a group homomorphism $\free:\F{}X\to G$?
Each reduced word is either empty, in which case it must go to the identity of $G$, or of the form $wg$ for some $g\in X$, in which case it must go to the product $\free(w)\cdot \pfree(g)$ in $G$.
And we prove that $\free(w_1\cdot w_2) = \free(w_1)\cdot \free(w_2)$ by --- you guessed it --- induction on the length of $w_2$.
This fairly simple proof actually displays many of the characteristics of analogous proofs about type theories that we will encounter throughout the book.
The construction of multiplication in $\F{}X$ is a simple form of \textbf{cut admissibility}, and the proof that $\F{}X$ is the free group on $X$ provides a prototype for the ``initiality theorems'' that we will prove for all of our type theories.
(This is the ``something special'' I referred to earlier that happens for groups, and also for categories, but not for abelian groups.)
But the most important thing to take away is the overall picture: we gave a concrete description of a free structure that was not obvious from its universal property, enabling us to write proofs in the free structure that would not make sense in an arbitrary structure, but nevertheless imply conclusions about arbitrary structures by the universal property.
Now you may be able to look back at \cref{sec:intro} and have a slightly better idea of what is happening.
The funny type-theoretic syntax such as $x:A,y:A \types x\cdot y :A$ is a particular explicit presentation of (in this case) the category with products ``freely generated by a monoid with two inverse operators''.
This is a category with products, say $\F{}\cI$, containing a monoid object $A$ with two inverse operators, with the property that given any other category with products \cM and a monoid object $B$ therein with two inverse operators, there is a unique functor $\F{}\cI \to \cM$ mapping $A$ and its inverse operators to $B$ and its inverse operators.
Our calculation in this type theory showed that the two inverse operators of $A$ are equal; therefore, so must those of $B$, for any \cM and $B$.
I emphasize again that we will make all of this more precise later on, so it is not necessary to understand deeply right now.
But the idea is unfamiliar enough to many mathematicians that you may need to let it wash over you for a while before coming to understand it.
(Certainly that was my own experience with learning type theory.)
I also hope that seeing this glimpse of the bigger picture will motivate the reader to make it through the (sometimes rather technical) details of subsequent chapters.
\begin{rmk}
It is worth noting that type theory is not the only syntax for free structures in category theory; probably the best-known alternative syntax is \emph{string diagrams} (see e.g.~\cite{js:geom-tenscalc-i,selinger:graphical}).
Type theory and string diagrams use the same idea of giving a concrete presentation of a free object that is easier to reason about, but the particular presentations used are quite different.
Type-theoretic presentations are typically characterized by cut-admissibility and similar theorems, whereas string diagrams use topological structures and deformations.
Each has strengths and weaknesses; some proofs are easy in type theory and difficult with string diagrams, while for other proofs the opposite is true.
In fact, the \emph{usual} way of reasoning in category theory (or any other subject), in which we speak explicitly about objects, arrows, and so on, can be interpreted to be simply making use of the ``tautological'' presentation of a free structure rather than some fancier one.
In this case, of course, there is nothing practical to be gained by such a viewpoint; but it may help to ``relate the new with the old''.
\end{rmk}
\subsection*{Exercises}
\begin{ex}\label{ex:group-cutadm}
Write out the remaining details in the proof that $\F{}X$ is the free group generated by the set $X$.
\end{ex}
\section{On type theory and category theory}
\label{sec:generalities}
So much for the big picture of categorical logic.
However, since there are many other introductions to categorical logic (a non-exhaustive list could include~\cite{mr:focl,ls:hocl,jacobs:cltt,goldblatt:topoi,ptj:elephant}), it seems appropriate to say a few words about what distinguishes this one.
These words may not make very much sense to the beginner who doesn't yet know what we are talking about, but they may help to orient the expert, and as the beginner becomes more expert he or she can return to them later on.
Our perspective is very much that of the category theorist: our primary goal is to use type theory as a convenient syntax to prove things about categories, by presenting free structures in a particular way.
(It can be tempting for the category theorist to want to generalize away from free structures to arbitrary ones, but this temptation should be resisted; see \cref{rmk:free}.)
In particular, this means that we are not interested in aspects of type theory such as computability, canonicity, proof search, cut-elimination, focusing, and so on \emph{for their own sake}.
However, at the same time we recognize their importance for type theory as a subject in its own right, which suggests that they should not be ignored by the category theorist.
If nothing else, the category theorist will encounter these words when speaking to type theorists, and so it is advantageous to have at least a passing familiarity with them.
In fact, our perspective is that the esoteric-sounding notion of \emph{cut admissibility} (and its various other incarnations such as \emph{cut-elimination} or \emph{admissibility of substitution}) essentially \emph{defines} what we mean by a ``type theory'' (as opposed to some other syntax for free structures, such as string diagrams or the tautological one).
Of course this is not literally true; a more careful statement would be that type theories with cut elimination are those that exhibit the most behavior most characteristic of type theories.
(Jean-Yves Girard remarked that ``a logic without cut-elimination is like a car without an engine.'')
A ``type theory without cut elimination'' can still yield explicit presentations of free structures, but will tend to lack some of the characteristic features of categorical logic.
So what is this mysterious cut-admissibility, from a categorical perspective?
We saw a simple example of it for groups in \cref{sec:syntax}.
In general, cut admissibility says that the morphisms in a free categorical structure can be presented \emph{without explicit reference to composition}.
This is a bit of a cheat, because as we will see, in fact what we do is to build just enough ``implicit'' reference to composition into our rules to ensure that we no longer need to talk about composition explicitly.
However, this does not make the process trivial, and it can still yield valuable results.
As a simple example of nontriviality, if an arrow is constructed by applying a universal property, then that property automatically determines some of the composites of that arrow.
For instance, a pairing $\pair{f}{g}:X\to A\times B$ must compose with the projections $\pi_1:A\times B\to A$ and $\pi_2:A\times B\to B$ to give $f$ and $g$ respectively.
Thus, these composites do not need to be ``built in'' by hand.
Another interesting fact about cut-elimination is that the composition it produces is automatically associative (and unital), despite the fact that we do not apparently put associativity in anywhere (even implicitly).
Do\v{s}en~\cite{dosen:cutelim-cats} %\footnote{[TODO: Read Do\v{s}en and Petri\'{c}, \textit{Proof-Theoretical Coherence}, \url{http://www.mi.sanu.ac.rs/~kosta/publications.htm}]}
uses this to ``explain'' or ``justify'' the definition of category (and other basic category-theoretic notions) in terms of cut-elimination.
Of course, for our intended audience of category theorists it is cut-elimination, rather than associativity, that requires explanation and justification; but nevertheless the relationship is intriguing.
There is undoubtedly a connection with the ``something special'' possessed by groups and categories but not by magmas or abelian groups.
Both of these facts are instances of an underlying general principle: by presenting a free categorical structure without explicit reference to composition, we are free to then \emph{define} its composition as an operation on its already-existing morphisms, and we can choose this definition so as to ensure that various desirable properties hold automatically.
This eliminates or reduces the need for quotienting by equivalence relations in the presentation of a free structure.
Put differently, a type theory isolates a class of \emph{canonical forms} for morphisms.
In simple cases every morphism has exactly one canonical form, so that no equivalence relation on the canonical forms is needed.
In more complicated situations we still need an equivalence relation, but the necessary equivalence relation is often simpler and/or more intuitive than that involved in more tautological presentations of free structures.
Another characteristic advantage of categorical logic is that it enables us to use ``set-like'' reasoning to prove things about arbitrary categories, by means of ``term calculi'' associated to its presentations of free structures.
(This is what we exhibited several examples of in \cref{sec:intro}.)
Such syntax is not actually a characteristic of \emph{all} type theories, but of a large class of common ones that are sometimes known as ``natural deduction'' theories (although this usage of the term is much broader than its traditional denotation).
Roughly speaking, natural deduction theories ``build in composition'' on the left side only, which from a categorical perspective suggests that they are talking about representable presheaves, i.e.\ describing a category by way of its Yoneda embedding.
The characteristic ``set-like'' syntax of natural deduction theories then corresponds to the point of view that considers an arbitrary morphism $x:X\to A$ in a category to be a ``generalized element'' of $A$.
Despite the usefulness of terms, we will maintain and emphasize throughout the principle that terms should be just a convenient notation for derivation trees.
This perspective has many advantages.
For instance, it means that a (constructive) proof of cut-elimination \emph{is already} a definition of substitution into terms; it is not necessary to separately define a notion of ``substitution into terms'' and then prove that this \emph{separately defined} notion of substitution is admissible.
It also deals quite nicely with the problems of $\alpha$-equivalence and bound variable renaming: as an operation on derivations, substitution doesn't need to care about ``whether a free variable is going to get captured''; the point is just that when we choose a term to represent the substituted derivation we have to accord with the general rules for how terms are assigned to derivations.
Most importantly, however, adhering to the ``terms are derivations'' principle greatly simplifies the proofs of the central ``initiality theorems'' (that the type theory really does present a free category with appropriate structure), since we can define a map out of the type theory \emph{by induction on derivations} and deduce immediately that it is also defined on terms.
If the ``terms are derivations'' principle is broken, then one generally ends up wanting to induct on derivations anyway, and then having to prove laboriously that the resulting ``operation'' on terms is independent of their derivations.
Informally, the ``terms are derivations'' principle means that \emph{the meaning of a notation can be evaluated simply on the basis of the notation as written, without having to guess at the thought processes of the person who wrote it down}.
That is, the meaning of ``$2+3$'' should not depend on whether we obtained it by substituting $x=2$ into $x+3$ or by substituting $y=3$ into $2+y$.
This is obviously a desirable feature, and arguably even a necessary one if our ``notation'' is to be worthy of the name.
Moreover, this ``freedom from mind-reading'' should hold \emph{by definition} of the meaning of our notation: the meaning of $2+3$ should be defined on its own without reference to $x+3$ and $2+y$, with the fact that we can obtain it from the latter expressions by substitution being a later observation.
This principle demands in particular that substitution be an ``admissible rule'' rather than a primitive one (that is, an operation defined on terms/derivations, rather than one of the rules for producing them).
For similar reasons, we present our type theories so as to ensure that as many structural rules as possible are admissible rather than primitive: not only cut/substitution, but also exchange, contraction, and weakening.
The meaning of $x+y$ should not depend on which of the variables $x$ and $y$ happens to have been mentioned first in the course of a proof.
Many introductions to type theory are somewhat vague about exactly how these structural rules are to be imposed, especially for substructural theories such as linear logic with exchange only.
However, when we try to use type theory to present a free symmetric monoidal category (as opposed to a free symmetric monoidal poset), we have to worry about the functoriality of the exchange rule, which technically requires being explicit about exactly how exchange works.
If we make exchange admissible, then it is automatically functorial, just as making substitution admissible gives associativity for free; this considerably simplifies the theory.
Having structural rules as primitive would also make the notation quite tedious if we continued to adhere to the principle that terms are just a notation for derivations.
In fact, it seems to me that much of the literature on categorical logic contains gaps or even errors relating to these points.
It is very tempting to prove the initiality theorem by induction on derivations without realizing that by breaking the ``terms are derivations'' principle one thereby incurs an obligation to prove that the interpretation of a term is independent of its derivation.
It is also very tempting to include too many primitive rules, perhaps based on the thought that if a rule is true anyway, it's simpler to assume it than to have to prove it.
One way to break this habit is to think of primitive rules as the \emph{operations} in an algebraic theory for which we are interested in the free algebras: clearly if there are too many operations, then the initial algebra will be too big.
Another unusual feature of our treatment is the emphasis on multicategories (of various generalized sorts, including also the still more general ``polycategories'' and their generalizations).
We start with ordinary multicategories since they are simplest categorically, which forces us to consider ``substructural'' type theories such as linear logic at least briefly.
But soon we move on to \emph{cartesian multicategories}, which correspond to the more familiar kind of type theory with exchange, contraction, and weakening; these are a very natural structure, but are hard to find in the category-theoretic literature.
Although multicategories have been present in categorical logic from close to the beginnings of both (Lambek's original definition of multicategory~\cite{lambek:dedsys-ii} was motivated by logical considerations), they are rarely mentioned in introductions to the subject.
One concrete advantage of using multicategories is a more direct correspondence between the type theory and the category theory: type theory distinguishes between a sequent $A,B\types C$ and a sequent $A\times B\types C$ (even though they are bijectively related), so it seems natural to work with a categorical structure that also distinguishes between morphisms $(A,B)\to C$ and $A\times B\to C$.
However, the correspondence and motivation goes deeper than that.
We may ask \emph{why} type theory distinguishes these two kinds of sequents?
We will discuss this in more detail in \cref{sec:why-multicats}, but the short answer is that ``it makes cut-elimination work''.
More specifically, it enables us to formulate type theory in such a way that \emph{each rule refers to at most one type former}, so that we can ``commute these rules past each other'' in the proof of cut-elimination.
Moreover, including sequents such as $A,B\types C$ allows us to describe certain operations in a type-theoretic style that would not otherwise be possible, such as a monoidal tensor product.
A type theorist speaks of this in terms of \emph{deciding on the judgmental structure first} (including ``structural rules'') and then defining the connectives to ``internalize'' various aspects of that structure.
From a categorical point of view, the move to (generalized) multicategories has the feature that \emph{it gives things universal properties}.
For instance, the tensor product in a monoidal category has no universal property, but the tensor product in a multicategory does.
In general, from a well-behaved 2-monad $T$ we can define a notion of ``$T$-multicategory''~\cite{burroni:t-cats,leinster:higher-opds,hermida:coh-univ,cs:multicats} in which $T$-algebra structure acquires a universal property (specifically, $T$ is replaced by a lax- or colax-idempotent 2-monad with the same algebras).
In type theoretic language, the move to $T$-multicategories corresponds to including the desired operations in the judgmental structure.
The fact that the $T$-operations then have universal properties is what enables us to write down the usual sort of type-theoretic left/right or introduction/elimination rules for them.
Making this correspondence explicit is helpful for many reasons.
Pedagogically, it can help the category theorist, who believes in universal properties, to understand why type theories are formulated the way they are.
It also makes the ``initiality theorems'' more modular: first we model the judgmental structure with a multicategory, and then we add more type formers corresponding to objects with various universal properties.
It can even be helpful from a purely type-theoretic perspective, suggesting more systematic ways to formulate cut admissibility theorems (see e.g.\ \cref{thm:monpos-cutadm,thm:natded-logic-multicutadm}). % [TODO: Also the polycategorical case]).
Finally, it provides a guide for new applications of categorical logic: when seeking a categorical structure to model a given type theory, we should look for a kind of multicategory corresponding to its judgments; while when seeking an internal logic for a categorical structure, we should represent it using universal properties in some kind of multicategory, from which we can extract an appropriate judgmental structure.
These facts about cut-elimination and multicategories have surely been known in some form to experts for a long time, but I am not aware of a clear presentation of them for the beginner coming from a category-theoretic background.
They are not strictly necessary if one wants simply to use type theory for internal reasoning about categories, and there are plenty of good introductions that take a geodesic route to that application.
However, I believe that they yield a deeper understanding of the type/category correspondence; and they are especially valuable when it comes to designing type theories that correspond to new categorical structures (or vice versa).
\section{Expectations of the reader}
\label{sec:expectations}
I will not assume that the reader has any acquaintance with type theory, or any interest in it apart from its uses for category theory.
However, because one of my goals is to help the reader become familiar with the lingo and concerns of type theorists, I will sometimes include a little more detail than is strictly necessary for categorical applications.
The reader should feel free to skip over these brief digressions.
It is possible that my zeal to explain all the aspects of type theory that can be puzzling to the category theorist has made this book a little more ``encyclopedic'' than would be ideal for a first introduction to the subject.
I hope that it will still be of use to the newcomer; but if you haven't had any prior exposure to type theory or categorical logic, you may want to supplement it with other readings as well.
Another reason for supplementing is that I have intentionally minimized the space devoted to category theory.
Of course, we are interested in type theory as a language for categories, and I have tried to include enough examples to illustrate its usefulness.
But our focus will be on type theories and how they correspond to categories, not on the categorical structures themselves.
For basic notions of category theory, see e.g.~\cite{maclane,awodey:cat-thy,mclarty:ecat-etop,leinster:cat-thy}.
To learn more about the multicategories that appear in \cref{chap:simple}, I recommend~\cite{leinster:higher-opds,cs:multicats}.
And for the indexed categories and ``logical'' types of categories appearing in \cref{chap:fol,chap:hol,chap:dtt} one can consult~\cite{mm:shv-gl,ptj:topos-theory,ptj:elephant,jacobs:cltt}.
I have endeavored to include a reasonable number of exercises of varying difficulty; these are placed at the end of most sections, and then compiled again for ease of reference at the end of each chapter.
As always, doing exercises is important (perhaps even essential) for coming to understand a subject.
But whether or not you plan to \emph{do} the exercises, I highly recommend at least \emph{reading} all the exercises as part of each section, and spending at least a few seconds thinking about how one might do them.
A number of ideas are introduced in exercises and then come back again later in the text.
% Local Variables:
% TeX-master: "catlog"
% End: