annotate src/CCC.agda @ 953:eb62812b5885

Topos written
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 19 Feb 2021 12:09:48 +0900
parents 61bc4fcba050
children 6aa6cbf630a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
779
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 open import Level
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
2 open import Category
779
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 module CCC where
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
5
779
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 open import HomReasoning
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 open import cat-utility
780
b44c1c6ce646 CCC in Hom form
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 779
diff changeset
8 open import Relation.Binary.PropositionalEquality
779
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
10
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
11 open import HomReasoning
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
12
784
f27d966939f8 add CCC hom
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 783
diff changeset
13 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
14 ( 1 : Obj A )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
15 ( ○ : (a : Obj A ) → Hom A a 1 )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
16 ( _∧_ : Obj A → Obj A → Obj A )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
17 ( <_,_> : {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
18 ( π : {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
19 ( π' : {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
20 ( _<=_ : (a b : Obj A ) → Obj A )
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
21 ( _* : {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
22 ( ε : {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
23 : Set ( c₁ ⊔ c₂ ⊔ ℓ ) where
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
24 field
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
25 -- cartesian
793
f37f11e1b871 Hom a,b = Hom 1 b^a
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 789
diff changeset
26 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
27 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
28 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
29 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
30 π-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
31 -- closed
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
32 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
33 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
34 *-cong : {a b c : Obj A} → { f f' : Hom A (a ∧ b) c } → A [ f ≈ f' ] → A [ f * ≈ f' * ]
779
6b4bd02efd80 CCC start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
35
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
36 e'2 : A [ ○ 1 ≈ id1 A 1 ]
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
37 e'2 = let open ≈-Reasoning A in begin
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
38 ○ 1
793
f37f11e1b871 Hom a,b = Hom 1 b^a
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 789
diff changeset
39 ≈↑⟨ e2 ⟩
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
40 id1 A 1
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
41
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
42 e''2 : {a b : Obj A} {f : Hom A a b } → A [ A [ ○ b o f ] ≈ ○ a ]
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
43 e''2 {a} {b} {f} = let open ≈-Reasoning A in begin
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
44 ○ b o f
793
f37f11e1b871 Hom a,b = Hom 1 b^a
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 789
diff changeset
45 ≈⟨ e2 ⟩
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
46 ○ a
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
47
789
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
48 π-id : {a b : Obj A} → A [ < π , π' > ≈ id1 A (a ∧ b ) ]
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
49 π-id {a} {b} = let open ≈-Reasoning A in begin
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
50 < π , π' >
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
51 ≈↑⟨ π-cong idR idR ⟩
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
52 < π 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
53 ≈⟨ e3c ⟩
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
54 id1 A (a ∧ b )
4e1e2f7199c8 CCC Hom done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 787
diff changeset
55
794
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
56 distr-π : {a b c d : Obj A} {f : Hom A c a }{g : Hom A c b } {h : Hom A d c } → A [ A [ < f , g > o h ] ≈ < A [ f o h ] , A [ g o h ] > ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
57 distr-π {a} {b} {c} {d} {f} {g} {h} = let open ≈-Reasoning A in begin
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
58 < f , g > o h
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
59 ≈↑⟨ e3c ⟩
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
60 < π 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
61 ≈⟨ π-cong assoc assoc ⟩
a67959bcd44b ccc → hom on going
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 784
diff changeset
62 < ( π 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
63 ≈⟨ π-cong (car e3a ) (car e3b) ⟩
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
64 < f o h , g o h >
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
65
794
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
66 _×_ : { a b c d : Obj A } ( f : Hom A a c ) (g : Hom A b d ) → Hom A (a ∧ b) ( c ∧ d )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
67 f × g = < (A [ f o π ] ) , (A [ g o π' ]) >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
68 distr-* : {a b c d : Obj A } { h : Hom A (a ∧ b) c } { k : Hom A d a } → A [ A [ h * o k ] ≈ ( A [ h o < A [ k o π ] , π' > ] ) * ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
69 distr-* {a} {b} {c} {d} {h} {k} = begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
70 h * o k
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
71 ≈↑⟨ e4b ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
72 ( ε o < (h * o k ) o π , π' > ) *
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
73 ≈⟨ *-cong ( begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
74 ε o < (h * o k ) o π , π' >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
75 ≈↑⟨ cdr ( π-cong assoc refl-hom ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
76 ε o ( < h * o ( k o π ) , π' > )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
77 ≈↑⟨ cdr ( π-cong (cdr e3a) e3b ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
78 ε o ( < h * o ( π o < k o π , π' > ) , π' o < k o π , π' > > )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
79 ≈⟨ cdr ( π-cong assoc refl-hom) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
80 ε o ( < (h * o π) o < k o π , π' > , π' o < k o π , π' > > )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
81 ≈↑⟨ cdr ( distr-π ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
82 ε o ( < h * o π , π' > o < k o π , π' > )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
83 ≈⟨ assoc ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
84 ( ε o < h * o π , π' > ) o < k o π , π' >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
85 ≈⟨ car e4a ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
86 h o < k o π , π' >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
87 ∎ ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
88 ( h o < k o π , π' > ) *
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
89 ∎ where open ≈-Reasoning A
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
90 α : {a b c : Obj A } → Hom A (( a ∧ b ) ∧ c ) ( a ∧ ( b ∧ c ) )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
91 α = < A [ π o π ] , < A [ π' o π ] , π' > >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
92 α' : {a b c : Obj A } → Hom A ( a ∧ ( b ∧ c ) ) (( a ∧ b ) ∧ c )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
93 α' = < < π , A [ π o π' ] > , A [ π' o π' ] >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
94 β : {a b c d : Obj A } { f : Hom A a b} { g : Hom A a c } { h : Hom A a d } → A [ A [ α o < < f , g > , h > ] ≈ < f , < g , h > > ]
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
95 β {a} {b} {c} {d} {f} {g} {h} = begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
96 α o < < f , g > , h >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
97 ≈⟨⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
98 ( < ( π o π ) , < ( π' o π ) , π' > > ) o < < f , g > , h >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
99 ≈⟨ distr-π ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
100 < ( ( π o π ) o < < f , g > , h > ) , ( < ( π' o π ) , π' > o < < f , g > , h > ) >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
101 ≈⟨ π-cong refl-hom distr-π ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
102 < ( ( π 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
103 ≈↑⟨ π-cong assoc ( π-cong assoc refl-hom ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
104 < ( π 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
105 ≈⟨ π-cong (cdr e3a ) ( π-cong (cdr e3a ) e3b ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
106 < ( π o < f , g > ) , < ( π' o < f , g > ) , h > >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
107 ≈⟨ π-cong e3a ( π-cong e3b refl-hom ) ⟩
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
108 < f , < g , h > >
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
109 ∎ where open ≈-Reasoning A
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 793
diff changeset
110
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
111
784
f27d966939f8 add CCC hom
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 783
diff changeset
112 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
113 field
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
114 1 : Obj A
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
115 ○ : (a : Obj A ) → Hom A a 1
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
116 _∧_ : Obj A → Obj A → Obj A
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
117 <_,_> : {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
118 π : {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
119 π' : {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
120 _<=_ : (a b : Obj A ) → Obj A
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
121 _* : {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
122 ε : {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
123 isCCC : IsCCC A 1 ○ _∧_ <_,_> π π' _<=_ _* ε
781
340708e8d54f fix for 2.5.4.2
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 780
diff changeset
124
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
125 ----
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
126 --
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
127 -- Sub Object Classifier as Topos
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
128 --
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
129
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
130 open Equalizer
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
131
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
132 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
133 field
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
134 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
135
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
136 open Mono
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
137
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
138 open import equalizer
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
139
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
140 record IsTopos {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) (○ : (a : Obj A ) → Hom A a 1)
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
141 ( Ω : Obj A )
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
142 ( ⊤ : Hom A 1 Ω )
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
143 (Ker : {a : Obj A} → ( h : Hom A a Ω ) → Equalizer A h (A [ ⊤ o (○ a) ]))
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
144 (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
145 field
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
146 char-ker-id : {a b : Obj A } {h : Hom A a Ω} → (m : Hom A b a) → (mono : Mono A m)
953
eb62812b5885 Topos written
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 952
diff changeset
147 → A [ char (equalizer (Ker h)) record { isMono = monic (Ker h) } ≈ h ]
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
148 ker-char-iso : {a b : Obj A} → (m : Hom A b a) → (mono : Mono A m) → Iso A b ( equalizer-c (Ker ( char m mono )))
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
149
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
150 record Topos {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) (○ : (a : Obj A ) → Hom A a 1) : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
151 field
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
152 Ω : Obj A
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
153 ⊤ : Hom A 1 Ω
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
154 Ker : {a : Obj A} → ( h : Hom A a Ω ) → Equalizer A h (A [ ⊤ o (○ a) ])
952
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
155 char : {a b : Obj A} → (m : Hom A b a ) → Mono A m → Hom A a Ω
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 950
diff changeset
156 isTopos : IsTopos A 1 ○ Ω ⊤ Ker char
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
157 ker : {a : Obj A} → ( h : Hom A a Ω ) → Hom A ( equalizer-c (Ker h) ) a
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
158 ker h = equalizer (Ker h)
783
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
159
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
160
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
161
bded2347efa4 CCC by equation
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 781
diff changeset
162
950
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
163
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
164
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
165
bd32a37784b0 Topos start
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 949
diff changeset
166