annotate src/CCChom.agda @ 970:72b6b4577911

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