-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy path13.html
988 lines (897 loc) · 41.3 KB
/
13.html
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
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
<!doctype html>
<html lang="ja">
<head>
<meta charset="utf-8">
<title>圏論勉強会 第13回 @ ワークスアプリケーションズ</title>
<meta name="description" content="Seminar of category theory">
<meta name="author" content="Koichi Nakamura">
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="apple-mobile-web-app-status-bar-style" content="black-translucent" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
<link rel="stylesheet" href="css/reveal.css">
<link rel="stylesheet" href="css/theme/sky.css" id="theme">
<meta http-equiv="X-UA-Compatible" CONTENT="IE=EmulateIE7" />
<!-- For syntax highlighting -->
<link rel="stylesheet" href="plugin/highlight/styles/github.css">
<!-- If the query includes 'print-pdf', use the PDF print sheet -->
<script>
document.write( '<link rel="stylesheet" href="css/print/' + ( window.location.search.match( /print-pdf/gi ) ? 'pdf' : 'paper' ) + '.css" type="text/css" media="print">' );
</script>
<script type="text/javascript" async
src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-AMS_HTML">
</script>
<script type="text/x-mathjax-config">
MathJax.Hub.Config({
tex2jax: {
inlineMath: [ ['$','$'], ["\\(","\\)"] ],
displayMath: [ ['$$','$$'], ["\\[","\\]"] ]
}
});
</script>
<style type="text/css">
<!--
div.definition {
padding-top: 10px;
padding-bottom: 10px;
padding-left: 10px;
padding-right: 10px;
border: 4px solid #333333;
box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
}
div.theorem {
padding-top: 10px;
padding-bottom: 10px;
padding-left: 10px;
padding-right: 10px;
border: 4px solid #333333;
box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
}
div.block {
margin: 10px;
padding-top: 10px;
padding-bottom: 10px;
padding-left: 10px;
padding-right: 10px;
border: 2px solid #C0C0C0;
}
div.example {
margin: 10px;
padding-top: 10px;
padding-bottom: 10px;
padding-left: 10px;
padding-right: 10px;
border: 2px solid #C0C0C0;
}
-->
</style>
<!--[if lt IE 9]>
<script src="lib/js/html5shiv.js"></script>
<![endif]-->
</head>
<body>
<div class="reveal">
<!-- Any section element inside of this container is displayed as a slide -->
<div class="slides">
<section>
<h1>圏論勉強会<br>第13回</h1>
<h3>@ワークスアプリケーションズ</h3>
<small> 中村晃一 <br> 2013年8月8日</small>
</section>
<section>
<h3>謝辞</h3>
<p>
この勉強会の企画,会場設備の提供をして頂きました<br>
㈱ ワークスアプリケーションズ様<br>
にこの場をお借りして御礼申し上げます。
</p>
</section>
<section>
<h3> この会について </h3>
<ul>
<li> <span style="color:red">圏論(category theory)</span>を題材にいろんなことを学びます。</li>
<li> 分かり易さを重視して初歩的な例を多用します。</li>
<li> 関数型言語の経験がある方がより楽しめると思います。資料中では主にHaskellを使います。 </li>
<li> 中高生も数人見ているらしいのでプログラミングと関係が浅い内容も取り上げます。</li>
<li> この資料は<a href="http://nineties.github.com/category-seminar/">http://nineties.github.com/category-seminar</a>に置いてあります。</li>
</ul>
</section>
<section>
$$ \newcommand\append{{+\hspace{-.7em}+}} $$
</section>
<section>
<h2> 第13回 </h2>
<h3> 随伴・モナド </h3>
</section>
<section>
<h3> 第13回の内容 </h3>
<p>
前回にひき続いて随伴の説明をします。様々な圏論の概念は随伴として統一的に理解する事が可能です。
また、モナドという概念を圏論的な文脈でのそれと、表示的意味論への応用に関して説明します。
</p>
</section>
<section>
<h3> 随伴 </h3>
</section>
<section id="adjunction">
<h3> 随伴 </h3>
<div class="definition" style="font-size:90%">
<p>
圏$\mathbf{C},\mathbf{D}$と函手$F: C\leftrightarrows D: G$について,
任意の$X,Y$に関して自然な同型
$$ \phi: \mathrm{Hom}_{\mathbf{D}}(F(X), Y) \cong \mathrm{Hom}_{\mathbf{C}}(X, G(Y)) $$
が存在するならば$(F,G,\phi)$を<span style="color:red">随伴(adjunction)</span>と言う。また$F$を$G$の<span style="color:red">左随伴(left adjoint)</span>,$G$を$F$の<span style="color:red">右随伴(right adjoint)</span>と言い
$$ F\dashv G$$
と表す。
</p>
<div align="center"> <img width="50%" src="fig/adjunction.png"> </div>
</div>
<p style="font-size:80%">
注: $\phi$は$X,Y$のペア毎に存在するので注意して下さい。
</p>
</section>
<section>
<h3> 単位元と余単位元 </h3>
<div class="definition" style="font-size:90%">
<p>
随伴$(F,G,\phi)$に対して
$$ \eta_X = \phi(1_{F(X)})\qquad \epsilon_Y = \phi^{-1}(1_{G(Y)}) $$
により定まる自然変換$\eta: 1_{\mathbf{C}}\rightarrow G\circ F$及び,$\epsilon: F\circ G\rightarrow 1_{\mathbf{D}}$を随伴の<span style="color:red">単位元(unit)</span>、<span style="color:red">余単位元(counit)</span>という。
</p>
<img width="45%" src="fig/unit_of_adjunction.png">
<img width="45%" src="fig/counit_of_adjunction.png">
</div>
</section>
<section>
<p>
今の定義は随伴の<span style="color:red">Hom-set definition</span>と呼ばれる形の定義です。対称性がありとても綺麗な形をしています。
</p>
<p class="fragment">
しかし、この定義から直接これまでに学習してきた普遍性に基づく定義を導出するのは面倒ですので、随伴の同値な定義を紹介します。
</p>
</section>
<section>
<h3> Unit definition </h3>
<p style="font-size:90%">
函手$F: \mathbf{C}\leftrightarrows \mathbf{D}: G$が随伴$F\dashv G$をなす事は以下と同値。
</p>
<div class="definition" style="font-size:90%">
<p>
自然変換$\eta: 1_{\mathbf{C}}\rightarrow G\circ F$が存在して、任意の対象$X,Y$と射$f: X\rightarrow G(Y)$に対して
以下の図式が可換となるような射$\bar{f}: F(X)\rightarrow Y$が唯一つ存在する。
</p>
<div align="center"> <img width="50%" src="fig/unit_definition_of_adjunction.png"> </div>
</div>
</section>
<section style="font-size:80%">
<p>
【証明:Hom-set definition $\Rightarrow$ Unit definition]<br>
随伴$ \phi: \mathrm{Hom}_{\mathbf{D}}(F(X), Y) \cong \mathrm{Hom}_{\mathbf{C}}(X, G(Y)) $
に対して$\eta_X = \phi(1_{F(X)})$とおく。
</p>
<p>
$X$に関する自然性より任意の$g: X\rightarrow X'$に対して下図が可換である。
</p>
<div align="center"> <img width="60%" src="fig/adjunction_proof2.png"> </div>
<p>
すなわち,任意の$h: F(X')\rightarrow Y$について
$$ \phi(h)\circ g = \phi(h\circ F(g)) \qquad\cdots (1)$$
が成り立つ。
</p>
</section>
<section style="font-size:80%">
<p>
同様に$Y$に関する自然性より任意の$g: Y\rightarrow Y'$に対して下図が可換である。
</p>
<div align="center"> <img width="60%" src="fig/adjunction_proof1.png"> </div>
<p>
すなわち,任意の$h: F(X)\rightarrow Y$について
$$ \phi(g\circ h) = G(g)\circ\phi(h) \qquad\cdots (2)$$
が成立する。
</p>
</section>
<section style="font-size:80%">
<p>
まず、任意の$f: X\rightarrow Y$に対して
$$ \begin{aligned}
G(F(f))\circ \eta_X &= G(F(f))\circ \phi(1_{F(X)}) \\
&= \phi(F(f)\circ 1_{F(X)}) \qquad (\because (2)) \\
&= \phi(1_{F(Y)}\circ F(f)) \\
&= \phi(1_{F(Y)})\circ f \qquad (\because (1)) \\
&= \eta_Y\circ f \\
\end{aligned} $$
すなわち、下図が可換となるので$\eta_X$は自然変換$\eta : 1_{\mathbf{C}}\rightarrow G\circ F$を定める。
</p>
<div align="center"> <img width="40%" src="fig/adjunction_proof3.png"> </div>
</section>
<section style="font-size:80%">
<img align="right" width="40%" src="fig/adjunction_proof4.png">
<p>
続いて,任意の$f: X\rightarrow G(Y)$に対して
$$ f = G(\bar{f})\circ \eta_X $$
を満たす$\bar{f}: F(X)\rightarrow Y$は
$$ \begin{aligned}
f &= G(\bar{f})\circ \phi(1_{F(X)}) \\
&= \phi(\bar{f}\circ 1_{F(X)}) \qquad (\because (2)) \\
&= \phi(\bar{f}) \\
\end{aligned} $$
より$\phi$が全単射である事から$\bar{f} = \phi^{-1}(f)$と一意に定まる。
以上でHom-set definitionからUnit-definitionが得られた。
<span style="float:right">□</span>
</p>
</section>
<section style="font-size:80%">
<p>
【証明:Unit definition $\Rightarrow$ Hom-set definition】<br>
自然変換$\eta: 1_{\mathbf{C}}\rightarrow G\circ F$を用いて
$$ \phi(f) = G(f)\circ\eta_X \qquad (f: F(X)\rightarrow Y) \qquad\cdots(*)$$
と定める。$\eta$の普遍性より$\phi$は全単射
$$ \phi: \mathrm{Hom}_{\mathbf{D}}(F(X), Y)\cong\mathrm{Hom}_{\mathbf{C}}(X, G(Y)) $$
である。
</p>
</section>
<section style="font-size:80%">
<p>
次に,任意の$f: F(X')\rightarrow Y$と$g: X\rightarrow X'$に対して
$$ \begin{aligned}
\phi(f)\circ g &= G(f)\circ\eta_{X'}\circ g \\
&= G(f)\circ G(F(g))\circ\eta_X \qquad (\because \text{$\eta$は自然変換$1_{\mathbf{C}}\rightarrow G\circ F$}) \\
&= G(f\circ F(g))\circ \eta_X \\
&= \phi(f\circ F(g)) \\
\end{aligned} $$
が成り立つので下図が可換である。すなわち$(*)$は$X$に関して自然である。
</p>
<div align="center"> <img width="60%" src="fig/adjunction_proof2.png"> </div>
</section>
<section style="font-size:80%">
<p>
同様に,任意の$f: F(X)\rightarrow Y$と$g: X\rightarrow X'$に対して
$$ \begin{aligned}
G(g)\circ\phi(f) &= G(g)\circ G(f)\circ\eta_X \\
&= G(g\circ f)\circ\eta_X \\
&= \phi(g\circ f) \\
\end{aligned} $$
が成り立つので下図が可換である。すなわち$(*)$は$Y$に関して自然である。
</p>
<div align="center"> <img width="60%" src="fig/adjunction_proof1.png"> </div>
<p>
以上よりUnit definitionからHom-set definitionが得られた。
<span style="float:right">□</span>
</p>
</section>
<section>
<h3> Counit definition </h3>
<div style="font-size:90%">
<p>
函手$F: \mathbf{C}\leftrightarrows \mathbf{D}: G$が随伴$F\dashv G$をなす事は以下と同値。
</p>
<div class="definition">
<p>
自然変換$\epsilon: F\circ G\rightarrow 1_{\mathbf{D}}$が存在して、任意の対象$X,Y$と射$f: F(X)\rightarrow Y$に対して
以下の図式が可換となるような射$\tilde{f}: X\rightarrow G(Y)$が唯一つ存在する。
</p>
<div align="center"> <img width="50%" src="fig/counit_definition_of_adjunction.png"> </div>
</div>
<p>これは双対性により得られます。</p>
</div>
</section>
<section>
<h3> 様々な随伴の例 </h3>
</section>
<section>
<h3> 対角函手の右随伴 </h3>
<p>
$ \Delta(X) = (X,X) $で定義される対角函手$\Delta: \mathbf{C}\rightarrow \mathbf{C}\times\mathbf{C}$が右随伴$P$
を持つ条件は何であるのかを調べます。
</p>
</section>
<section>
<p style="font-size:80%">
自然変換$\epsilon: \Delta\circ P \rightarrow 1_{\mathbf{C}\times\mathbf{C}}$の$X$成分($\mathbf{C}\times\mathbf{C}$の射)を
$$ \epsilon_X = (\pi_1, \pi_2) $$
と簡単に表すことにすると,任意の$(f,g): (X,X)\rightarrow (A,B)$に対して
$$ (\pi_1,\pi_2)\circ(u,u) = (f,g) \ \Leftrightarrow \pi_1\circ u = f, \pi_2\circ u = g $$
を満たす$u: X\rightarrow P(A,B)$が唯一つ存在する事が$P(A,B)$の条件です。これは$\epsilon_X$が射影であり,
$$ P(A,B)\cong A\times B $$
であるという事に他なりません。
</p>
<div align="center"> <img width="90%" src="fig/product_functor_counit.png"> </div>
</section>
<section>
<p>
つまり,対角函手$\Delta(X):\mathbf{C}\rightarrow\mathbf{C}\times\mathbf{C}$が右随伴を持つのは,$\mathbf{C}$が任意の二対象の積を持つ時であり
$$ \Delta \dashv \times $$
となります。
</p>
</section>
<section>
<p>
同様にして対角函手$\Delta$が左随伴を持つのは,$\mathbf{C}$が任意の二対象の余積を持つ時であり
$$ + \dashv \Delta $$
となります。まとめると,
$$ + \dashv \Delta \dashv \times $$
という関係があります。
</p>
</section>
<section>
<h3> 一般の対角函手 </h3>
<p>
インデックス圏$\mathbf{J}$に対して対角函手
$$ \Delta_{\mathbf{J}}: \mathbf{C} \rightarrow \mathbf{C}^{\mathbf{J}} $$
は
$$ \Delta_{\mathbf{J}}(X)(A) = X,\ \Delta_{\mathbf{J}}(X)(f) = 1_X $$
によって定義されます。$\mathbf{J}$を二点集合$\mathbf{2}$と置いたのが、先ほどの例です。
$$ \mathbf{C}^{\mathbf{2}}\cong \mathbf{C}\times\mathbf{C} $$
だった事に注意しましょう。
</p>
</section>
<section>
<h3> 対角函手の左右随伴 </h3>
<div class="theorem">
<p>
インデックス圏$\mathbf{J}$に対して$\Delta_{\mathbf{J}}$が左随伴・右随伴を持つならば
$$ \lim_{\stackrel{\longrightarrow}{\mathbf{J}}} \dashv \Delta_{\mathbf{J}} \dashv \lim_{\stackrel{\longleftarrow}{\mathbf{J}}} $$
が成立する。
</p>
</div>
<div style="font-size:80%">
<p>
例えば$\mathbf{J}$を以下の様な平行射からなる圏とすると,
</p>
<div align="center"> <img width="15%" src="fig/parallel_arrow.png"> </div>
<p>
任意の函手$D: \mathbf{J}\rightarrow\mathbf{C}$に対して
$$ \lim_{\stackrel{\longleftarrow}{\mathbf{J}}}D, \lim_{\stackrel{\longrightarrow}{\mathbf{J}}}D $$
がイコライザ及びコイコライザとなるという事をやりましたが(第7回),これらを随伴のCounit/Unit definitionから導出してみましょう。
</p>
</div>
</section>
<section>
<h3> 指数対象 </h3>
<div style="font-size:80%">
<p>
続いて,函手$F(X) = X\times A$の右随伴$G$が存在する条件をCounit definitionを用いて書きだしてみると,
</p>
<img align="right" width="40%" src="fig/adjunction_exponential.png">
<p>
$\epsilon_Y: G(Y)\times A\rightarrow Y$が存在して,任意の$f: X\times A\rightarrow Y$に対して
$$ \epsilon_Y\circ(\tilde{f}\times 1_A) = f $$
を満たす$\tilde{f}: X\rightarrow G(Y)$が唯一つ存在する。
</p>
<p>
となります。これは$\epsilon_Y$が評価射であり
$$ G(Y) \cong Y^A $$
であるという事に他なりません。
</p>
<p>
つまり
$$ (-)\times A \dashv (-)^A $$
という関係があります。
</p>
</div>
</section>
<section>
<h3> 自由モノイドの構成 </h3>
<div style="font-size:80%">
<p>
忘却函手$|-|: \mathbf{Mon}\rightarrow\mathbf{Sets}$の左随伴$F$が存在する条件をUnit definitionを用いて書きだしてみると,
</p>
<img align="right" width="50%" src="fig/free_construction_functor.png">
<p>
$\eta_X: X\rightarrow |F(X)|$が存在して,任意の$f: X\rightarrow |Y|$に対して
$$ |\bar{f}|\circ\eta_X = f $$
を満たす$\bar{f}: F(X)\rightarrow Y$が唯一つ存在する。
</p>
<p>
となります。これは$F(X)$が自由モノイドである事に他なりません(第3回)。
</p>
<p>
また$\eta_X(a) = [a]$となります。
</p>
</div>
</section>
<section>
<h3> 自由モノイドの構成の余単位元 </h3>
<div style="font-size:80%">
<p>
余単位元は下図を可換にする$\epsilon_Y$です。
ここで$F(f)$は
$$F(f)([a_1,\cdots,a_n]) = [f(a_1),\cdots,f(a_n)] $$
という列から列への準同型であり,これに$\epsilon_Y$を適用したのが$[a_1,\cdots,a_n]$を$\tilde{f}$で畳み込んだものと一致するので,
$$ \epsilon_Y([b_1,\cdots,b_n]) = b_1\circ \cdots \circ b_n $$
となります。($\circ$は$Y$のモノイド演算)
</p>
</div>
<div align="center"><img width="100%" src="fig/free_construction_functor2.png"></div>
</section>
<section>
<h3> 随伴に関する定理 </h3>
</section>
<section>
<h3> 随伴は存在するなら一意 </h3>
<div class="theorem">
<p>
$F$に右随伴が存在するならば,それは同型を除いて一意である。すなわち
$$ F\dashv G,\ F\dashv H$$
ならば$G \cong H$である。左随伴に関しても同様。
</p>
</div>
<p style="font-size:70%">
【証明】<br>
任意の$X,Y$に対して
$$ \mathrm{Hom}_{\mathbf{C}}(X, G(Y)) \cong \mathrm{Hom}_{\mathbf{D}}(F(X), Y)\cong\mathrm{Hom}_{\mathbf{C}}(X, H(Y)) $$
は$X$に関して自然なので米田の補題より
$$ G(Y) \cong H(Y) $$
となる。さらにこれは$Y$に関して自然なので
$$ G \cong H $$
である。
<span style="float:right">□</span>
</p>
</section>
<section>
<h3> 随伴と連続性 </h3>
<div class="theorem">
<p>
$$ F\dashv G \qquad (F:\mathbf{C}\leftrightarrows\mathbf{D}:G)$$
の時$F$は余連続,$G$は連続。
</p>
</div>
<p style="font-size:70%">
函手$D:\mathbf{J}\rightarrow\mathbf{C}$の余極限が存在すると仮定すると,任意の$Y$に関して自然同型
$$\begin{aligned}
\mathrm{Hom}_{\mathbf{D}}(F(\lim_{\rightarrow}D_i), Y) &\cong \mathrm{Hom}_{\mathbf{C}}(\lim_{\rightarrow}D_i, G(Y)) \quad(\because\text{随伴})\\
&\cong \lim_{\rightarrow}\mathrm{Hom}_{\mathbf{C}}(D_i, G(Y)) \quad(\because \text{反変Hom函手は余連続})\\
&\cong \lim_{\rightarrow}\mathrm{Hom}_{\mathbf{D}}(F(D_i), Y) \quad(\because\text{随伴})\\
&\cong \mathrm{Hom}_{\mathbf{D}}(\lim_{\rightarrow}F(D_i), Y) \quad(\because\text{反変Hom函手は余連続})\\
\end{aligned} $$
が存在する。依って米田の補題より
$$ F(\lim_{\rightarrow}D_i) \cong \lim_{\rightarrow}F(D_i) $$
が成り立つので$F$は余連続である。$G$の連続性は双対性より示される。
<span style="float:right">□</span>
</p>
</section>
<section>
<h3> 随伴の連続性の例 </h3>
<p style="font-size:80%">
デカルト閉圏$\mathbf{C}$が任意の有限余積を持つとします。
$$(-)\times A\dashv (-)^A$$
だったので今の定理より
$$ \begin{aligned}
& 1^A \cong 1 \\
& (B\times C)^A \cong B^A\times C^A \\
& 0\times A \cong 0 \\
& (B+C)\times A \cong B\times A + C\times A
\end{aligned} $$
などが直ちに得られます。特に3,4番目の性質が成り立つので<span style="color:red">任意の有限余積を持つデカルト閉圏は分配的</span>(第11回)である事が判ります。
</p>
</section>
<section>
<p>
以上で随伴については終了としますが,他にも興味深い様々な随伴の例や定理が存在します。
テキストの第9章を是非読んでみて下さい。
</p>
</section>
<section>
<h3> モナド </h3>
</section>
<section>
<p>
まず,純粋に圏論的な意味でのモナドを説明します。その後、理論計算機科学での応用について説明します。
</p>
</section>
<section>
<h3> モナド </h3>
<div class="definition">
<p>
圏$\mathbf{C}$における<span style="color:red">モナド(monad)</span>とは,自己函手$T:\mathbf{C}\rightarrow\mathbf{C}$と自然変換
$$ \eta: 1_{\mathbf{C}}\rightarrow T,\ \mu: T^2\rightarrow T $$
からなり等式
$$ \begin{aligned}
& \mu\circ\mu_T = \mu\circ T(\mu) \\
& \mu\circ\eta_T = \mu\circ T(\eta) = 1_T \\
\end{aligned} $$
が成り立つものである。$\eta$をモナドの単位元,$\mu$をモナドの積などと呼ぶ。
</p>
</div>
<p style="font-size:70%">
注:$ T^2 = T\circ T$
</p>
</section>
<section>
<p>
今の定義における等式は以下の可換図式で表されます。
</p>
<div align="center"> <img width="70%" src="fig/monad_diagram.png"> </div>
<p>
成分毎に書き表すと任意の$X$に対して
$$\begin{aligned}
& \mu_X \circ T(\mu_X) = \mu_X \circ \mu_{T(X)} \\
& \mu_X \circ \eta_{T(X)} = \mu_X\circ T(\eta_X) = 1_{T(X)}\\
\end{aligned} $$
が成り立つという意味です。
</p>
</section>
<section>
<h3> モナドの例:リストモナド </h3>
<div style="font-size:80%">
<p>
簡単の為に$\mathbf{Sets}$で考えます。
</p>
<p>
函手$T: \mathbf{Sets}\rightarrow\mathbf{Sets}$を
$$ T(A) = \text{($A$の要素からなる有限列の集合)} $$
と定義します。$T(f)$は列の要素毎に$f$を適用する関数にします。
</p>
<p>
さらに,自然変換を
$$ \begin{aligned}
&\eta_X(a) = [a] \\
&\mu_X([a_1,\cdots,a_n]) = a_1\append\cdots\append a_n\\
\end{aligned} $$
と定義すると$(T,\eta,\mu)$はモナドとなります。
</p>
</div>
</section>
<section>
<div style="font-size:80%">
<p>
$\eta,\mu$が自然変換である事の証明は省略し,等式の証明のみを行います。
</p>
<p>
【一つ目の等式】<br>
$$\begin{aligned}
&\mu_X\circ T(\mu_X)([[a_1,\cdots,a_m],\cdots,[x_1,\cdots,x_n]]) \\
= &\mu_X([a_1\append\cdots\append a_m,\cdots,x_1\append\cdots\append x_n]) \\
= &a_1\append\cdots\append a_m\append\cdots\append x_1\append\cdots\append x_n \\
&\mu_X\circ \mu_{T(X)}([[a_1,\cdots,a_m],\cdots,[x_1,\cdots,x_n]]) \\
= &\mu_X([a_1,\cdots,a_m,\cdots,x_1,\cdots,x_n]) \\
= &a_1\append\cdots\append a_m\append\cdots\append x_1\append\cdots\append x_n \\
\end{aligned} $$
より
$$ \mu_X\circ T(\mu_X) = \mu_X\circ \mu_{T(X)} $$
</div>
</section>
<section>
<div style="font-size:80%">
<p>
【二つ目の等式】<br>
$$\begin{aligned}
&\mu_X\circ\eta_{T(X)}([a_1,\cdots,a_n]) \\
= &\mu_X([[a_1,\cdots,a_n]]) \\
= &[a_1,\cdots,a_n] \\
&\mu_X\circ T(\eta_X)([a_1,\cdots,a_n]) \\
= &\mu_X([[a_1],\cdots,[a_n]]) \\
= &[a_1,\cdots,a_n] \\
\end{aligned} $$
より
$$ \mu_X\circ\eta_{T(X)} = \mu_X\circ T(\eta_X) = 1_{T(X)} $$
</p>
</div>
</section>
<section>
<h3> 随伴とモナドの関係 </h3>
<div class="theorem">
<p>
随伴$F\dashv G$の単位元・余単位元を$\eta,\epsilon$とすると
</p>
<ul>
<li> 自己函手$T = G\circ F: \mathbf{C}\rightarrow\mathbf{C}$ </li>
<li> 自然変換$\eta: 1_{\mathbf{C}}\rightarrow T$ </li>
<li> 自然変換$G(\epsilon_F): T^2 \rightarrow T$ </li>
</ul>
<p>
はモナドである。
</p>
</div>
</section>
<section style="font-size:80%">
<p>
【証明:一つ目の等式】<br>
<img align="right" width="30%" src="fig/monad_proof1.png">
$\epsilon$は自然変換$\epsilon: F\circ G\rightarrow 1_{\mathbf{D}}$なので,任意の$X,Y$に関して
右の図式が可換。
</p>
<p>
従って$X$に$F\circ G\circ F(X)$,$Y$に$F(X)$,$f$に$\epsilon_{F(X)}$を代入して図式全体を$G$で移すと以下の可換図式
が得られる。
</p>
<div align="center"> <img width="60%" src="fig/monad_proof2.png"> </div>
<p>
よって$T=G\circ F$,$\mu_X = G(\epsilon_{F(X)})$より
$$\mu_X \circ T(\mu_X) = \mu_X \circ \mu_{T(X)}$$
である。
<span style="float:right">□</span>
</p>
</section>
<section style="font-size:80%">
<p>
【証明:二つ目の等式】<br>
任意の$f: F(X)\rightarrow Y$に対して
$$ \phi(f) = G(f)\circ\eta_X $$
だったので,$\epsilon_{F(X)}: F\circ G\circ F(X)\rightarrow F(X)$を代入して
$$ \phi(\epsilon_{F(X)}) = G(\epsilon_{F(X)})\circ\eta_{G(F(X))} $$
である。ここで$\epsilon_{F(X)} = \phi^{-1}(1_{G(F(X))})$であったから
$$ 1_{G(F(X))} = G(\epsilon_{F(X)})\circ \eta_{G(F(X))} $$
つまり
$$ 1_{T(X)} = \mu_X \circ \eta_{T(X)} $$
である。
</p>
</section>
<section style="font-size:80%">
<p>
また任意の$f: X\rightarrow G(Y)$に対して
$$\phi^{-1}(f) = \epsilon_Y\circ F(f)$$
だったので,$f = \eta_X$とすると
$$\phi^{-1}(\eta_X) = \epsilon_{F(X)}\circ F(\eta_X) $$
すなわち$\eta_X = \phi(1_{F(X)})$より
$$ 1_{F(X)} = \epsilon_{F(X)}\circ F(\eta_X) $$
が成り立つ。この両辺に$G$を適用して
$$ 1_{G(F(X))} = G(\epsilon_{F(X)})\circ G(F(\eta_X)) $$
が成り立つ。すなわち
$$ 1_{T(X)} = \mu_X\circ T(\eta_X) $$
である。
<span style="float:right">□</span>
</p>
</section>
<section>
<h3> 随伴からリストモナドを導出する例 </h3>
<p style="font-size:80%">
自由モノイドの構成と忘却函手の随伴
$$ F \dashv |-| $$
からモナドを導出すると,先ほどのリストモナドが得られます。
まず任意の集合$A$に対して$F(A)$が自由モノイド,$|F(A)|$がその台集合なので
$$ T(A) = |F(A)| = \text{($A$の要素からなる有限列の集合)} $$
となります。また,$ \eta_X(a) = [a] $でであり,
$$ \epsilon_Y([a_1,\cdots,a_n]) = a_1\circ\cdots\circ a_n $$
だったので,$\epsilon_{F(X)}$は
$$ \epsilon_{F(X)}([a_1,\cdots,a_n]) = a_1\append\cdots\append a_n$$
になります。($F(X)$は自由モノイドなのでその演算は連結捜査)
従って,
$$ \mu_X = |\epsilon_{F(X)}|([a_1,\cdots,a_n]) = a_1\append\cdots\append a_n$$
となります。
</p>
</section>
<section>
<h3> 練習問題 </h3>
<p>
随伴
$$ (-)\times S \dashv (-)^S $$
からモナドを導出して下さい。
</p>
</section>
<section>
<p>
逆に,圏$\mathbf{C}$上のモナド$(T,\eta,\mu)$が与えられると$\mathbf{C}$と
Eilenberg-Moore圏と呼ばれる圏の間に随伴を構成する事が出来ます。<br>
時間がないので解説は省略しまが,テキストの10.3節に説明があります。$F$代数の圏を理解していれば読めるはずです。
</p>
<p>
随伴とモナドが一対一に対応するという訳ではないので注意して下さい。
</p>
</section>
<section>
<h3> モノイド対象 </h3>
</section>
<section>
<h3> モノイド </h3>
<p style="font-size:90%">
モノイドとは集合・二項演算・単位元の組$(M,\circ,e)$であって<br>
任意の$x,y,z$に対して
$$ (x\circ y)\circ z = x\circ (y\circ z) $$
任意の$x$に対して
$$ e\circ x = x\circ e = x$$
が成り立つ物でした。これは$\mathbf{Sets}$における以下の可換図式で表現する事が出来ます。
見やすさの為$\circ = \mu$と置き直しています。
</p>
<div align="center"> <img width="100%" src="fig/monoid_object.png"> </div>
</section>
<section>
<h3> モノイダル圏 </h3>
<p style="font-size:90%">
今の議論では$\mathbf{Sets}$の積$\times$,$\times$が結合的である事,$1$が$\times$の単位であること
を使い,その上でモノイドの等式を図式としてあらわしました。
</p>
<p style="font-size:90%">
これと同じ特徴を持つ圏を<span style="color:red">モノイダル圏(monoidal category)</span>と言います。
</p>
<div class="definition">
<p>
圏$\mathbf{C}$がモノイダル圏であるとは,函手$\otimes:\mathbf{C}\times\mathbf{C}\rightarrow\mathbf{C}$が存在し,
任意の対象$X,Y,Z$に対して
$$ (X\otimes Y)\otimes Z \cong X\otimes (Y\otimes Z) $$
が成り立ち,また対象$I$が存在して
$$ I\otimes X \cong X \cong X\otimes I$$
が成り立つ事である。<small>(厳密にはコヒーレンス条件というものが加わる)</small>
</p>
</div>
</section>
<section>
<h3> モノイド対象 </h3>
<div class="definition">
<p>
モノイダル圏$(\mathbf{C},\otimes,I)$におけるモノイド対象とは対象$M$,射$\mu: M\otimes M\rightarrow M, e:I\rightarrow M$からなり,以下の図式が可換であるものである。
</p>
<div align="center"> <img width="100%" src="fig/monoid_object2.png"> </div>
</div>
</section>
<section>
<h3> モナドは自己函手の圏のモノイド対象 </h3>
<p>
圏$\mathbf{C}$を固定して
</p>
<ul>
<li> 対象: $\mathbf{C}$から$\mathbf{C}$への自己函手 </li>
<li> 射: 自然変換 </li>
</ul>
<p>
とすると$\mathbf{C}$上の自己函手の圏が出来ます。この圏は$I = 1_{\mathbf{C}}$,$F\otimes G = F\circ G$とするとモノイダル圏になっています(練習問題)。
すると,$(T,\eta,\mu)$がモナドであるということはこれがこのモノイダル圏におけるモノイド対象であるという事と一致します。
</p>
</section>
<section>
<h3> 理論計算機科学におけるモナド </h3>
</section>
<section>
<p>
表示的意味論の分野でモナドを利用する事が1989年にEugenio Moggiによって提案されました。
</p>
<p>
表示的意味論とはプログラムに部分関数などの数学的対象を割り当てる事を手法とする意味論でした。Moggiの提案はプログラムの表示(正確にはComputational effectと呼ばれる物の表示)にモナドを利用しようというものです。
</p>
<ul>
<li> <a href="http://www.disi.unige.it/person/MoggiE/ftp/ic91.pdf"> Eugenio Moggi "Notion of computation and monads" </a>
</li>
</ul>
</section>
<section>
<h3> Computational effect </h3>
<div style="font-size:90%">
<p>
単純な計算というのは「$A$型の入力に対して$B$型の出力を行うもの」と考える事ができます。
</p>
<div align="center"> <img width="40%" src="fig/simple_computation.png"> </div>
<p>
しかし、実際の計算には以下の様な作用が加わります。これらを<span style="color:red">計算作用(Computational effect)</span>と呼ぶことにします。
</p>
<ul>
<li> 値を返さない場合がある(partiality) </li>
<li> 複数の計算結果がある(nondeterminism) </li>
<li> 副作用(状態の更新)がある(side-effects) </li>
<li> エラーが発生する(exception) </li>
<li> 継続を返す(continuations) </li>
</ul>
</div>
</section>
<section>
<h3> Computational effectを自己函手で表す。 </h3>
<p>
Moggiのアイデアでは,$\mathbf{C}$を型の圏とした場合,計算作用を自己函手$T:\mathbf{C}\rightarrow\mathbf{C}$によって表現します。
</p>
<div align="center"> <img width="40%" src="fig/computational_effect.png"> </div>
<p>
「計算作用」の表示が$T$であり,「計算」の表示が射
$$ f: A\rightarrow T(B) $$
という事になります。この射は<span style="color:red">クライスリ射(Kleisli arrow)</span>と呼ばれます。
</p>
</section>
<section>
<h3> $T$の例 </h3>
<ul>
<li> partiality: $T(B) = B + 1$ </li>
<li> nondeterminism: $T(B) = \mathcal{P}_{\text{fin}}(B)$<br>
$\mathcal{P}_{\text{fin}}(B)$は$B$の有限部分集合の集合 </li>
<li> side-effects: $T(B) = (S\times B)^S $ </li>
<li> exception: $T(B) = B + E$ </li>
<li> continuations: $T(B) = R^{R^B}\qquad(\text{$R$は戻り値の型})$
</ul>
</section>
<section>
<h3> 計算の合成 </h3>
<p>
計算$f: A\rightarrow T(B)$と$g: B\rightarrow T(C)$を単純に合成すると,計算作用が2回発生する為,出力が$T^2(C)$という型になってしまいます。
</p>
<div align="center"> <img width="60%" src="fig/computational_effect3.png"> </div>
<p>
例えば,$T$が副作用を表しているならば$T^2$は「副作用が2度発生する」という計算作用を表します。
</p>
</section>
<section>
<h3> 計算作用は畳み込める </h3>
<p>
私達は「副作用のある計算」をいくつ合成しても、単に「副作用のある計算」と認識する事が多いと思います。この考え方の背後には計算作用の畳み込み
$$ \mu_X: T^2(X) \rightarrow T(X) $$
が存在しています。この畳込みは下図の$A,B,C$の型に依存していない操作と考えられるので、自然変換$\mu: T^2 \rightarrow T$で表す事にします。
</p>
<div align="center"> <img width="60%" src="fig/computational_effect4.png"> </div>
</section>
<section>
<h3> 「何もしない」計算 </h3>
<p>
また「何もしない」という計算を表現出来る必要もあります。これは自然変換
$$ \eta: 1_{\mathbf{C}}\rightarrow T $$
で表す事にします。
</p>
<div align="center"> <img width="40%" src="fig/computational_effect2.png"> </div>
</section>
<section>
<h3> 計算作用の畳み込みは結合的 </h3>
<p>
計算の合成は結合的な操作だと考えられますので,計算作用$T$の畳み込みも結合的だと言えそうです。これがモナドの一つ目の等式
$$\mu_X \circ T(\mu_X) = \mu_X \circ \mu_{T(X)}$$
です。
</p>
<div align="center"> <img width="30%" src="fig/computational_effect5.png"> </div>
</section>
<section>
<h3> 「何もしない」計算は単位的 </h3>
<p>
$\eta_X$は「何もしない」計算なので,計算作用の畳み込みに関して単位元として振る舞うはずです。これがモナドの二つ目の等式
$$ \mu_X \circ \eta_{T(X)} = \mu_X\circ T(\eta_X) = 1_{T(X)}$$
です。
</p>
<div align="center"> <img width="50%" src="fig/computational_effect6.png"> </div>
</section>
<section>
<h3> まとめ </h3>
<p>
計算作用は型の圏の上のモナド$(T,\eta,\mu)$で表します。
</p>
<ul>
<li> $\eta$は何もしないという作用 </li>
<li> $\mu$は積み重なった作用の畳み込み </li>
</ul>
<p>
計算はクライスリ射$f: A\rightarrow T(B)$で表し,射$f:A\rightarrow T(B)$と$g: B\rightarrow T(C)$の合成は
$$ g\circ_K f = \mu_C\circ T(g)\circ f $$
によって行う。
</p>
</section>
<section>
<h3> どう役に立つのか? </h3>
<p>
計算の数学的な表示を与えるという事は、プログラムの数学的な解析が可能になります。これは「計算とは何か?」事に関する理解を深めてくれますし,
プログラム検証やプログラム最適化など具体的な応用の可能性も拓きます。さらに、計算と論理は密接に関わっていますから理論計算機科学分野以外への貢献も考えられます。
</p>
<p>
また、Haskellにおいてはdo記法というものがありますがこれもモナドによる抽象化の上に成り立っていますし、プログラムのデザインに関する考え方にも影響を与えている(はず)と考えられます。
</p>
</section>
<section>
<h3> 以上で圏論勉強会を終わります。 </h3>
<p>
全13回、お付き合い頂きありがとうございました。<br>
圏論の入門程度の内容しか出来ませんでしたが、大体どのような学問なのか理解して頂けたと思います。今後は是非Awodey本や「圏論の基礎」などの書籍を読んで、演習問題に取り組んで見て下さい。また学んだ知識を活かして、理論計算機科学の論文(勉強会中に紹介した論文など)を読んでみると良いと思います。
</p>
</section>
</div>
</div>
<script src="lib/js/head.min.js"></script>
<script src="js/reveal.min.js"></script>
<script>
// Full list of configuration options available here:
// https://github.com/hakimel/reveal.js#configuration
Reveal.initialize({
controls: false,
progress: true,
history: true,
center: true,
rollingLinks: false,
theme: Reveal.getQueryHash().theme, // available themes are in /css/theme
transition: Reveal.getQueryHash().transition || 'none', // default/cube/page/concave/zoom/linear/fade/none
// Optional libraries used to extend on reveal.js
dependencies: [
{ src: 'lib/js/classList.js', condition: function() { return !document.body.classList; } },
{ src: 'plugin/markdown/showdown.js', condition: function() { return !!document.querySelector( '[data-markdown]' ); } },
{ src: 'plugin/markdown/markdown.js', condition: function() { return !!document.querySelector( '[data-markdown]' ); } },
{ src: 'plugin/highlight/highlight.js', async: true, callback: function() { hljs.initHighlightingOnLoad(); } },
{ src: 'plugin/zoom-js/zoom.js', async: true, condition: function() { return !!document.body.classList; } },
{ src: 'plugin/notes/notes.js', async: true, condition: function() { return !!document.body.classList; } }
// { src: 'plugin/search/search.js', async: true, condition: function() { return !!document.body.classList; } }
// { src: 'plugin/remotes/remotes.js', async: true, condition: function() { return !!document.body.classList; } }
]
});
Reveal.addEventListener( 'slidechanged', function( event ) {
MathJax.Hub.Rerender(event.currentSlide);
});
</script>
</body>
</html>