annotate src/CCC.agda @ 1110:45de2b31bf02

add original library and fix for safe mode
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 07 Oct 2023 19:43:31 +0900
parents 321f0fef54c2
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1110
45de2b31bf02 add original library and fix for safe mode
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1097
diff changeset
1 {-# OPTIONS --cubical-compatible --safe #-}
45de2b31bf02 add original library and fix for safe mode
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1097
diff changeset
2
779
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 open import Level
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
4 open import Category
779
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 module CCC where
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
7
779
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 open import HomReasoning
1110
45de2b31bf02 add original library and fix for safe mode
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1097
diff changeset
9 open import Definitions
780
b44c1c6ce646 CCC in Hom form
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 779
diff changeset
10 open import Relation.Binary.PropositionalEquality
779
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
12
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
13 open import HomReasoning
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
14
784
f27d966939f8 add CCC hom
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 783
diff changeset
15 record IsCCC {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ)
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
16 ( 1 : Obj A )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
17 ( ○ : (a : Obj A ) → Hom A a 1 )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
18 ( _∧_ : Obj A → Obj A → Obj A )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
19 ( <_,_> : {a b c : Obj A } → Hom A c a → Hom A c b → Hom A c (a ∧ b) )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
20 ( π : {a b : Obj A } → Hom A (a ∧ b) a )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
21 ( π' : {a b : Obj A } → Hom A (a ∧ b) b )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
22 ( _<=_ : (a b : Obj A ) → Obj A )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
23 ( _* : {a b c : Obj A } → Hom A (a ∧ b) c → Hom A a (c <= b) )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
24 ( ε : {a b : Obj A } → Hom A ((a <= b ) ∧ b) a )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
25 : Set ( c₁ ⊔ c₂ ⊔ ℓ ) where
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
26 field
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
27 -- cartesian
793
f37f11e1b871 Hom a,b = Hom 1 b^a
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 789
diff changeset
28 e2 : {a : Obj A} → ∀ { f : Hom A a 1 } → A [ f ≈ ○ a ]
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
29 e3a : {a b c : Obj A} → { f : Hom A c a }{ g : Hom A c b } → A [ A [ π o < f , g > ] ≈ f ]
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
30 e3b : {a b c : Obj A} → { f : Hom A c a }{ g : Hom A c b } → A [ A [ π' o < f , g > ] ≈ g ]
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
31 e3c : {a b c : Obj A} → { h : Hom A c (a ∧ b) } → A [ < A [ π o h ] , A [ π' o h ] > ≈ h ]
785
a67959bcd44b ccc → hom on going
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 784
diff changeset
32 π-cong : {a b c : Obj A} → { f f' : Hom A c a }{ g g' : Hom A c b } → A [ f ≈ f' ] → A [ g ≈ g' ] → A [ < f , g > ≈ < f' , g' > ]
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
33 -- closed
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
34 e4a : {a b c : Obj A} → { h : Hom A (c ∧ b) a } → A [ A [ ε o < A [ (h *) o π ] , π' > ] ≈ h ]
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
35 e4b : {a b c : Obj A} → { k : Hom A c (a <= b ) } → A [ ( A [ ε o < A [ k o π ] , π' > ] ) * ≈ k ]
787
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 785
diff changeset
36 *-cong : {a b c : Obj A} → { f f' : Hom A (a ∧ b) c } → A [ f ≈ f' ] → A [ f * ≈ f' * ]
967
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
37 open ≈-Reasoning A
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
38 e'2 : ○ 1 ≈ id1 A 1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
39 e'2 = begin
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
40 ○ 1
793
f37f11e1b871 Hom a,b = Hom 1 b^a
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 789
diff changeset
41 ≈↑⟨ e2 ⟩
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
42 id1 A 1
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
43
967
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
44 e''2 : {a b : Obj A} {f : Hom A a b } → ( ○ b o f ) ≈ ○ a
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
45 e''2 {a} {b} {f} = begin
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
46 ○ b o f
793
f37f11e1b871 Hom a,b = Hom 1 b^a
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 789
diff changeset
47 ≈⟨ e2 ⟩
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
48 ○ a
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
49
967
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
50 π-id : {a b : Obj A} → < π , π' > ≈ id1 A (a ∧ b )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
51 π-id {a} {b} = begin
789
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
52 < π , π' >
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
53 ≈↑⟨ π-cong idR idR ⟩
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
54 < π o id1 A (a ∧ b) , π' o id1 A (a ∧ b) >
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
55 ≈⟨ e3c ⟩
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
56 id1 A (a ∧ b )
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
57
967
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
58 distr-π : {a b c d : Obj A} {f : Hom A c a }{g : Hom A c b } {h : Hom A d c } → ( < f , g > o h ) ≈ < ( f o h ) , ( g o h ) >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
59 distr-π {a} {b} {c} {d} {f} {g} {h} = begin
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
60 < f , g > o h
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
61 ≈↑⟨ e3c ⟩
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
62 < π o < f , g > o h , π' o < f , g > o h >
785
a67959bcd44b ccc → hom on going
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 784
diff changeset
63 ≈⟨ π-cong assoc assoc ⟩
a67959bcd44b ccc → hom on going
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 784
diff changeset
64 < ( π o < f , g > ) o h , (π' o < f , g > ) o h >
a67959bcd44b ccc → hom on going
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 784
diff changeset
65 ≈⟨ π-cong (car e3a ) (car e3b) ⟩
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
66 < f o h , g o h >
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
67
794
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
68 _×_ : { a b c d : Obj A } ( f : Hom A a c ) (g : Hom A b d ) → Hom A (a ∧ b) ( c ∧ d )
967
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
69 f × g = < ( f o π ) , (g o π' ) >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
70 π-exchg : {a b c : Obj A} {f : Hom A c a }{g : Hom A c b } → < π' , π > o < f , g > ≈ < g , f >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
71 π-exchg {a} {b} {c} {f} {g} = begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
72 < π' , π > o < f , g >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
73 ≈⟨ distr-π ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
74 < π' o < f , g > , π o < f , g > >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
75 ≈⟨ π-cong e3b e3a ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
76 < g , f >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
77
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
78 π'π : {a b : Obj A} → < π' , π > o < π' , π > ≈ id1 A (a ∧ b)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
79 π'π = trans-hom π-exchg π-id
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
80 exchg-π : {a b c d : Obj A} {f : Hom A c a }{g : Hom A d b } → < f o π , g o π' > o < π' , π > ≈ < f o π' , g o π >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
81 exchg-π {a} {b} {c} {d} {f} {g} = begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
82 < f o π , g o π' > o < π' , π >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
83 ≈⟨ distr-π ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
84 < (f o π) o < π' , π > , (g o π' ) o < π' , π > >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
85 ≈↑⟨ π-cong assoc assoc ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
86 < f o (π o < π' , π > ) , g o (π' o < π' , π >)>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
87 ≈⟨ π-cong (cdr e3a) (cdr e3b) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
88 < f o π' , g o π >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
89
979
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
90 π≈ : {a b c : Obj A} {f f' : Hom A c a }{g g' : Hom A c b } → < f , g > ≈ < f' , g' > → f ≈ f'
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
91 π≈ {_} {_} {_} {f} {f'} {g} {g'} eq = begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
92 f ≈↑⟨ e3a ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
93 π o < f , g > ≈⟨ cdr eq ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
94 π o < f' , g' > ≈⟨ e3a ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
95 f'
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
96
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
97 π'≈ : {a b c : Obj A} {f f' : Hom A c a }{g g' : Hom A c b } → < f , g > ≈ < f' , g' > → g ≈ g'
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
98 π'≈ {_} {_} {_} {f} {f'} {g} {g'} eq = begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
99 g ≈↑⟨ e3b ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
100 π' o < f , g > ≈⟨ cdr eq ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
101 π' o < f' , g' > ≈⟨ e3b ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
102 g'
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 977
diff changeset
103
967
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
104 distr-* : {a b c d : Obj A } { h : Hom A (a ∧ b) c } { k : Hom A d a } → ( h * o k ) ≈ ( h o < ( k o π ) , π' > ) *
794
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
105 distr-* {a} {b} {c} {d} {h} {k} = begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
106 h * o k
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
107 ≈↑⟨ e4b ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
108 ( ε o < (h * o k ) o π , π' > ) *
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
109 ≈⟨ *-cong ( begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
110 ε o < (h * o k ) o π , π' >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
111 ≈↑⟨ cdr ( π-cong assoc refl-hom ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
112 ε o ( < h * o ( k o π ) , π' > )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
113 ≈↑⟨ cdr ( π-cong (cdr e3a) e3b ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
114 ε o ( < h * o ( π o < k o π , π' > ) , π' o < k o π , π' > > )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
115 ≈⟨ cdr ( π-cong assoc refl-hom) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
116 ε o ( < (h * o π) o < k o π , π' > , π' o < k o π , π' > > )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
117 ≈↑⟨ cdr ( distr-π ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
118 ε o ( < h * o π , π' > o < k o π , π' > )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
119 ≈⟨ assoc ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
120 ( ε o < h * o π , π' > ) o < k o π , π' >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
121 ≈⟨ car e4a ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
122 h o < k o π , π' >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
123 ∎ ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
124 ( h o < k o π , π' > ) *
967
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
125
794
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
126 α : {a b c : Obj A } → Hom A (( a ∧ b ) ∧ c ) ( a ∧ ( b ∧ c ) )
967
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
127 α = < ( π o π ) , < ( π' o π ) , π' > >
794
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
128 α' : {a b c : Obj A } → Hom A ( a ∧ ( b ∧ c ) ) (( a ∧ b ) ∧ c )
967
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
129 α' = < < π , ( π o π' ) > , ( π' o π' ) >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
130 β : {a b c d : Obj A } { f : Hom A a b} { g : Hom A a c } { h : Hom A a d } → ( α o < < f , g > , h > ) ≈ < f , < g , h > >
794
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
131 β {a} {b} {c} {d} {f} {g} {h} = begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
132 α o < < f , g > , h >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
133 ≈⟨⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
134 ( < ( π o π ) , < ( π' o π ) , π' > > ) o < < f , g > , h >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
135 ≈⟨ distr-π ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
136 < ( ( π o π ) o < < f , g > , h > ) , ( < ( π' o π ) , π' > o < < f , g > , h > ) >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
137 ≈⟨ π-cong refl-hom distr-π ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
138 < ( ( π o π ) o < < f , g > , h > ) , ( < ( ( π' o π ) o < < f , g > , h > ) , ( π' o < < f , g > , h > ) > ) >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
139 ≈↑⟨ π-cong assoc ( π-cong assoc refl-hom ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
140 < ( π o (π o < < f , g > , h >) ) , ( < ( π' o ( π o < < f , g > , h > ) ) , ( π' o < < f , g > , h > ) > ) >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
141 ≈⟨ π-cong (cdr e3a ) ( π-cong (cdr e3a ) e3b ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
142 < ( π o < f , g > ) , < ( π' o < f , g > ) , h > >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
143 ≈⟨ π-cong e3a ( π-cong e3b refl-hom ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
144 < f , < g , h > >
967
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 965
diff changeset
145
794
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
146
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
147
784
f27d966939f8 add CCC hom
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 783
diff changeset
148 record CCC {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) : Set ( c₁ ⊔ c₂ ⊔ ℓ ) where
781
340708e8d54f fix for 2.5.4.2
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 780
diff changeset
149 field
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
150 1 : Obj A
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
151 ○ : (a : Obj A ) → Hom A a 1
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
152 _∧_ : Obj A → Obj A → Obj A
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
153 <_,_> : {a b c : Obj A } → Hom A c a → Hom A c b → Hom A c (a ∧ b)
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
154 π : {a b : Obj A } → Hom A (a ∧ b) a
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
155 π' : {a b : Obj A } → Hom A (a ∧ b) b
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
156 _<=_ : (a b : Obj A ) → Obj A
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
157 _* : {a b c : Obj A } → Hom A (a ∧ b) c → Hom A a (c <= b)
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
158 ε : {a b : Obj A } → Hom A ((a <= b ) ∧ b) a
784
f27d966939f8 add CCC hom
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 783
diff changeset
159 isCCC : IsCCC A 1 ○ _∧_ <_,_> π π' _<=_ _* ε
781
340708e8d54f fix for 2.5.4.2
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 780
diff changeset
160
1011
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
161 open Functor
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
162
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
163 record CCCFunctor {c₁ c₂ ℓ c₁' c₂' ℓ' : Level} (A : Category c₁ c₂ ℓ) (B : Category c₁' c₂' ℓ')
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
164 (ca : CCC A) (cb : CCC B) (functor : Functor A B)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
165 : Set (suc (c₁ ⊔ c₂ ⊔ ℓ ⊔ c₁' ⊔ c₂' ⊔ ℓ')) where
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
166 field
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
167 f1 : FObj functor (CCC.1 ca) ≡ CCC.1 cb
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
168 f○ : {a : Obj A} → B [ FMap functor (CCC.○ ca a) ≈
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
169 subst (λ k → Hom B (FObj functor a) k) (sym f1) (CCC.○ cb (FObj functor a)) ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
170 f∧ : {a b : Obj A} → FObj functor ( CCC._∧_ ca a b ) ≡ CCC._∧_ cb (FObj functor a ) (FObj functor b)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
171 f<= : {a b : Obj A} → FObj functor ( CCC._<=_ ca a b ) ≡ CCC._<=_ cb (FObj functor a ) (FObj functor b)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
172 f<> : {a b c : Obj A} → (f : Hom A c a ) → (g : Hom A c b )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
173 → B [ FMap functor (CCC.<_,_> ca f g ) ≈
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
174 subst (λ k → Hom B (FObj functor c) k ) (sym f∧ ) ( CCC.<_,_> cb (FMap functor f ) ( FMap functor g )) ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
175 fπ : {a b : Obj A} → B [ FMap functor (CCC.π ca {a} {b}) ≈
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
176 subst (λ k → Hom B k (FObj functor a) ) (sym f∧ ) (CCC.π cb {FObj functor a} {FObj functor b}) ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
177 fπ' : {a b : Obj A} → B [ FMap functor (CCC.π' ca {a} {b}) ≈
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
178 subst (λ k → Hom B k (FObj functor b) ) (sym f∧ ) (CCC.π' cb {FObj functor a} {FObj functor b}) ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
179 f* : {a b c : Obj A} → (f : Hom A (CCC._∧_ ca a b) c ) → B [ FMap functor (CCC._* ca f) ≈
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
180 subst (λ k → Hom B (FObj functor a) k) (sym f<=) (CCC._* cb ((subst (λ k → Hom B k (FObj functor c) ) f∧ (FMap functor f) ))) ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
181 fε : {a b : Obj A} → B [ FMap functor (CCC.ε ca {a} {b} )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
182 ≈ subst (λ k → Hom B k (FObj functor a)) (trans (cong (λ k → CCC._∧_ cb k (FObj functor b)) (sym f<=)) (sym f∧))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
183 (CCC.ε cb {FObj functor a} {FObj functor b}) ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 986
diff changeset
184
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
185 open Equalizer
963
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
186 open import equalizer
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
187
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
188 record Mono {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) {b a : Obj A} (mono : Hom A b a) : Set (c₁ ⊔ c₂ ⊔ ℓ) where
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
189 field
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
190 isMono : {c : Obj A} ( f g : Hom A c b ) → A [ A [ mono o f ] ≈ A [ mono o g ] ] → A [ f ≈ g ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
191
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
192 open Mono
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
193
1075
10b4d04b734f fix topos char iso
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1074
diff changeset
194 eMonic : {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) {b a : Obj A} { f g : Hom A b a } → (equ : Equalizer A f g ) → Mono A (equalizer equ)
10b4d04b734f fix topos char iso
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1074
diff changeset
195 eMonic A equ = record { isMono = λ f g → monic equ }
10b4d04b734f fix topos char iso
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1074
diff changeset
196
1069
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
197 iso-mono : {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) {a b c : Obj A } {m : Hom A a b} ( mono : Mono A m ) (i : Iso A a c ) → Mono A (A [ m o Iso.≅← i ] )
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
198 iso-mono A {a} {b} {c} {m} mono i = record { isMono = λ {d} f g → im f g } where
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
199 im : {d : Obj A} (f g : Hom A d c ) → A [ A [ A [ m o Iso.≅← i ] o f ] ≈ A [ A [ m o Iso.≅← i ] o g ] ] → A [ f ≈ g ]
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
200 im {d} f g mf=mg = begin
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
201 f ≈↑⟨ idL ⟩
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
202 id1 A _ o f ≈↑⟨ car (Iso.iso← i) ⟩
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
203 ( Iso.≅→ i o Iso.≅← i) o f ≈↑⟨ assoc ⟩
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
204 Iso.≅→ i o (Iso.≅← i o f) ≈⟨ cdr ( Mono.isMono mono _ _ (if=ig mf=mg) ) ⟩
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
205 Iso.≅→ i o (Iso.≅← i o g) ≈⟨ assoc ⟩
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
206 ( Iso.≅→ i o Iso.≅← i) o g ≈⟨ car (Iso.iso← i) ⟩
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
207 id1 A _ o g ≈⟨ idL ⟩
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
208 g ∎ where
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
209 open ≈-Reasoning A
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
210 if=ig : ( m o Iso.≅← i ) o f ≈ ( m o Iso.≅← i ) o g → m o (Iso.≅← i o f ) ≈ m o ( Iso.≅← i o g )
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
211 if=ig eq = trans-hom assoc (trans-hom eq (sym-hom assoc ) )
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
212
1072
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
213 iso-mono→ : {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) {a b c : Obj A } {m : Hom A a b} ( mono : Mono A m ) (i : Iso A c a ) → Mono A (A [ m o Iso.≅→ i ] )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
214 iso-mono→ A {a} {b} {c} {m} mono i = record { isMono = λ {d} f g → im f g } where
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
215 im : {d : Obj A} (f g : Hom A d c ) → A [ A [ A [ m o Iso.≅→ i ] o f ] ≈ A [ A [ m o Iso.≅→ i ] o g ] ] → A [ f ≈ g ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
216 im {d} f g mf=mg = begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
217 f ≈↑⟨ idL ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
218 id1 A _ o f ≈↑⟨ car (Iso.iso→ i) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
219 ( Iso.≅← i o Iso.≅→ i) o f ≈↑⟨ assoc ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
220 Iso.≅← i o (Iso.≅→ i o f) ≈⟨ cdr ( Mono.isMono mono _ _ (if=ig mf=mg) ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
221 Iso.≅← i o (Iso.≅→ i o g) ≈⟨ assoc ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
222 ( Iso.≅← i o Iso.≅→ i) o g ≈⟨ car (Iso.iso→ i) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
223 id1 A _ o g ≈⟨ idL ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
224 g ∎ where
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
225 open ≈-Reasoning A
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
226 if=ig : ( m o Iso.≅→ i ) o f ≈ ( m o Iso.≅→ i ) o g → m o (Iso.≅→ i o f ) ≈ m o ( Iso.≅→ i o g )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1071
diff changeset
227 if=ig eq = trans-hom assoc (trans-hom eq (sym-hom assoc ) )
1069
849f85e543f1 char-cong
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1034
diff changeset
228
1074
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
229 ----
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
230 --
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
231 -- Sub Object Classifier as Topos
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
232 -- pull back on
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
233 --
1097
321f0fef54c2 add Todo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1095
diff changeset
234 -- m ∙ f ≈ m ∙ g → f ≈ g
321f0fef54c2 add Todo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1095
diff changeset
235 --
1074
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
236 -- iso ○ b
1097
321f0fef54c2 add Todo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1095
diff changeset
237 -- e ⇐====⇒ b -----------→ 1
1074
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
238 -- | | |
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
239 -- | m | | ⊤
1097
321f0fef54c2 add Todo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1095
diff changeset
240 -- | ↓ char m ↓
321f0fef54c2 add Todo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1095
diff changeset
241 -- + ------→ a -----------→ Ω
1074
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
242 -- ker h h
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
243 --
1097
321f0fef54c2 add Todo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1095
diff changeset
244 -- Ker h = Equalizer (char m mono) (⊤ ∙ ○ a )
321f0fef54c2 add Todo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1095
diff changeset
245 -- m = Equalizer (char m mono) (⊤ ∙ ○ a )
321f0fef54c2 add Todo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1095
diff changeset
246 --
1074
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
247 -- if m is an equalizer, there is an iso between e and b as k, and if we have the iso, m becomes an equalizer.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
248 -- equalizer.equalizerIso : {a b c : Obj A} → (f g : Hom A a b ) → (equ : Equalizer A f g )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
249 -- → (m : Hom A c a) → ( ker-iso : IsoL A m (equalizer equ) ) → IsEqualizer A m f g
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1072
diff changeset
250
975
f8fba4f1dcfa char-m=⊤
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 974
diff changeset
251 record IsTopos {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) (c : CCC A)
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
252 ( Ω : Obj A )
975
f8fba4f1dcfa char-m=⊤
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 974
diff changeset
253 ( ⊤ : Hom A (CCC.1 c) Ω )
f8fba4f1dcfa char-m=⊤
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 974
diff changeset
254 (Ker : {a : Obj A} → ( h : Hom A a Ω ) → Equalizer A h (A [ ⊤ o (CCC.○ c a) ]))
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
255 (char : {a b : Obj A} → (m : Hom A b a) → Mono A m → Hom A a Ω) : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
256 field
1071
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1070
diff changeset
257 ker-m : {a b : Obj A} → (m : Hom A b a ) → (mono : Mono A m) → IsEqualizer A m (char m mono) (A [ ⊤ o (CCC.○ c a) ])
1075
10b4d04b734f fix topos char iso
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1074
diff changeset
258 char-uniqueness : {a b : Obj A } {h : Hom A a Ω}
10b4d04b734f fix topos char iso
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1074
diff changeset
259 → A [ char (equalizer (Ker h)) (record { isMono = λ f g → monic (Ker h)}) ≈ h ]
10b4d04b734f fix topos char iso
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1074
diff changeset
260 char-iso : {a a' b : Obj A} → (p : Hom A a b ) (q : Hom A a' b ) → (mp : Mono A p) →(mq : Mono A q) →
1095
0211d99f29fc Topos Sets char-iso done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1075
diff changeset
261 (i : Iso A a a' ) → A [ p ≈ A [ q o Iso.≅→ i ] ] → A [ char p mp ≈ char q mq ]
1097
321f0fef54c2 add Todo
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1095
diff changeset
262 -- this means, char m is unique among all equalizers of h and ○ a
1075
10b4d04b734f fix topos char iso
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1074
diff changeset
263 char-cong : {a b : Obj A } { m m' : Hom A b a } { mono : Mono A m } { mono' : Mono A m' }
1070
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1069
diff changeset
264 → A [ m ≈ m' ] → A [ char m mono ≈ char m' mono' ]
1095
0211d99f29fc Topos Sets char-iso done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1075
diff changeset
265 char-cong {a} {b} {m} {m'} {mo} {mo'} m=m' = char-iso m m' mo mo' (≡-iso A _) ( begin
0211d99f29fc Topos Sets char-iso done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1075
diff changeset
266 m ≈⟨ m=m' ⟩
0211d99f29fc Topos Sets char-iso done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1075
diff changeset
267 m' ≈↑⟨ idR ⟩
0211d99f29fc Topos Sets char-iso done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1075
diff changeset
268 m' o Iso.≅→ (≡-iso A b) ∎ ) where open ≈-Reasoning A
1016
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1011
diff changeset
269 ker : {a : Obj A} → ( h : Hom A a Ω ) → Hom A ( equalizer-c (Ker h) ) a
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1011
diff changeset
270 ker h = equalizer (Ker h)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1011
diff changeset
271 char-m=⊤ : {a b : Obj A} → (m : Hom A b a) → (mono : Mono A m) → A [ A [ char m mono o m ] ≈ A [ ⊤ o CCC.○ c b ] ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1011
diff changeset
272 char-m=⊤ {a} {b} m mono = begin
1018
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1017
diff changeset
273 char m mono o m ≈⟨ IsEqualizer.fe=ge (ker-m m mono) ⟩
1016
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1011
diff changeset
274 (⊤ o CCC.○ c a) o m ≈↑⟨ assoc ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1011
diff changeset
275 ⊤ o (CCC.○ c a o m ) ≈⟨ cdr (IsCCC.e2 (CCC.isCCC c)) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 1011
diff changeset
276 ⊤ o CCC.○ c b ∎ where open ≈-Reasoning A
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
277
975
f8fba4f1dcfa char-m=⊤
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 974
diff changeset
278 record Topos {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) (c : CCC A) : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
279 field
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
280 Ω : Obj A
975
f8fba4f1dcfa char-m=⊤
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 974
diff changeset
281 ⊤ : Hom A (CCC.1 c) Ω
f8fba4f1dcfa char-m=⊤
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 974
diff changeset
282 Ker : {a : Obj A} → ( h : Hom A a Ω ) → Equalizer A h (A [ ⊤ o (CCC.○ c a) ])
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
283 char : {a b : Obj A} → (m : Hom A b a ) → Mono A m → Hom A a Ω
975
f8fba4f1dcfa char-m=⊤
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 974
diff changeset
284 isTopos : IsTopos A c Ω ⊤ Ker char
973
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 967
diff changeset
285 Monik : {a : Obj A} (h : Hom A a Ω) → Mono A (equalizer (Ker h))
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 967
diff changeset
286 Monik h = record { isMono = λ f g → monic (Ker h ) }
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
287
963
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
288 record NatD {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
289 field
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
290 Nat : Obj A
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
291 nzero : Hom A 1 Nat
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
292 nsuc : Hom A Nat Nat
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
293
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
294 open NatD
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
295
986
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
296 record IsToposNat {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) (iNat : NatD A 1 )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
297 ( initialNat : (nat : NatD A 1 ) → Hom A (Nat iNat) (Nat nat) )
963
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
298 : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
299 field
986
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
300 izero : (nat : NatD A 1 ) → A [ A [ initialNat nat o nzero iNat ] ≈ nzero nat ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
301 isuc : (nat : NatD A 1 ) → A [ A [ initialNat nat o nsuc iNat ] ≈ A [ nsuc nat o initialNat nat ] ]
963
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
302
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
303 record ToposNat {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 954
diff changeset
304 field
986
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
305 iNat : NatD A 1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
306 initialNat : (nat : NatD A 1 ) → Hom A (Nat iNat) (Nat nat)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
307 nat-unique : (nat : NatD A 1 ) → {g : Hom A (Nat iNat) (Nat nat) }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
308 → A [ A [ g o nzero iNat ] ≈ nzero nat ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
309 → A [ A [ g o nsuc iNat ] ≈ A [ nsuc nat o g ] ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
310 → A [ g ≈ initialNat nat ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 981
diff changeset
311 isToposN : IsToposNat A 1 iNat initialNat
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
312