779
|
1 open import Level
|
|
2 open import Category
|
784
|
3 module CCChom where
|
779
|
4
|
|
5 open import HomReasoning
|
|
6 open import cat-utility
|
784
|
7 open import Data.Product renaming (_×_ to _∧_)
|
|
8 open import Category.Constructions.Product
|
790
|
9 open import Relation.Binary.PropositionalEquality hiding ( [_] )
|
779
|
10
|
|
11 open Functor
|
|
12
|
|
13 -- ccc-1 : Hom A a 1 ≅ {*}
|
|
14 -- ccc-2 : Hom A c (a × b) ≅ (Hom A c a ) × ( Hom A c b )
|
|
15 -- ccc-3 : Hom A a (c ^ b) ≅ Hom A (a × b) c
|
|
16
|
785
|
17 data One : Set where
|
779
|
18 OneObj : One -- () in Haskell ( or any one object set )
|
|
19
|
780
|
20 OneCat : Category Level.zero Level.zero Level.zero
|
|
21 OneCat = record {
|
|
22 Obj = One ;
|
|
23 Hom = λ a b → One ;
|
|
24 _o_ = λ{a} {b} {c} x y → OneObj ;
|
|
25 _≈_ = λ x y → x ≡ y ;
|
|
26 Id = λ{a} → OneObj ;
|
|
27 isCategory = record {
|
|
28 isEquivalence = record {refl = refl ; trans = trans ; sym = sym } ;
|
|
29 identityL = λ{a b f} → lemma {a} {b} {f} ;
|
|
30 identityR = λ{a b f} → lemma {a} {b} {f} ;
|
|
31 o-resp-≈ = λ{a b c f g h i} _ _ → refl ;
|
|
32 associative = λ{a b c d f g h } → refl
|
|
33 }
|
|
34 } where
|
785
|
35 lemma : {a b : One } → { f : One } → OneObj ≡ f
|
780
|
36 lemma {a} {b} {f} with f
|
|
37 ... | OneObj = refl
|
|
38
|
783
|
39 record IsoS {c₁ c₂ ℓ c₁' c₂' ℓ' : Level} (A : Category c₁ c₂ ℓ) (B : Category c₁' c₂' ℓ') (a b : Obj A) ( a' b' : Obj B )
|
|
40 : Set ( c₁ ⊔ c₂ ⊔ ℓ ⊔ c₁' ⊔ c₂' ⊔ ℓ' ) where
|
|
41 field
|
|
42 ≅→ : Hom A a b → Hom B a' b'
|
|
43 ≅← : Hom B a' b' → Hom A a b
|
|
44 iso→ : {f : Hom B a' b' } → B [ ≅→ ( ≅← f) ≈ f ]
|
|
45 iso← : {f : Hom A a b } → A [ ≅← ( ≅→ f) ≈ f ]
|
787
|
46 cong→ : {f g : Hom A a b } → A [ f ≈ g ] → B [ ≅→ f ≈ ≅→ g ]
|
|
47 cong← : {f g : Hom B a' b'} → B [ f ≈ g ] → A [ ≅← f ≈ ≅← g ]
|
779
|
48
|
783
|
49
|
784
|
50 record IsCCChom {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) (1 : Obj A)
|
780
|
51 ( _*_ : Obj A → Obj A → Obj A ) ( _^_ : Obj A → Obj A → Obj A ) : Set ( c₁ ⊔ c₂ ⊔ ℓ ) where
|
779
|
52 field
|
785
|
53 ccc-1 : {a : Obj A} {b c : Obj OneCat} → -- Hom A a 1 ≅ {*}
|
|
54 IsoS A OneCat a 1 b c
|
780
|
55 ccc-2 : {a b c : Obj A} → -- Hom A c ( a * b ) ≅ ( Hom A c a ) * ( Hom A c b )
|
784
|
56 IsoS A (A × A) c (a * b) (c , c ) (a , b )
|
780
|
57 ccc-3 : {a b c : Obj A} → -- Hom A a ( c ^ b ) ≅ Hom A ( a * b ) c
|
|
58 IsoS A A a (c ^ b) (a * b) c
|
788
|
59 nat-2 : {a b c : Obj A} → {f : Hom A (b * c) (b * c) } → {g : Hom A a (b * c) }
|
|
60 → (A × A) [ (A × A) [ IsoS.≅→ ccc-2 f o (g , g) ] ≈ IsoS.≅→ ccc-2 ( A [ f o g ] ) ]
|
789
|
61 nat-3 : {a b c : Obj A} → { k : Hom A c (a ^ b ) } → A [ A [ IsoS.≅→ (ccc-3) (id1 A (a ^ b)) o
|
|
62 (IsoS.≅← (ccc-2 ) (A [ k o (proj₁ ( IsoS.≅→ ccc-2 (id1 A (c * b)))) ] ,
|
|
63 (proj₂ ( IsoS.≅→ ccc-2 (id1 A (c * b) ))))) ] ≈ IsoS.≅→ (ccc-3 ) k ]
|
788
|
64
|
|
65 open import CCC
|
|
66
|
779
|
67
|
784
|
68 record CCChom {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) : Set ( c₁ ⊔ c₂ ⊔ ℓ ) where
|
781
|
69 field
|
|
70 one : Obj A
|
|
71 _*_ : Obj A → Obj A → Obj A
|
|
72 _^_ : Obj A → Obj A → Obj A
|
784
|
73 isCCChom : IsCCChom A one _*_ _^_
|
783
|
74
|
|
75 open import HomReasoning
|
|
76
|
784
|
77 CCC→hom : {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( c : CCC A ) → CCChom A
|
|
78 CCC→hom A c = record {
|
|
79 one = CCC.1 c
|
|
80 ; _*_ = CCC._∧_ c
|
|
81 ; _^_ = CCC._<=_ c
|
|
82 ; isCCChom = record {
|
787
|
83 ccc-1 = λ {a} {b} {c'} → record { ≅→ = c101 ; ≅← = c102 ; iso→ = c103 {a} {b} {c'} ; iso← = c104 ; cong← = c105 ; cong→ = c106 }
|
|
84 ; ccc-2 = record { ≅→ = c201 ; ≅← = c202 ; iso→ = c203 ; iso← = c204 ; cong← = c205; cong→ = c206 }
|
|
85 ; ccc-3 = record { ≅→ = c301 ; ≅← = c302 ; iso→ = c303 ; iso← = c304 ; cong← = c305 ; cong→ = c306 }
|
789
|
86 ; nat-2 = nat-2 ; nat-3 = nat-3
|
784
|
87 }
|
785
|
88 } where
|
|
89 c101 : {a : Obj A} → Hom A a (CCC.1 c) → Hom OneCat OneObj OneObj
|
|
90 c101 _ = OneObj
|
|
91 c102 : {a : Obj A} → Hom OneCat OneObj OneObj → Hom A a (CCC.1 c)
|
|
92 c102 {a} OneObj = CCC.○ c a
|
|
93 c103 : {a : Obj A } {b c : Obj OneCat} {f : Hom OneCat b b } → _[_≈_] OneCat {b} {c} ( c101 {a} (c102 {a} f) ) f
|
|
94 c103 {a} {OneObj} {OneObj} {OneObj} = refl
|
|
95 c104 : {a : Obj A} → {f : Hom A a (CCC.1 c)} → A [ (c102 ( c101 f )) ≈ f ]
|
793
|
96 c104 {a} {f} = let open ≈-Reasoning A in HomReasoning.≈-Reasoning.sym A (IsCCC.e2 (CCC.isCCC c) )
|
785
|
97 c201 : { c₁ a b : Obj A} → Hom A c₁ ((c CCC.∧ a) b) → Hom (A × A) (c₁ , c₁) (a , b)
|
|
98 c201 f = ( A [ CCC.π c o f ] , A [ CCC.π' c o f ] )
|
|
99 c202 : { c₁ a b : Obj A} → Hom (A × A) (c₁ , c₁) (a , b) → Hom A c₁ ((c CCC.∧ a) b)
|
|
100 c202 (f , g ) = CCC.<_,_> c f g
|
|
101 c203 : { c₁ a b : Obj A} → {f : Hom (A × A) (c₁ , c₁) (a , b)} → (A × A) [ (c201 ( c202 f )) ≈ f ]
|
|
102 c203 = ( IsCCC.e3a (CCC.isCCC c) , IsCCC.e3b (CCC.isCCC c))
|
|
103 c204 : { c₁ a b : Obj A} → {f : Hom A c₁ ((c CCC.∧ a) b)} → A [ (c202 ( c201 f )) ≈ f ]
|
|
104 c204 = IsCCC.e3c (CCC.isCCC c)
|
|
105 c301 : { d a b : Obj A} → Hom A a ((c CCC.<= d) b) → Hom A ((c CCC.∧ a) b) d -- a -> d <= b -> (a ∧ b ) -> d
|
|
106 c301 {d} {a} {b} f = A [ CCC.ε c o CCC.<_,_> c ( A [ f o CCC.π c ] ) ( CCC.π' c ) ]
|
|
107 c302 : { d a b : Obj A} → Hom A ((c CCC.∧ a) b) d → Hom A a ((c CCC.<= d) b)
|
|
108 c302 f = CCC._* c f
|
|
109 c303 : { c₁ a b : Obj A} → {f : Hom A ((c CCC.∧ a) b) c₁} → A [ (c301 ( c302 f )) ≈ f ]
|
|
110 c303 = IsCCC.e4a (CCC.isCCC c)
|
|
111 c304 : { c₁ a b : Obj A} → {f : Hom A a ((c CCC.<= c₁) b)} → A [ (c302 ( c301 f )) ≈ f ]
|
|
112 c304 = IsCCC.e4b (CCC.isCCC c)
|
787
|
113 c105 : {a : Obj A } {f g : Hom OneCat OneObj OneObj} → _[_≈_] OneCat {OneObj} {OneObj} f g → A [ c102 {a} f ≈ c102 {a} g ]
|
|
114 c105 refl = let open ≈-Reasoning A in refl-hom
|
|
115 c106 : { a : Obj A } {f g : Hom A a (CCC.1 c)} → A [ f ≈ g ] → _[_≈_] OneCat {OneObj} {OneObj} OneObj OneObj
|
|
116 c106 _ = refl
|
|
117 c205 : { a b c₁ : Obj A } {f g : Hom (A × A) (c₁ , c₁) (a , b)} → (A × A) [ f ≈ g ] → A [ c202 f ≈ c202 g ]
|
|
118 c205 f=g = IsCCC.π-cong (CCC.isCCC c ) (proj₁ f=g ) (proj₂ f=g )
|
|
119 c206 : { a b c₁ : Obj A } {f g : Hom A c₁ ((c CCC.∧ a) b)} → A [ f ≈ g ] → (A × A) [ c201 f ≈ c201 g ]
|
|
120 c206 {a} {b} {c₁} {f} {g} f=g = ( begin
|
|
121 CCC.π c o f
|
|
122 ≈⟨ cdr f=g ⟩
|
|
123 CCC.π c o g
|
|
124 ∎ ) , ( begin
|
|
125 CCC.π' c o f
|
|
126 ≈⟨ cdr f=g ⟩
|
|
127 CCC.π' c o g
|
|
128 ∎ ) where open ≈-Reasoning A
|
|
129 c305 : { a b c₁ : Obj A } {f g : Hom A ((c CCC.∧ a) b) c₁} → A [ f ≈ g ] → A [ (c CCC.*) f ≈ (c CCC.*) g ]
|
|
130 c305 f=g = IsCCC.*-cong (CCC.isCCC c ) f=g
|
|
131 c306 : { a b c₁ : Obj A } {f g : Hom A a ((c CCC.<= c₁) b)} → A [ f ≈ g ] → A [ c301 f ≈ c301 g ]
|
|
132 c306 {a} {b} {c₁} {f} {g} f=g = begin
|
|
133 CCC.ε c o CCC.<_,_> c ( f o CCC.π c ) ( CCC.π' c )
|
|
134 ≈⟨ cdr ( IsCCC.π-cong (CCC.isCCC c ) (car f=g ) refl-hom) ⟩
|
|
135 CCC.ε c o CCC.<_,_> c ( g o CCC.π c ) ( CCC.π' c )
|
|
136 ∎ where open ≈-Reasoning A
|
788
|
137 nat-2 : {a b : Obj A} {c = c₁ : Obj A} {f : Hom A ((c CCC.∧ b) c₁) ((c CCC.∧ b) c₁)}
|
|
138 {g : Hom A a ((c CCC.∧ b) c₁)} → (A × A) [ (A × A) [ c201 f o g , g ] ≈ c201 (A [ f o g ]) ]
|
|
139 nat-2 {a} {b} {c₁} {f} {g} = ( begin
|
|
140 ( CCC.π c o f) o g
|
|
141 ≈↑⟨ assoc ⟩
|
|
142 ( CCC.π c ) o (f o g)
|
|
143 ∎ ) , (sym-hom assoc) where open ≈-Reasoning A
|
789
|
144 nat-3 : {a b : Obj A} {c = c₁ : Obj A} {k : Hom A c₁ ((c CCC.<= a) b)} →
|
|
145 A [ A [ c301 (id1 A ((c CCC.<= a) b)) o c202 (A [ k o proj₁ (c201 (id1 A ((c CCC.∧ c₁) b))) ] , proj₂ (c201 (id1 A ((c CCC.∧ c₁) b)))) ]
|
|
146 ≈ c301 k ]
|
|
147 nat-3 {a} {b} { c₁} {k} = begin
|
|
148 c301 (id1 A ((c CCC.<= a) b)) o c202 ( k o proj₁ (c201 (id1 A ((c CCC.∧ c₁) b))) , proj₂ (c201 (id1 A ((c CCC.∧ c₁) b))))
|
|
149 ≈⟨⟩
|
|
150 ( CCC.ε c o CCC.<_,_> c ((id1 A (CCC._<=_ c a b )) o CCC.π c) (CCC.π' c))
|
|
151 o (CCC.<_,_> c (k o ( CCC.π c o (id1 A (CCC._∧_ c c₁ b )))) ( CCC.π' c o (id1 A (CCC._∧_ c c₁ b))))
|
|
152 ≈↑⟨ assoc ⟩
|
|
153 (CCC.ε c) o (( CCC.<_,_> c ((id1 A (CCC._<=_ c a b )) o CCC.π c) (CCC.π' c))
|
|
154 o (CCC.<_,_> c (k o ( CCC.π c o (id1 A (CCC._∧_ c c₁ b )))) ( CCC.π' c o (id1 A (CCC._∧_ c c₁ b)))))
|
|
155 ≈⟨ cdr (car (IsCCC.π-cong (CCC.isCCC c ) idL refl-hom ) ) ⟩
|
|
156 (CCC.ε c) o ( CCC.<_,_> c (CCC.π c) (CCC.π' c)
|
|
157 o (CCC.<_,_> c (k o ( CCC.π c o (id1 A (CCC._∧_ c c₁ b )))) ( CCC.π' c o (id1 A (CCC._∧_ c c₁ b)))))
|
|
158 ≈⟨ cdr (car (IsCCC.π-id (CCC.isCCC c))) ⟩
|
|
159 (CCC.ε c) o ( id1 A (CCC._∧_ c ((c CCC.<= a) b) b )
|
|
160 o (CCC.<_,_> c (k o ( CCC.π c o (id1 A (CCC._∧_ c c₁ b )))) ( CCC.π' c o (id1 A (CCC._∧_ c c₁ b)))))
|
|
161 ≈⟨ cdr ( cdr ( IsCCC.π-cong (CCC.isCCC c) (cdr idR) idR )) ⟩
|
|
162 (CCC.ε c) o ( id1 A (CCC._∧_ c ((c CCC.<= a) b) b ) o (CCC.<_,_> c (k o ( CCC.π c )) ( CCC.π' c )))
|
|
163 ≈⟨ cdr idL ⟩
|
|
164 (CCC.ε c) o (CCC.<_,_> c ( k o (CCC.π c) ) (CCC.π' c))
|
|
165 ≈⟨⟩
|
|
166 c301 k
|
|
167 ∎ where open ≈-Reasoning A
|
788
|
168
|
793
|
169 lemma1 : {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( ccc : CCC A ) → {a b c : Obj A} → -- Hom A 1 ( c ^ b ) ≅ Hom A b c
|
|
170 IsoS A A (CCC.1 ccc ) (CCC._<=_ ccc c b) b c
|
|
171 lemma1 A ccc {a} {b} {c} = record {
|
|
172 ≅→ = λ f → A [ CCC.ε ccc o CCC.<_,_> ccc ( A [ f o CCC.○ ccc b ] ) ( id1 A b ) ]
|
|
173 ; ≅← = λ f → CCC._* ccc ( A [ f o CCC.π' ccc ] )
|
|
174 ; iso→ = iso→
|
|
175 ; iso← = iso←
|
|
176 ; cong→ = cong*
|
|
177 ; cong← = cong2
|
|
178 } where
|
|
179 cc = IsCCChom.ccc-3 ( CCChom.isCCChom (CCC→hom A ccc ) )
|
|
180 -- e4a : {a b c : Obj A} → { k : Hom A (c /\ b) a } → A [ A [ ε o ( <,> ( A [ (k *) o π ] ) π') ] ≈ k ]
|
|
181 iso→ : {f : Hom A b c} → A [
|
|
182 (A Category.o CCC.ε ccc) (CCC.< ccc , (A Category.o (ccc CCC.*) ((A Category.o f) (CCC.π' ccc))) (CCC.○ ccc b) > (Category.Category.Id A)) ≈ f ]
|
|
183 iso→ {f} = begin
|
|
184 CCC.ε ccc o (CCC.<_,_> ccc (CCC._* ccc ( f o (CCC.π' ccc)) o (CCC.○ ccc b)) (id1 A b ) )
|
|
185 ≈↑⟨ cdr ( IsCCC.π-cong ( CCC.isCCC ccc ) refl-hom (IsCCC.e3b (CCC.isCCC ccc) ) ) ⟩
|
|
186 CCC.ε ccc o ( CCC.<_,_> ccc (CCC._* ccc (f o CCC.π' ccc) o CCC.○ ccc b) ((CCC.π' ccc) o CCC.<_,_> ccc (CCC.○ ccc b) (id1 A b) ) )
|
|
187 ≈↑⟨ cdr ( IsCCC.π-cong ( CCC.isCCC ccc ) (cdr (IsCCC.e3a (CCC.isCCC ccc))) refl-hom ) ⟩
|
|
188 CCC.ε ccc o ( CCC.<_,_> ccc (CCC._* ccc (f o CCC.π' ccc) o ( CCC.π ccc o CCC.<_,_> ccc (CCC.○ ccc b) (id1 A b) ) ) ((CCC.π' ccc) o CCC.<_,_> ccc (CCC.○ ccc b) (id1 A b) ) )
|
|
189 ≈⟨ cdr ( IsCCC.π-cong ( CCC.isCCC ccc ) assoc refl-hom ) ⟩
|
|
190 CCC.ε ccc o ( CCC.<_,_> ccc ((CCC._* ccc (f o CCC.π' ccc) o CCC.π ccc ) o CCC.<_,_> ccc (CCC.○ ccc b) (id1 A b) ) ((CCC.π' ccc) o CCC.<_,_> ccc (CCC.○ ccc b) (id1 A b) ) )
|
|
191 ≈↑⟨ cdr ( IsCCC.distr ( CCC.isCCC ccc ) ) ⟩
|
|
192 CCC.ε ccc o ( CCC.<_,_> ccc (CCC._* ccc (f o CCC.π' ccc) o CCC.π ccc ) (CCC.π' ccc) o CCC.<_,_> ccc (CCC.○ ccc b) (id1 A b) )
|
|
193 ≈⟨ assoc ⟩
|
|
194 ( CCC.ε ccc o CCC.<_,_> ccc (CCC._* ccc (f o CCC.π' ccc) o CCC.π ccc ) (CCC.π' ccc) ) o CCC.<_,_> ccc (CCC.○ ccc b) (id1 A b)
|
|
195 ≈⟨ car ( IsCCC.e4a (CCC.isCCC ccc) ) ⟩
|
|
196 ( f o CCC.π' ccc ) o CCC.<_,_> ccc (CCC.○ ccc b) (id1 A b)
|
|
197 ≈↑⟨ assoc ⟩
|
|
198 f o ( CCC.π' ccc o CCC.<_,_> ccc (CCC.○ ccc b) (id1 A b) )
|
|
199 ≈⟨ cdr (IsCCC.e3b (CCC.isCCC ccc)) ⟩
|
|
200 f o id1 A b
|
|
201 ≈⟨ idR ⟩
|
|
202 f
|
|
203 ∎ where open ≈-Reasoning A
|
|
204 lemma : {f : Hom A (CCC.1 ccc) ((ccc CCC.<= c) b)} → A [ A [ A [ f o (CCC.○ ccc b) ] o (CCC.π' ccc) ] ≈ A [ f o (CCC.π ccc) ] ]
|
|
205 lemma {f} = begin
|
|
206 ( f o (CCC.○ ccc b) ) o (CCC.π' ccc)
|
|
207 ≈↑⟨ assoc ⟩
|
|
208 f o ( (CCC.○ ccc b) o (CCC.π' ccc) )
|
|
209 ≈⟨ cdr ( IsCCC.e2 (CCC.isCCC ccc) ) ⟩
|
|
210 f o (CCC.○ ccc ( CCC._∧_ ccc (CCC.1 ccc) b ) )
|
|
211 ≈↑⟨ cdr ( IsCCC.e2 (CCC.isCCC ccc) ) ⟩
|
|
212 f o ( (CCC.○ ccc) (CCC.1 ccc) o (CCC.π ccc) )
|
|
213 ≈↑⟨ cdr ( car ( IsCCC.e2 (CCC.isCCC ccc) )) ⟩
|
|
214 f o ( id1 A (CCC.1 ccc) o (CCC.π ccc) )
|
|
215 ≈⟨ cdr (idL) ⟩
|
|
216 f o (CCC.π ccc)
|
|
217 ∎ where open ≈-Reasoning A
|
|
218 -- e4b : {a b c : Obj A} → { k : Hom A c (a <= b ) } → A [ ( A [ ε o ( <,> ( A [ k o π ] ) π' ) ] ) * ≈ k ]
|
|
219 iso← : {f : Hom A (CCC.1 ccc) ((ccc CCC.<= c) b)} → A [ (ccc CCC.*) ((A Category.o (A Category.o CCC.ε ccc) (CCC.< ccc , (A Category.o f) (CCC.○ ccc b) >
|
|
220 (Category.Category.Id A))) (CCC.π' ccc)) ≈ f ]
|
|
221 iso← {f} = begin
|
|
222 CCC._* ccc (( CCC.ε ccc o ( CCC.<_,_> ccc ( f o (CCC.○ ccc b) ) (id1 A b ))) o (CCC.π' ccc))
|
|
223 ≈↑⟨ IsCCC.*-cong ( CCC.isCCC ccc ) assoc ⟩
|
|
224 CCC._* ccc ( CCC.ε ccc o (( CCC.<_,_> ccc ( f o (CCC.○ ccc b) ) (id1 A b )) o (CCC.π' ccc)))
|
|
225 ≈⟨ IsCCC.*-cong ( CCC.isCCC ccc ) (cdr ( IsCCC.distr ( CCC.isCCC ccc ) ) ) ⟩
|
|
226 CCC._* ccc ( CCC.ε ccc o CCC.<_,_> ccc ( (f o (CCC.○ ccc b)) o CCC.π' ccc ) (id1 A b o CCC.π' ccc) )
|
|
227 ≈⟨ IsCCC.*-cong ( CCC.isCCC ccc ) (cdr ( IsCCC.π-cong ( CCC.isCCC ccc ) lemma idL )) ⟩
|
|
228 CCC._* ccc ( CCC.ε ccc o CCC.<_,_> ccc ( f o CCC.π ccc ) (CCC.π' ccc) )
|
|
229 ≈⟨ IsCCC.e4b (CCC.isCCC ccc) ⟩
|
|
230 f
|
|
231 ∎ where open ≈-Reasoning A
|
|
232 cong* : {f g : Hom A (CCC.1 ccc) ((ccc CCC.<= c) b)} →
|
|
233 A [ f ≈ g ] → A [ (A Category.o CCC.ε ccc) (CCC.< ccc , (A Category.o f) (CCC.○ ccc b) > (Category.Category.Id A))
|
|
234 ≈ (A Category.o CCC.ε ccc) (CCC.< ccc , (A Category.o g) (CCC.○ ccc b) > (Category.Category.Id A)) ]
|
|
235 cong* {f} {g} f≈g = begin
|
|
236 CCC.ε ccc o ( CCC.<_,_> ccc ( f o ( CCC.○ ccc b )) (id1 A b ))
|
|
237 ≈⟨ cdr (IsCCC.π-cong ( CCC.isCCC ccc ) (car f≈g) refl-hom ) ⟩
|
|
238 CCC.ε ccc o ( CCC.<_,_> ccc ( g o ( CCC.○ ccc b )) (id1 A b ))
|
|
239 ∎ where open ≈-Reasoning A
|
|
240 cong2 : {f g : Hom A b c} → A [ f ≈ g ] →
|
|
241 A [ (ccc CCC.*) ((A Category.o f) (CCC.π' ccc)) ≈ (ccc CCC.*) ((A Category.o g) (CCC.π' ccc)) ]
|
|
242 cong2 {f} {g} f≈g = begin
|
|
243 CCC._* ccc ( f o (CCC.π' ccc) )
|
|
244 ≈⟨ IsCCC.*-cong ( CCC.isCCC ccc ) (car f≈g ) ⟩
|
|
245 CCC._* ccc ( g o (CCC.π' ccc) )
|
|
246 ∎ where open ≈-Reasoning A
|
|
247
|
|
248
|
787
|
249
|
785
|
250
|
|
251 open CCChom
|
|
252 open IsCCChom
|
|
253 open IsoS
|
|
254
|
|
255 hom→CCC : {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( h : CCChom A ) → CCC A
|
|
256 hom→CCC A h = record {
|
|
257 1 = 1
|
|
258 ; ○ = ○
|
|
259 ; _∧_ = _/\_
|
|
260 ; <_,_> = <,>
|
|
261 ; π = π
|
|
262 ; π' = π'
|
|
263 ; _<=_ = _<=_
|
|
264 ; _* = _*
|
|
265 ; ε = ε
|
|
266 ; isCCC = isCCC
|
|
267 } where
|
|
268 1 : Obj A
|
|
269 1 = one h
|
|
270 ○ : (a : Obj A ) → Hom A a 1
|
|
271 ○ a = ≅← ( ccc-1 (isCCChom h ) {_} {OneObj} {OneObj} ) OneObj
|
|
272 _/\_ : Obj A → Obj A → Obj A
|
|
273 _/\_ a b = _*_ h a b
|
|
274 <,> : {a b c : Obj A } → Hom A c a → Hom A c b → Hom A c ( a /\ b)
|
|
275 <,> f g = ≅← ( ccc-2 (isCCChom h ) ) ( f , g )
|
|
276 π : {a b : Obj A } → Hom A (a /\ b) a
|
|
277 π {a} {b} = proj₁ ( ≅→ ( ccc-2 (isCCChom h ) ) (id1 A (_*_ h a b) ))
|
|
278 π' : {a b : Obj A } → Hom A (a /\ b) b
|
|
279 π' {a} {b} = proj₂ ( ≅→ ( ccc-2 (isCCChom h ) ) (id1 A (_*_ h a b) ))
|
|
280 _<=_ : (a b : Obj A ) → Obj A
|
|
281 _<=_ = _^_ h
|
|
282 _* : {a b c : Obj A } → Hom A (a /\ b) c → Hom A a (c <= b)
|
|
283 _* = ≅← ( ccc-3 (isCCChom h ) )
|
|
284 ε : {a b : Obj A } → Hom A ((a <= b ) /\ b) a
|
|
285 ε {a} {b} = ≅→ ( ccc-3 (isCCChom h ) {_^_ h a b} {b} ) (id1 A ( _^_ h a b ))
|
|
286 isCCC : CCC.IsCCC A 1 ○ _/\_ <,> π π' _<=_ _* ε
|
|
287 isCCC = record {
|
|
288 e2 = e2
|
|
289 ; e3a = e3a
|
|
290 ; e3b = e3b
|
|
291 ; e3c = e3c
|
|
292 ; π-cong = π-cong
|
|
293 ; e4a = e4a
|
|
294 ; e4b = e4b
|
787
|
295 ; *-cong = *-cong
|
785
|
296 } where
|
786
|
297 e20 : ∀ ( f : Hom OneCat OneObj OneObj ) → _[_≈_] OneCat {OneObj} {OneObj} f OneObj
|
|
298 e20 OneObj = refl
|
793
|
299 e2 : {a : Obj A} → ∀ { f : Hom A a 1 } → A [ f ≈ ○ a ]
|
|
300 e2 {a} {f} = begin
|
786
|
301 f
|
|
302 ≈↑⟨ iso← ( ccc-1 (isCCChom h )) ⟩
|
|
303 ≅← ( ccc-1 (isCCChom h ) {a} {OneObj} {OneObj}) ( ≅→ ( ccc-1 (isCCChom h ) {a} {OneObj} {OneObj} ) f )
|
|
304 ≈⟨ ≡-cong {Level.zero} {Level.zero} {Level.zero} {OneCat} {OneObj} {OneObj} (
|
|
305 λ y → ≅← ( ccc-1 (isCCChom h ) {a} {OneObj} {OneObj} ) y ) (e20 ( ≅→ ( ccc-1 (isCCChom h ) {a} {OneObj} {OneObj} ) f) ) ⟩
|
|
306 ≅← ( ccc-1 (isCCChom h ) {a} {OneObj} {OneObj} ) OneObj
|
|
307 ≈⟨⟩
|
|
308 ○ a
|
|
309 ∎ where open ≈-Reasoning A
|
787
|
310 --
|
|
311 -- g id
|
|
312 -- a -------------> b * c ------> b * c
|
|
313 --
|
|
314 -- a -------------> b * c ------> b
|
|
315 -- a -------------> b * c ------> c
|
|
316 --
|
|
317 cong-proj₁ : {a b c d : Obj A} → { f g : Hom (A × A) ( a , b ) ( c , d ) } → (A × A) [ f ≈ g ] → A [ proj₁ f ≈ proj₁ g ]
|
|
318 cong-proj₁ eq = proj₁ eq
|
788
|
319 cong-proj₂ : {a b c d : Obj A} → { f g : Hom (A × A) ( a , b ) ( c , d ) } → (A × A) [ f ≈ g ] → A [ proj₂ f ≈ proj₂ g ]
|
|
320 cong-proj₂ eq = proj₂ eq
|
785
|
321 e3a : {a b c : Obj A} → { f : Hom A c a }{ g : Hom A c b } → A [ A [ π o <,> f g ] ≈ f ]
|
786
|
322 e3a {a} {b} {c} {f} {g} = begin
|
|
323 π o <,> f g
|
|
324 ≈⟨⟩
|
|
325 proj₁ (≅→ (ccc-2 (isCCChom h)) (id1 A (_*_ h a b) )) o (≅← (ccc-2 (isCCChom h)) (f , g))
|
788
|
326 ≈⟨ cong-proj₁ (nat-2 (isCCChom h)) ⟩
|
787
|
327 proj₁ (≅→ (ccc-2 (isCCChom h)) (( id1 A ( _*_ h a b )) o ( ≅← (ccc-2 (isCCChom h)) (f , g) ) ))
|
|
328 ≈⟨ cong-proj₁ ( cong→ (ccc-2 (isCCChom h)) idL ) ⟩
|
|
329 proj₁ (≅→ (ccc-2 (isCCChom h)) ( ≅← (ccc-2 (isCCChom h)) (f , g) ))
|
|
330 ≈⟨ cong-proj₁ ( iso→ (ccc-2 (isCCChom h))) ⟩
|
786
|
331 proj₁ ( f , g )
|
|
332 ≈⟨⟩
|
|
333 f
|
|
334 ∎ where open ≈-Reasoning A
|
785
|
335 e3b : {a b c : Obj A} → { f : Hom A c a }{ g : Hom A c b } → A [ A [ π' o <,> f g ] ≈ g ]
|
788
|
336 e3b {a} {b} {c} {f} {g} = begin
|
|
337 π' o <,> f g
|
|
338 ≈⟨⟩
|
|
339 proj₂ (≅→ (ccc-2 (isCCChom h)) (id1 A (_*_ h a b) )) o (≅← (ccc-2 (isCCChom h)) (f , g))
|
|
340 ≈⟨ cong-proj₂ (nat-2 (isCCChom h)) ⟩
|
|
341 proj₂ (≅→ (ccc-2 (isCCChom h)) (( id1 A ( _*_ h a b )) o ( ≅← (ccc-2 (isCCChom h)) (f , g) ) ))
|
|
342 ≈⟨ cong-proj₂ ( cong→ (ccc-2 (isCCChom h)) idL ) ⟩
|
|
343 proj₂ (≅→ (ccc-2 (isCCChom h)) ( ≅← (ccc-2 (isCCChom h)) (f , g) ))
|
|
344 ≈⟨ cong-proj₂ ( iso→ (ccc-2 (isCCChom h))) ⟩
|
|
345 proj₂ ( f , g )
|
|
346 ≈⟨⟩
|
|
347 g
|
|
348 ∎ where open ≈-Reasoning A
|
785
|
349 e3c : {a b c : Obj A} → { h : Hom A c (a /\ b) } → A [ <,> ( A [ π o h ] ) ( A [ π' o h ] ) ≈ h ]
|
788
|
350 e3c {a} {b} {c} {f} = begin
|
|
351 <,> ( π o f ) ( π' o f )
|
|
352 ≈⟨⟩
|
|
353 ≅← (ccc-2 (isCCChom h)) ( ( proj₁ (≅→ (ccc-2 (isCCChom h)) (id1 A (_*_ h a b) ))) o f
|
|
354 , ( proj₂ (≅→ (ccc-2 (isCCChom h)) (id1 A (_*_ h a b)))) o f )
|
|
355 ≈⟨⟩
|
|
356 ≅← (ccc-2 (isCCChom h)) (_[_o_] (A × A) (≅→ (ccc-2 (isCCChom h)) (id1 A (_*_ h a b) )) (f , f ) )
|
|
357 ≈⟨ cong← (ccc-2 (isCCChom h)) (nat-2 (isCCChom h)) ⟩
|
|
358 ≅← (ccc-2 (isCCChom h)) (≅→ (ccc-2 (isCCChom h)) (id1 A (_*_ h a b) o f ))
|
|
359 ≈⟨ cong← (ccc-2 (isCCChom h)) (cong→ (ccc-2 (isCCChom h)) idL ) ⟩
|
|
360 ≅← (ccc-2 (isCCChom h)) (≅→ (ccc-2 (isCCChom h)) f )
|
|
361 ≈⟨ iso← (ccc-2 (isCCChom h)) ⟩
|
|
362 f
|
|
363 ∎ where open ≈-Reasoning A
|
785
|
364 π-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' ]
|
786
|
365 π-cong {a} {b} {c} {f} {f'} {g} {g'} eq1 eq2 = begin
|
|
366 <,> f g
|
|
367 ≈⟨⟩
|
|
368 ≅← (ccc-2 (isCCChom h)) (f , g)
|
787
|
369 ≈⟨ cong← (ccc-2 (isCCChom h)) ( eq1 , eq2 ) ⟩
|
786
|
370 ≅← (ccc-2 (isCCChom h)) (f' , g')
|
|
371 ≈⟨⟩
|
|
372 <,> f' g'
|
|
373 ∎ where open ≈-Reasoning A
|
|
374 e4a : {a b c : Obj A} → { k : Hom A (c /\ b) a } → A [ A [ ε o ( <,> ( A [ (k *) o π ] ) π') ] ≈ k ]
|
|
375 e4a {a} {b} {c} {k} = begin
|
|
376 ε o ( <,> ((k *) o π ) π' )
|
|
377 ≈⟨⟩
|
787
|
378 ≅→ (ccc-3 (isCCChom h)) (id1 A (_^_ h a b)) o (≅← (ccc-2 (isCCChom h)) ((( ≅← (ccc-3 (isCCChom h)) k) o π ) , π'))
|
789
|
379 ≈⟨ nat-3 (isCCChom h) ⟩
|
787
|
380 ≅→ (ccc-3 (isCCChom h)) (≅← (ccc-3 (isCCChom h)) k)
|
|
381 ≈⟨ iso→ (ccc-3 (isCCChom h)) ⟩
|
786
|
382 k
|
|
383 ∎ where open ≈-Reasoning A
|
785
|
384 e4b : {a b c : Obj A} → { k : Hom A c (a <= b ) } → A [ ( A [ ε o ( <,> ( A [ k o π ] ) π' ) ] ) * ≈ k ]
|
787
|
385 e4b {a} {b} {c} {k} = begin
|
|
386 ( ε o ( <,> ( k o π ) π' ) ) *
|
|
387 ≈⟨⟩
|
|
388 ≅← (ccc-3 (isCCChom h)) ( ≅→ ( ccc-3 (isCCChom h ) {_^_ h a b} {b} ) (id1 A ( _^_ h a b )) o (≅← (ccc-2 (isCCChom h)) ( k o π , π')))
|
789
|
389 ≈⟨ cong← (ccc-3 (isCCChom h)) (nat-3 (isCCChom h)) ⟩
|
787
|
390 ≅← (ccc-3 (isCCChom h)) (≅→ (ccc-3 (isCCChom h)) k)
|
|
391 ≈⟨ iso← (ccc-3 (isCCChom h)) ⟩
|
|
392 k
|
|
393 ∎ where open ≈-Reasoning A
|
|
394 *-cong : {a b c : Obj A} {f f' : Hom A (a /\ b) c} → A [ f ≈ f' ] → A [ f * ≈ f' * ]
|
|
395 *-cong eq = cong← ( ccc-3 (isCCChom h )) eq
|
785
|
396
|
790
|
397 open import Category.Sets
|
|
398
|
|
399 postulate extensionality : { c₁ c₂ ℓ : Level} ( A : Category c₁ c₂ ℓ ) → Relation.Binary.PropositionalEquality.Extensionality c₂ c₂
|
|
400
|
|
401 data One' {l : Level} : Set l where
|
|
402 OneObj' : One' -- () in Haskell ( or any one object set )
|
|
403
|
|
404 sets : {l : Level } → CCC (Sets {l})
|
|
405 sets {l} = record {
|
|
406 1 = One'
|
|
407 ; ○ = λ _ → λ _ → OneObj'
|
|
408 ; _∧_ = _/\_
|
|
409 ; <_,_> = <,>
|
|
410 ; π = π
|
|
411 ; π' = π'
|
|
412 ; _<=_ = _<=_
|
|
413 ; _* = _*
|
|
414 ; ε = ε
|
|
415 ; isCCC = isCCC
|
|
416 } where
|
|
417 1 : Obj Sets
|
|
418 1 = One'
|
|
419 ○ : (a : Obj Sets ) → Hom Sets a 1
|
|
420 ○ a = λ _ → OneObj'
|
|
421 _/\_ : Obj Sets → Obj Sets → Obj Sets
|
|
422 _/\_ a b = a ∧ b
|
|
423 <,> : {a b c : Obj Sets } → Hom Sets c a → Hom Sets c b → Hom Sets c ( a /\ b)
|
|
424 <,> f g = λ x → ( f x , g x )
|
|
425 π : {a b : Obj Sets } → Hom Sets (a /\ b) a
|
|
426 π {a} {b} = proj₁
|
|
427 π' : {a b : Obj Sets } → Hom Sets (a /\ b) b
|
|
428 π' {a} {b} = proj₂
|
|
429 _<=_ : (a b : Obj Sets ) → Obj Sets
|
|
430 a <= b = b → a
|
|
431 _* : {a b c : Obj Sets } → Hom Sets (a /\ b) c → Hom Sets a (c <= b)
|
|
432 f * = λ x → λ y → f ( x , y )
|
|
433 ε : {a b : Obj Sets } → Hom Sets ((a <= b ) /\ b) a
|
|
434 ε {a} {b} = λ x → ( proj₁ x ) ( proj₂ x )
|
|
435 isCCC : CCC.IsCCC Sets 1 ○ _/\_ <,> π π' _<=_ _* ε
|
|
436 isCCC = record {
|
|
437 e2 = e2
|
|
438 ; e3a = λ {a} {b} {c} {f} {g} → e3a {a} {b} {c} {f} {g}
|
|
439 ; e3b = λ {a} {b} {c} {f} {g} → e3b {a} {b} {c} {f} {g}
|
|
440 ; e3c = e3c
|
|
441 ; π-cong = π-cong
|
|
442 ; e4a = e4a
|
|
443 ; e4b = e4b
|
|
444 ; *-cong = *-cong
|
|
445 } where
|
793
|
446 e2 : {a : Obj Sets} {f : Hom Sets a 1} → Sets [ f ≈ ○ a ]
|
|
447 e2 {a} {f} = extensionality Sets ( λ x → e20 x )
|
790
|
448 where
|
|
449 e20 : (x : a ) → f x ≡ ○ a x
|
|
450 e20 x with f x
|
|
451 e20 x | OneObj' = refl
|
|
452 e3a : {a b c : Obj Sets} {f : Hom Sets c a} {g : Hom Sets c b} →
|
|
453 Sets [ ( Sets [ π o ( <,> f g) ] ) ≈ f ]
|
|
454 e3a = refl
|
|
455 e3b : {a b c : Obj Sets} {f : Hom Sets c a} {g : Hom Sets c b} →
|
|
456 Sets [ Sets [ π' o ( <,> f g ) ] ≈ g ]
|
|
457 e3b = refl
|
|
458 e3c : {a b c : Obj Sets} {h : Hom Sets c (a /\ b)} →
|
|
459 Sets [ <,> (Sets [ π o h ]) (Sets [ π' o h ]) ≈ h ]
|
|
460 e3c = refl
|
|
461 π-cong : {a b c : Obj Sets} {f f' : Hom Sets c a} {g g' : Hom Sets c b} →
|
|
462 Sets [ f ≈ f' ] → Sets [ g ≈ g' ] → Sets [ <,> f g ≈ <,> f' g' ]
|
|
463 π-cong refl refl = refl
|
|
464 e4a : {a b c : Obj Sets} {h : Hom Sets (c /\ b) a} →
|
|
465 Sets [ Sets [ ε o <,> (Sets [ h * o π ]) π' ] ≈ h ]
|
|
466 e4a = refl
|
|
467 e4b : {a b c : Obj Sets} {k : Hom Sets c (a <= b)} →
|
|
468 Sets [ (Sets [ ε o <,> (Sets [ k o π ]) π' ]) * ≈ k ]
|
|
469 e4b = refl
|
|
470 *-cong : {a b c : Obj Sets} {f f' : Hom Sets (a /\ b) c} →
|
|
471 Sets [ f ≈ f' ] → Sets [ f * ≈ f' * ]
|
|
472 *-cong refl = refl
|
787
|
473
|
|
474
|