Mercurial > hg > Members > kono > Proof > category
comparison CCChom.agda @ 785:a67959bcd44b
ccc → hom on going
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Wed, 17 Apr 2019 21:32:56 +0900 |
parents | f27d966939f8 |
children | 287d25c87b60 |
comparison
equal
deleted
inserted
replaced
784:f27d966939f8 | 785:a67959bcd44b |
---|---|
12 | 12 |
13 -- ccc-1 : Hom A a 1 ≅ {*} | 13 -- ccc-1 : Hom A a 1 ≅ {*} |
14 -- ccc-2 : Hom A c (a × b) ≅ (Hom A c a ) × ( Hom A c b ) | 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 | 15 -- ccc-3 : Hom A a (c ^ b) ≅ Hom A (a × b) c |
16 | 16 |
17 data One {c : Level} : Set c where | 17 data One : Set where |
18 OneObj : One -- () in Haskell ( or any one object set ) | 18 OneObj : One -- () in Haskell ( or any one object set ) |
19 | 19 |
20 OneCat : Category Level.zero Level.zero Level.zero | 20 OneCat : Category Level.zero Level.zero Level.zero |
21 OneCat = record { | 21 OneCat = record { |
22 Obj = One ; | 22 Obj = One ; |
30 identityR = λ{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 ; | 31 o-resp-≈ = λ{a b c f g h i} _ _ → refl ; |
32 associative = λ{a b c d f g h } → refl | 32 associative = λ{a b c d f g h } → refl |
33 } | 33 } |
34 } where | 34 } where |
35 lemma : {a b : One {Level.zero}} → { f : One {Level.zero}} → OneObj ≡ f | 35 lemma : {a b : One } → { f : One } → OneObj ≡ f |
36 lemma {a} {b} {f} with f | 36 lemma {a} {b} {f} with f |
37 ... | OneObj = refl | 37 ... | OneObj = refl |
38 | 38 |
39 record IsoS {c₁ c₂ ℓ c₁' c₂' ℓ' : Level} (A : Category c₁ c₂ ℓ) (B : Category c₁' c₂' ℓ') (a b : Obj A) ( a' b' : Obj B ) | 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 | 40 : Set ( c₁ ⊔ c₂ ⊔ ℓ ⊔ c₁' ⊔ c₂' ⊔ ℓ' ) where |
46 | 46 |
47 | 47 |
48 record IsCCChom {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) (1 : Obj A) | 48 record IsCCChom {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) (1 : Obj A) |
49 ( _*_ : Obj A → Obj A → Obj A ) ( _^_ : Obj A → Obj A → Obj A ) : Set ( c₁ ⊔ c₂ ⊔ ℓ ) where | 49 ( _*_ : Obj A → Obj A → Obj A ) ( _^_ : Obj A → Obj A → Obj A ) : Set ( c₁ ⊔ c₂ ⊔ ℓ ) where |
50 field | 50 field |
51 ccc-1 : {a : Obj A} → -- Hom A a 1 ≅ {*} | 51 ccc-1 : {a : Obj A} {b c : Obj OneCat} → -- Hom A a 1 ≅ {*} |
52 IsoS A OneCat a 1 OneObj OneObj | 52 IsoS A OneCat a 1 b c |
53 ccc-2 : {a b c : Obj A} → -- Hom A c ( a * b ) ≅ ( Hom A c a ) * ( Hom A c b ) | 53 ccc-2 : {a b c : Obj A} → -- Hom A c ( a * b ) ≅ ( Hom A c a ) * ( Hom A c b ) |
54 IsoS A (A × A) c (a * b) (c , c ) (a , b ) | 54 IsoS A (A × A) c (a * b) (c , c ) (a , b ) |
55 ccc-3 : {a b c : Obj A} → -- Hom A a ( c ^ b ) ≅ Hom A ( a * b ) c | 55 ccc-3 : {a b c : Obj A} → -- Hom A a ( c ^ b ) ≅ Hom A ( a * b ) c |
56 IsoS A A a (c ^ b) (a * b) c | 56 IsoS A A a (c ^ b) (a * b) c |
57 | 57 |
71 CCC→hom A c = record { | 71 CCC→hom A c = record { |
72 one = CCC.1 c | 72 one = CCC.1 c |
73 ; _*_ = CCC._∧_ c | 73 ; _*_ = CCC._∧_ c |
74 ; _^_ = CCC._<=_ c | 74 ; _^_ = CCC._<=_ c |
75 ; isCCChom = record { | 75 ; isCCChom = record { |
76 ccc-1 = {!!} | 76 ccc-1 = λ {a} {b} {c'} → record { ≅→ = c101 ; ≅← = c102 ; iso→ = c103 {a} {b} {c'} ; iso← = c104 } |
77 ; ccc-2 = {!!} | 77 ; ccc-2 = record { ≅→ = c201 ; ≅← = c202 ; iso→ = c203 ; iso← = c204 } |
78 ; ccc-3 = {!!} | 78 ; ccc-3 = record { ≅→ = c301 ; ≅← = c302 ; iso→ = c303 ; iso← = c304 } |
79 } | 79 } |
80 } | 80 } where |
81 c101 : {a : Obj A} → Hom A a (CCC.1 c) → Hom OneCat OneObj OneObj | |
82 c101 _ = OneObj | |
83 c102 : {a : Obj A} → Hom OneCat OneObj OneObj → Hom A a (CCC.1 c) | |
84 c102 {a} OneObj = CCC.○ c a | |
85 c103 : {a : Obj A } {b c : Obj OneCat} {f : Hom OneCat b b } → _[_≈_] OneCat {b} {c} ( c101 {a} (c102 {a} f) ) f | |
86 c103 {a} {OneObj} {OneObj} {OneObj} = refl | |
87 c104 : {a : Obj A} → {f : Hom A a (CCC.1 c)} → A [ (c102 ( c101 f )) ≈ f ] | |
88 c104 {a} {f} = let open ≈-Reasoning A in HomReasoning.≈-Reasoning.sym A (IsCCC.e2 (CCC.isCCC c) f ) | |
89 c201 : { c₁ a b : Obj A} → Hom A c₁ ((c CCC.∧ a) b) → Hom (A × A) (c₁ , c₁) (a , b) | |
90 c201 f = ( A [ CCC.π c o f ] , A [ CCC.π' c o f ] ) | |
91 c202 : { c₁ a b : Obj A} → Hom (A × A) (c₁ , c₁) (a , b) → Hom A c₁ ((c CCC.∧ a) b) | |
92 c202 (f , g ) = CCC.<_,_> c f g | |
93 c203 : { c₁ a b : Obj A} → {f : Hom (A × A) (c₁ , c₁) (a , b)} → (A × A) [ (c201 ( c202 f )) ≈ f ] | |
94 c203 = ( IsCCC.e3a (CCC.isCCC c) , IsCCC.e3b (CCC.isCCC c)) | |
95 c204 : { c₁ a b : Obj A} → {f : Hom A c₁ ((c CCC.∧ a) b)} → A [ (c202 ( c201 f )) ≈ f ] | |
96 c204 = IsCCC.e3c (CCC.isCCC c) | |
97 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 | |
98 c301 {d} {a} {b} f = A [ CCC.ε c o CCC.<_,_> c ( A [ f o CCC.π c ] ) ( CCC.π' c ) ] | |
99 c302 : { d a b : Obj A} → Hom A ((c CCC.∧ a) b) d → Hom A a ((c CCC.<= d) b) | |
100 c302 f = CCC._* c f | |
101 c303 : { c₁ a b : Obj A} → {f : Hom A ((c CCC.∧ a) b) c₁} → A [ (c301 ( c302 f )) ≈ f ] | |
102 c303 = IsCCC.e4a (CCC.isCCC c) | |
103 c304 : { c₁ a b : Obj A} → {f : Hom A a ((c CCC.<= c₁) b)} → A [ (c302 ( c301 f )) ≈ f ] | |
104 c304 = IsCCC.e4b (CCC.isCCC c) | |
105 | |
106 open CCChom | |
107 open IsCCChom | |
108 open IsoS | |
109 | |
110 hom→CCC : {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( h : CCChom A ) → CCC A | |
111 hom→CCC A h = record { | |
112 1 = 1 | |
113 ; ○ = ○ | |
114 ; _∧_ = _/\_ | |
115 ; <_,_> = <,> | |
116 ; π = π | |
117 ; π' = π' | |
118 ; _<=_ = _<=_ | |
119 ; _* = _* | |
120 ; ε = ε | |
121 ; isCCC = isCCC | |
122 } where | |
123 1 : Obj A | |
124 1 = one h | |
125 ○ : (a : Obj A ) → Hom A a 1 | |
126 ○ a = ≅← ( ccc-1 (isCCChom h ) {_} {OneObj} {OneObj} ) OneObj | |
127 _/\_ : Obj A → Obj A → Obj A | |
128 _/\_ a b = _*_ h a b | |
129 <,> : {a b c : Obj A } → Hom A c a → Hom A c b → Hom A c ( a /\ b) | |
130 <,> f g = ≅← ( ccc-2 (isCCChom h ) ) ( f , g ) | |
131 π : {a b : Obj A } → Hom A (a /\ b) a | |
132 π {a} {b} = proj₁ ( ≅→ ( ccc-2 (isCCChom h ) ) (id1 A (_*_ h a b) )) | |
133 π' : {a b : Obj A } → Hom A (a /\ b) b | |
134 π' {a} {b} = proj₂ ( ≅→ ( ccc-2 (isCCChom h ) ) (id1 A (_*_ h a b) )) | |
135 _<=_ : (a b : Obj A ) → Obj A | |
136 _<=_ = _^_ h | |
137 _* : {a b c : Obj A } → Hom A (a /\ b) c → Hom A a (c <= b) | |
138 _* = ≅← ( ccc-3 (isCCChom h ) ) | |
139 ε : {a b : Obj A } → Hom A ((a <= b ) /\ b) a | |
140 ε {a} {b} = ≅→ ( ccc-3 (isCCChom h ) {_^_ h a b} {b} ) (id1 A ( _^_ h a b )) | |
141 isCCC : CCC.IsCCC A 1 ○ _/\_ <,> π π' _<=_ _* ε | |
142 isCCC = record { | |
143 e2 = e2 | |
144 ; e3a = e3a | |
145 ; e3b = e3b | |
146 ; e3c = e3c | |
147 ; π-cong = π-cong | |
148 ; e4a = e4a | |
149 ; e4b = e4b | |
150 } where | |
151 e2 : {a : Obj A} → ∀ ( f : Hom A a 1 ) → A [ f ≈ ○ a ] | |
152 e2 f = {!!} | |
153 e3a : {a b c : Obj A} → { f : Hom A c a }{ g : Hom A c b } → A [ A [ π o <,> f g ] ≈ f ] | |
154 e3a = {!!} | |
155 e3b : {a b c : Obj A} → { f : Hom A c a }{ g : Hom A c b } → A [ A [ π' o <,> f g ] ≈ g ] | |
156 e3b = {!!} | |
157 e3c : {a b c : Obj A} → { h : Hom A c (a /\ b) } → A [ <,> ( A [ π o h ] ) ( A [ π' o h ] ) ≈ h ] | |
158 e3c = {!!} | |
159 π-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' ] | |
160 π-cong = {!!} | |
161 e4a : {a b c : Obj A} → { h : Hom A (c /\ b) a } → A [ A [ ε o ( <,> ( A [ (h *) o π ] ) π') ] ≈ h ] | |
162 e4a = {!!} | |
163 e4b : {a b c : Obj A} → { k : Hom A c (a <= b ) } → A [ ( A [ ε o ( <,> ( A [ k o π ] ) π' ) ] ) * ≈ k ] | |
164 e4b = {!!} | |
165 |