Mercurial > hg > Members > kono > Proof > category
annotate src/freyd1.agda @ 1124:f683d96fbc93 default tip
safe fix done
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sun, 07 Jul 2024 22:28:50 +0900 |
parents | 5620d4a85069 |
children |
rev | line source |
---|---|
1110
45de2b31bf02
add original library and fix for safe mode
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
949
diff
changeset
|
1 {-# OPTIONS --cubical-compatible --safe #-} |
45de2b31bf02
add original library and fix for safe mode
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
949
diff
changeset
|
2 |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
3 open import Category -- https://github.com/konn/category-agda |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
4 open import Level |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
5 |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
6 module freyd1 {c₁ c₂ ℓ c₁' c₂' ℓ' : Level} {A : Category c₁ c₂ ℓ} {C : Category c₁' c₂' ℓ'} |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
7 ( F : Functor A C ) ( G : Functor A C ) where |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
8 |
1110
45de2b31bf02
add original library and fix for safe mode
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
949
diff
changeset
|
9 open import Definitions |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
10 open import HomReasoning |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
11 open Functor |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
12 |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
13 open import Comma1 F G |
492 | 14 -- open import freyd CommaCategory -- we don't need this yet |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
15 |
492 | 16 open import Category.Cat -- Functor composition |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
17 open NTrans |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
18 open Complete |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
19 open CommaObj |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
20 open CommaHom |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
21 open Limit |
487 | 22 open IsLimit |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
23 |
493
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
24 -- |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
25 -- |
483 | 26 -- F : A → C |
27 -- G : A → C | |
28 -- | |
493
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
29 -- if A is complete and G preserve limit, Comma Category F↓G is complete |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
30 -- i.e. it has limit for Γ : I → F↓G |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
31 -- |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
32 -- |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
33 -- |
483 | 34 |
493
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
35 --- Get a functor Functor I A from a functor I CommaCategory |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
36 --- |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
37 FIA : { I : Category c₁ c₂ ℓ } → ( Γ : Functor I CommaCategory ) → Functor I A |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
38 FIA {I} Γ = record { |
482 | 39 FObj = λ x → obj (FObj Γ x ) ; |
40 FMap = λ {a} {b} f → arrow (FMap Γ f ) ; | |
41 isFunctor = record { | |
42 identity = identity | |
43 ; distr = IsFunctor.distr (isFunctor Γ) | |
44 ; ≈-cong = IsFunctor.≈-cong (isFunctor Γ) | |
45 }} where | |
46 identity : {x : Obj I } → A [ arrow (FMap Γ (id1 I x)) ≈ id1 A (obj (FObj Γ x)) ] | |
47 identity {x} = let open ≈-Reasoning (A) in begin | |
48 arrow (FMap Γ (id1 I x)) | |
49 ≈⟨ IsFunctor.identity (isFunctor Γ) ⟩ | |
50 id1 A (obj (FObj Γ x)) | |
51 ∎ | |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
52 |
493
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
53 --- Get a nat on A from a nat on CommaCategory |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
54 -- |
491
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
55 NIA : { I : Category c₁ c₂ ℓ } → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
56 (c : Obj CommaCategory ) ( ta : NTrans I CommaCategory ( K I CommaCategory c ) Γ ) → NTrans I A ( K I A (obj c) ) (FIA Γ) |
491
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
57 NIA {I} Γ c ta = record { |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
58 TMap = λ x → arrow (TMap ta x ) |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
59 ; isNTrans = record { commute = comm1 } |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
60 } where |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
61 comm1 : {a b : Obj I} {f : Hom I a b} → |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
62 A [ A [ FMap (FIA Γ) f o arrow (TMap ta a) ] ≈ A [ arrow (TMap ta b) o FMap (K I A (obj c)) f ] ] |
491
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
63 comm1 {a} {b} {f} = IsNTrans.commute (isNTrans ta ) |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
64 |
485 | 65 |
487 | 66 open LimitPreserve |
483 | 67 |
493
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
68 -- Limit on A from Γ : I → CommaCategory |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
69 -- |
1115
5620d4a85069
safe rewriting nearly finished
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1110
diff
changeset
|
70 LimitC : { I : Category c₁ c₂ ℓ } → ( comp : Complete {c₁} {c₂} {ℓ} A ) |
485 | 71 → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
72 → ( glimit : LimitPreserve I A C G ) |
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
73 → Limit I C (G ○ (FIA Γ)) |
492 | 74 LimitC {I} comp Γ glimit = plimit glimit (climit comp (FIA Γ)) |
486
56cf6581c5f6
add some lemma but no use
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
485
diff
changeset
|
75 |
1115
5620d4a85069
safe rewriting nearly finished
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1110
diff
changeset
|
76 tu : { I : Category c₁ c₂ ℓ } → ( comp : Complete {c₁} {c₂} {ℓ} A ) → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
77 → NTrans I C (K I C (FObj F (limit-c comp (FIA Γ)))) (G ○ (FIA Γ)) |
489 | 78 tu {I} comp Γ = record { |
493
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
79 TMap = λ i → C [ hom ( FObj Γ i ) o FMap F ( TMap (t0 ( climit comp (FIA Γ))) i) ] |
489 | 80 ; isNTrans = record { commute = λ {a} {b} {f} → commute {a} {b} {f} } |
81 } where | |
82 commute : {a b : Obj I} {f : Hom I a b} → | |
496 | 83 C [ C [ FMap (G ○ (FIA Γ)) f o C [ hom (FObj Γ a) o FMap F (TMap (t0 ( climit comp (FIA Γ))) a) ] ] |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
84 ≈ C [ C [ hom (FObj Γ b) o FMap F (TMap (t0 ( climit comp (FIA Γ))) b) ] o FMap (K I C (FObj F (limit-c comp (FIA Γ)))) f ] ] |
489 | 85 commute {a} {b} {f} = let open ≈-Reasoning (C) in begin |
496 | 86 FMap (G ○ (FIA Γ)) f o ( hom (FObj Γ a) o FMap F (TMap (t0 ( climit comp (FIA Γ))) a )) |
488
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
87 ≈⟨⟩ |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
88 FMap G (arrow (FMap Γ f ) ) o ( hom (FObj Γ a) o FMap F ( TMap (t0 ( climit comp (FIA Γ))) a )) |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
89 ≈⟨ assoc ⟩ |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
90 (FMap G (arrow (FMap Γ f ) ) o hom (FObj Γ a)) o FMap F ( TMap (t0 ( climit comp (FIA Γ))) a ) |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
91 ≈⟨ car ( comm (FMap Γ f)) ⟩ |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
92 (hom (FObj Γ b) o FMap F (arrow (FMap Γ f)) ) o FMap F ( TMap (t0 ( climit comp (FIA Γ))) a ) |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
93 ≈↑⟨ assoc ⟩ |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
94 hom (FObj Γ b) o ( FMap F (arrow (FMap Γ f)) o FMap F ( TMap (t0 ( climit comp (FIA Γ))) a ) ) |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
95 ≈↑⟨ cdr (distr F) ⟩ |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
96 hom (FObj Γ b) o ( FMap F (A [ arrow (FMap Γ f) o TMap (t0 ( climit comp (FIA Γ))) a ] ) ) |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
97 ≈⟨⟩ |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
98 hom (FObj Γ b) o ( FMap F (A [ FMap (FIA Γ) f o TMap (t0 ( climit comp (FIA Γ))) a ] ) ) |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
99 ≈⟨ cdr ( fcong F ( IsNTrans.commute (isNTrans (t0 ( climit comp (FIA Γ))) ))) ⟩ |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
100 hom (FObj Γ b) o ( FMap F ( A [ (TMap (t0 ( climit comp (FIA Γ))) b) o FMap (K I A (a0 (climit comp (FIA Γ)))) f ] )) |
488
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
101 ≈⟨⟩ |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
102 hom (FObj Γ b) o ( FMap F ( A [ (TMap (t0 ( climit comp (FIA Γ))) b) o id1 A (limit-c comp (FIA Γ)) ] )) |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
103 ≈⟨ cdr ( distr F ) ⟩ |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
104 hom (FObj Γ b) o ( FMap F (TMap (t0 ( climit comp (FIA Γ))) b) o FMap F (id1 A (limit-c comp (FIA Γ)))) |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
105 ≈⟨ cdr ( cdr ( IsFunctor.identity (isFunctor F) ) ) ⟩ |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
106 hom (FObj Γ b) o ( FMap F (TMap (t0 ( climit comp (FIA Γ))) b) o id1 C (FObj F (limit-c comp (FIA Γ)))) |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
107 ≈⟨ assoc ⟩ |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
108 ( hom (FObj Γ b) o FMap F (TMap (t0 ( climit comp (FIA Γ))) b)) o FMap (K I C (FObj F (limit-c comp (FIA Γ)))) f |
488
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
109 ∎ |
1115
5620d4a85069
safe rewriting nearly finished
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1110
diff
changeset
|
110 limitHom : { I : Category c₁ c₂ ℓ } → (comp : Complete {c₁} {c₂} {ℓ} A ) → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
111 → ( glimit : LimitPreserve I A C G ) → Hom C (FObj F (limit-c comp (FIA Γ ) )) (FObj G (limit-c comp (FIA Γ) )) |
489 | 112 limitHom comp Γ glimit = limit (isLimit (LimitC comp Γ glimit )) (FObj F ( limit-c comp (FIA Γ))) (tu comp Γ ) |
113 | |
1115
5620d4a85069
safe rewriting nearly finished
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1110
diff
changeset
|
114 commaLimit : { I : Category c₁ c₂ ℓ } → ( Complete {c₁} {c₂} {ℓ} A ) → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
115 → ( glimit : LimitPreserve I A C G ) |
489 | 116 → Obj CommaCategory |
117 commaLimit {I} comp Γ glimit = record { | |
118 obj = limit-c comp (FIA Γ) | |
119 ; hom = limitHom comp Γ glimit | |
120 } | |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
121 |
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
122 |
1115
5620d4a85069
safe rewriting nearly finished
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1110
diff
changeset
|
123 commaNat : { I : Category c₁ c₂ ℓ } → ( comp : Complete {c₁} {c₂} {ℓ} A ) → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
124 → ( glimit : LimitPreserve I A C G ) |
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
125 → NTrans I CommaCategory (K I CommaCategory (commaLimit {I} comp Γ glimit)) Γ |
488
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
126 commaNat {I} comp Γ glimit = record { |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
127 TMap = λ x → record { |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
128 arrow = TMap ( limit-u comp (FIA Γ ) ) x |
489 | 129 ; comm = comm1 x |
488
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
130 } |
489 | 131 ; isNTrans = record { commute = comm2 } |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
132 } where |
488
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
133 comm1 : (x : Obj I ) → |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
134 C [ C [ FMap G (TMap (limit-u comp (FIA Γ)) x) o hom (FObj (K I CommaCategory (commaLimit comp Γ glimit)) x) ] |
488
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
135 ≈ C [ hom (FObj Γ x) o FMap F (TMap (limit-u comp (FIA Γ)) x) ] ] |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
136 comm1 x = let open ≈-Reasoning (C) in begin |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
137 FMap G (TMap (limit-u comp (FIA Γ)) x) o hom (FObj (K I CommaCategory (commaLimit comp Γ glimit)) x) |
489 | 138 ≈⟨⟩ |
139 FMap G (TMap (limit-u comp (FIA Γ)) x) o hom (commaLimit comp Γ glimit) | |
140 ≈⟨⟩ | |
141 FMap G (TMap (limit-u comp (FIA Γ)) x) o limit (isLimit (LimitC comp Γ glimit )) (FObj F ( limit-c comp (FIA Γ))) (tu comp Γ ) | |
142 ≈⟨⟩ | |
143 TMap (t0 ( LimitC comp Γ glimit )) x o limit (isLimit (LimitC comp Γ glimit )) (FObj F ( limit-c comp (FIA Γ))) (tu comp Γ ) | |
144 ≈⟨ t0f=t ( isLimit ( LimitC comp Γ glimit ) ) ⟩ | |
145 TMap (tu comp Γ) x | |
146 ≈⟨⟩ | |
147 hom (FObj Γ x) o FMap F (TMap (limit-u comp (FIA Γ)) x) | |
148 ∎ | |
149 comm2 : {a b : Obj I} {f : Hom I a b} → | |
150 CommaCategory [ CommaCategory [ FMap Γ f o record { arrow = TMap (limit-u comp (FIA Γ)) a ; comm = comm1 a } ] | |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
151 ≈ CommaCategory [ record { arrow = TMap (limit-u comp (FIA Γ)) b ; comm = comm1 b } o FMap (K I CommaCategory (commaLimit comp Γ glimit)) f ] ] |
490 | 152 comm2 {a} {b} {f} = let open ≈-Reasoning (A) in begin |
153 FMap (FIA Γ) f o TMap (limit-u comp (FIA Γ)) a | |
154 ≈⟨ IsNTrans.commute (isNTrans (limit-u comp (FIA Γ))) ⟩ | |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
155 TMap (limit-u comp (FIA Γ)) b o FMap (K I A (limit-c comp (FIA Γ))) f |
489 | 156 ∎ |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
157 |
495 | 158 gnat : { I : Category c₁ c₂ ℓ } → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
159 → (a : CommaObj) → ( t : NTrans I CommaCategory (K I CommaCategory a) Γ ) → |
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
160 NTrans I C (K I C (FObj F (obj a))) (G ○ FIA Γ) |
495 | 161 gnat {I} Γ a t = record { |
494
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
162 TMap = λ i → C [ hom ( FObj Γ i ) o FMap F ( TMap (NIA Γ a t) i ) ] |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
163 ; isNTrans = record { commute = λ {x y f} → comm1 x y f } |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
164 } where |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
165 comm1 : (x y : Obj I) (f : Hom I x y ) → |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
166 C [ C [ FMap (G ○ FIA Γ) f o C [ hom (FObj Γ x) o FMap F (TMap (NIA Γ a t) x) ] ] |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
167 ≈ C [ C [ hom (FObj Γ y) o FMap F (TMap (NIA Γ a t) y) ] o FMap (K I C (FObj F (obj a))) f ] ] |
494
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
168 comm1 x y f = let open ≈-Reasoning (C) in begin |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
169 FMap (G ○ FIA Γ) f o ( hom (FObj Γ x) o FMap F (TMap (NIA Γ a t) x )) |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
170 ≈⟨⟩ |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
171 FMap G (FMap (FIA Γ) f) o ( hom (FObj Γ x) o FMap F (TMap (NIA Γ a t) x )) |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
172 ≈⟨ assoc ⟩ |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
173 (FMap G (FMap (FIA Γ) f) o ( hom (FObj Γ x))) o FMap F (TMap (NIA Γ a t) x ) |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
174 ≈⟨ car ( comm (FMap Γ f) ) ⟩ |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
175 ( hom (FObj Γ y) o FMap F (FMap (FIA Γ) f )) o FMap F (TMap (NIA Γ a t) x ) |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
176 ≈↑⟨ assoc ⟩ |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
177 hom (FObj Γ y) o ( FMap F (FMap (FIA Γ) f ) o FMap F (TMap (NIA Γ a t) x )) |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
178 ≈↑⟨ cdr (distr F) ⟩ |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
179 hom (FObj Γ y) o ( FMap F ( A [ FMap (FIA Γ) f o TMap (NIA Γ a t) x ]) ) |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
180 ≈⟨ cdr ( fcong F ( IsNTrans.commute ( isNTrans ( NIA Γ a t )))) ⟩ |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
181 hom (FObj Γ y) o ( FMap F ( A [ TMap (NIA Γ a t) y o id1 A (obj a) ]) ) |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
182 ≈⟨ cdr ( fcong F ( IsCategory.identityR (Category.isCategory A))) ⟩ |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
183 hom (FObj Γ y) o FMap F (TMap (NIA Γ a t) y) |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
184 ≈↑⟨ idR ⟩ |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
185 ( hom (FObj Γ y) o FMap F (TMap (NIA Γ a t) y) ) o FMap (K I C (FObj F (obj a))) f |
494
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
186 ∎ |
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
187 |
493
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
188 |
1115
5620d4a85069
safe rewriting nearly finished
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1110
diff
changeset
|
189 comma-a0 : { I : Category c₁ c₂ ℓ } → ( comp : Complete {c₁} {c₂} {ℓ} A ) → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
190 → ( glimit : LimitPreserve I A C G ) (a : CommaObj) → ( t : NTrans I CommaCategory (K I CommaCategory a) Γ ) → Hom CommaCategory a (commaLimit comp Γ glimit) |
491
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
191 comma-a0 {I} comp Γ glimit a t = record { |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
192 arrow = limit (isLimit ( climit comp (FIA Γ) ) ) (obj a ) (NIA {I} Γ a t ) |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
193 ; comm = comm1 |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
194 } where |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
195 comm1 : C [ C [ FMap G (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) o hom a ] |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
196 ≈ C [ hom (commaLimit comp Γ glimit) o FMap F (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) ] ] |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
197 comm1 = let open ≈-Reasoning (C) in begin |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
198 FMap G (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) o hom a |
495 | 199 ≈↑⟨ limit-uniqueness (isLimit (LimitC comp Γ glimit )) ( λ {i} → begin |
200 TMap (t0 (LimitC comp Γ glimit)) i o ( FMap G (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) o hom a ) | |
201 ≈⟨ assoc ⟩ | |
202 ( TMap (t0 (LimitC comp Γ glimit)) i o FMap G (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t))) o hom a | |
203 ≈⟨⟩ | |
204 ( FMap G ( TMap (limit-u comp (FIA Γ )) i ) o FMap G (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t))) o hom a | |
205 ≈↑⟨ car ( distr G ) ⟩ | |
206 FMap G ( A [ TMap (limit-u comp (FIA Γ )) i o limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t) ] ) o hom a | |
207 ≈⟨ car ( fcong G ( t0f=t (isLimit (climit comp (FIA Γ ))))) ⟩ | |
208 FMap G (arrow (TMap t i)) o hom a | |
209 ≈⟨ comm ( TMap t i) ⟩ | |
210 hom ( FObj Γ i ) o FMap F ( TMap (NIA Γ a t) i ) | |
211 ≈⟨⟩ | |
212 TMap (gnat Γ a t) i | |
213 ∎ | |
214 ) ⟩ | |
215 limit (isLimit (LimitC comp Γ glimit )) (FObj F (obj a)) (gnat Γ a t ) | |
216 ≈⟨ limit-uniqueness (isLimit (LimitC comp Γ glimit )) ( λ {i} → begin | |
493
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
217 TMap (t0 (LimitC comp Γ glimit )) i o |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
218 ( limit (isLimit (LimitC comp Γ glimit )) (FObj F ( limit-c comp (FIA Γ))) (tu comp Γ ) |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
219 o FMap F (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) ) |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
220 ≈⟨ assoc ⟩ |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
221 ( TMap (t0 (LimitC comp Γ glimit )) i o |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
222 ( limit (isLimit (LimitC comp Γ glimit )) (FObj F ( limit-c comp (FIA Γ))) (tu comp Γ ) )) |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
223 o FMap F (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
224 ≈⟨ car ( t0f=t ( isLimit (LimitC comp Γ glimit )) ) ⟩ |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
225 TMap (tu comp Γ ) i o FMap F (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
226 ≈⟨⟩ |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
227 ( hom ( FObj Γ i ) o FMap F ( TMap (t0 ( climit comp (FIA Γ))) i) ) |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
228 o FMap F (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
229 ≈↑⟨ assoc ⟩ |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
230 hom ( FObj Γ i ) o |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
231 ((FMap F ( TMap (t0 ( climit comp (FIA Γ))) i) ) o FMap F (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) ) |
659 | 232 ≈↑⟨ cdr ( distr F) ⟩ |
493
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
233 hom ( FObj Γ i ) o |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
234 FMap F ( A [ TMap (t0 ( climit comp (FIA Γ))) i o limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t) ] ) |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
235 ≈⟨ cdr ( fcong F ( t0f=t (isLimit (climit comp (FIA Γ))))) ⟩ |
494
ba6a67523523
unique direction 2 done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
493
diff
changeset
|
236 hom ( FObj Γ i ) o FMap F ( TMap (NIA Γ a t) i ) |
495 | 237 ≈⟨⟩ |
238 TMap (gnat Γ a t ) i | |
493
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
239 ∎ |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
240 ) ⟩ |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
241 limit (isLimit (LimitC comp Γ glimit )) (FObj F ( limit-c comp (FIA Γ))) (tu comp Γ ) |
de9ce7e0d97c
on going using limit-uniquness directly
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
492
diff
changeset
|
242 o FMap F (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) |
491
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
243 ≈⟨⟩ |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
244 hom (commaLimit comp Γ glimit) o FMap F (limit (isLimit (climit comp (FIA Γ))) (obj a) (NIA Γ a t)) |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
245 ∎ |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
246 |
1115
5620d4a85069
safe rewriting nearly finished
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1110
diff
changeset
|
247 comma-t0f=t : { I : Category c₁ c₂ ℓ } → ( comp : Complete {c₁} {c₂} {ℓ} A ) → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
248 → ( glimit : LimitPreserve I A C G ) (a : CommaObj) → ( t : NTrans I CommaCategory (K I CommaCategory a) Γ ) (i : Obj I ) |
491
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
249 → CommaCategory [ CommaCategory [ TMap (commaNat comp Γ glimit) i o comma-a0 comp Γ glimit a t ] ≈ TMap t i ] |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
250 comma-t0f=t {I} comp Γ glimit a t i = let open ≈-Reasoning (A) in begin |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
251 TMap ( limit-u comp (FIA Γ ) ) i o limit (isLimit ( climit comp (FIA Γ) ) ) (obj a ) (NIA {I} Γ a t ) |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
252 ≈⟨ t0f=t (isLimit ( climit comp (FIA Γ) ) ) ⟩ |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
253 TMap (NIA {I} Γ a t ) i |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
254 ∎ |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
255 |
1115
5620d4a85069
safe rewriting nearly finished
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1110
diff
changeset
|
256 comma-uniqueness : { I : Category c₁ c₂ ℓ } → ( comp : Complete {c₁} {c₂} {ℓ} A ) → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
257 → ( glimit : LimitPreserve I A C G ) (a : CommaObj) → ( t : NTrans I CommaCategory (K I CommaCategory a) Γ ) |
491
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
258 → ( f : Hom CommaCategory a (commaLimit comp Γ glimit)) |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
259 → ( ∀ { i : Obj I } → CommaCategory [ CommaCategory [ TMap ( commaNat { I} comp Γ glimit ) i o f ] ≈ TMap t i ] ) |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
260 → CommaCategory [ comma-a0 comp Γ glimit a t ≈ f ] |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
261 comma-uniqueness {I} comp Γ glimit a t f t=f = let open ≈-Reasoning (A) in begin |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
262 limit (isLimit ( climit comp (FIA Γ) ) ) (obj a ) (NIA {I} Γ a t ) |
495 | 263 ≈⟨ limit-uniqueness (isLimit ( climit comp (FIA Γ) ) ) t=f ⟩ |
491
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
264 arrow f |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
265 ∎ |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
266 |
1115
5620d4a85069
safe rewriting nearly finished
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1110
diff
changeset
|
267 hasLimit : { I : Category c₁ c₂ ℓ } → ( comp : Complete {c₁} {c₂} {ℓ} A ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
268 → ( glimit : LimitPreserve I A C G ) |
485 | 269 → ( Γ : Functor I CommaCategory ) |
691
917e51be9bbf
change argument of Limit and K
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
659
diff
changeset
|
270 → Limit I CommaCategory Γ |
485 | 271 hasLimit {I} comp glimit Γ = record { |
488
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
272 a0 = commaLimit {I} comp Γ glimit ; |
016087cfa75a
commaLimit done, commaNat trying..
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
487
diff
changeset
|
273 t0 = commaNat { I} comp Γ glimit ; |
487 | 274 isLimit = record { |
491
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
275 limit = λ a t → comma-a0 comp Γ glimit a t ; |
04da2c458d44
comma-a0 commuativity remains
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
490
diff
changeset
|
276 t0f=t = λ {a t i } → comma-t0f=t comp Γ glimit a t i ; |
495 | 277 limit-uniqueness = λ {a} {t} {f} t=f → comma-uniqueness {I} comp Γ glimit a t f t=f |
487 | 278 } |
481
65e6906782bb
Completeness of Comma Category begin
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
279 } |