diff src/CCCGraph.agda @ 991:e7848ad0c6f9

remove suc level in CCCGraph
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 06 Mar 2021 11:42:01 +0900
parents e2e11014b0f8
children c1576827404e
line wrap: on
line diff
--- a/src/CCCGraph.agda	Fri Mar 05 22:49:03 2021 +0900
+++ b/src/CCCGraph.agda	Sat Mar 06 11:42:01 2021 +0900
@@ -115,15 +115,19 @@
    open import Relation.Binary.PropositionalEquality renaming ( cong to ≡-cong ) hiding ( [_] )
    open Graph
 
-   data Objs : Set (suc c₁) where
-      atom : (vertex G) → Objs 
+   V = vertex G
+   E : V → V → Set c₂
+   E = edge G
+   
+   data Objs : Set c₁ where
+      atom : V → Objs 
       ⊤ : Objs 
-      _∧_ : Objs  → Objs  → Objs 
+      _∧_ : Objs  → Objs → Objs 
       _<=_ : Objs → Objs → Objs 
 
-   data  Arrows  : (b c : Objs ) → Set (suc c₁  ⊔  c₂)
-   data Arrow :  Objs → Objs → Set (suc c₁  ⊔ c₂)  where                       --- case i
-      arrow : {a b : vertex G} →  (edge G) a b → Arrow (atom a) (atom b)
+   data  Arrows  : (b c : Objs ) → Set (c₁  ⊔  c₂)
+   data Arrow :  Objs → Objs → Set (c₁  ⊔ c₂)  where                       --- case i
+      arrow : {a b : V} →  E a b → Arrow (atom a) (atom b)
       π : {a b : Objs } → Arrow ( a ∧ b ) a
       π' : {a b : Objs } → Arrow ( a ∧ b ) b
       ε : {a b : Objs } → Arrow ((a <= b) ∧ b ) a
@@ -159,7 +163,7 @@
    assoc≡ (iv f f1) g h = cong (λ k → iv f k ) ( assoc≡ f1 g h )
 
    -- positive intutionistic calculus
-   PL :  Category  (suc c₁) (suc c₁  ⊔ c₂) (suc c₁  ⊔ c₂)
+   PL :  Category  c₁ (c₁  ⊔ c₂) (c₁  ⊔ c₂)
    PL = record {
             Obj  = Objs;
             Hom = λ a b →  Arrows  a b ;
@@ -353,9 +357,9 @@
 
 --- Forgetful functor
 
-module forgetful {c₁ c₂ : Level} where
+module forgetful {c₁ : Level} where
 
-  ≃-cong : {c₁ c₂ ℓ : Level}  (B : Category c₁ c₂ ℓ ) → {a b a' b' : Obj B }
+  ≃-cong : {c₁ c₁ ℓ : Level}  (B : Category c₁ c₁ ℓ ) → {a b a' b' : Obj B }
       → { f f'   : Hom B a b }
       → { g g' : Hom B a' b' }
       → [_]_~_ B f g → B [ f ≈ f' ] → B [ g ≈ g' ] → [_]_~_ B f' g'
@@ -370,53 +374,36 @@
           ∎  )
 
   -- Grph does not allow morph on different level graphs
-  -- simply assumes we have iso to the another level. This may means same axiom on CCCs results the same CCCs.
-  postulate
-     g21 : Graph {suc c₁} {c₁ ⊔ c₂} → Graph {c₁} {c₂} 
-     m21 : (g : Graph {suc c₁ } {c₁ ⊔ c₂} )  → GMap  {suc c₁ } {c₁ ⊔ c₂} {c₁} {c₂} g (g21 g)
-     m12 : (g : Graph {suc c₁ } {c₁ ⊔ c₂} )  → GMap  {c₁} {c₂}  {suc c₁ } {c₁ ⊔ c₂} (g21 g) g
-     giso→  : { g : Graph {suc c₁ } {c₁ ⊔ c₂} }
-          → {a b : vertex g } →  (m12 g & m21 g) =m= id1 Grph g
-     giso←  : { g : Graph {suc c₁ } {c₁ ⊔ c₂} }
-          → {a b : vertex (g21 g) } →  (m21 g & m12 g ) =m= id1 Grph (g21 g)
-                -- Grph [ Grph [ m21 g o m12 g ] ≈ id1 Grph (g21 g) ]
+  -- simply assumes c₁ and c₂ has the same
   
-  uobj : Obj (Cart {suc c₁ } {c₁ ⊔ c₂} {c₁ ⊔ c₂}) → Obj Grph
+  uobj : Obj (Cart {c₁ } {c₁} {c₁}) → Obj Grph
   uobj a = record { vertex = Obj (cat a) ; edge = Hom (cat a) }
-  umap :  {a b : Obj (Cart {suc c₁ } {c₁ ⊔ c₂} {c₁ ⊔ c₂} ) } → Hom (Cart ) a b → Hom (Grph {c₁} {c₂}) (g21 ( uobj a )) (g21 ( uobj b ))
+  umap :  {a b : Obj (Cart {c₁ } {c₁} {c₁} ) } → Hom (Cart ) a b → Hom (Grph {c₁} {c₁}) (( uobj a )) (( uobj b ))
   umap {a} {b} f =  record {
-           vmap = λ e → vmap (m21 (uobj b)) (FObj (cmap f) (vmap (m12 (uobj a)) e ))
-         ; emap = λ e → emap (m21 (uobj b)) (FMap (cmap f) (emap (m12 (uobj a)) e )) } 
+           vmap = λ e → FObj (cmap f) e
+         ; emap = λ e → FMap (cmap f) e } 
 
-  UX :  Functor (Cart  {suc c₁} {c₁ ⊔ c₂} {c₁ ⊔ c₂}) (Grph {c₁} {c₂})
-  FObj UX a = g21 (uobj a)
+  UX :  Functor (Cart  {c₁} {c₁} {c₁}) (Grph {c₁} {c₁})
+  FObj UX a = (uobj a)
   FMap UX f =  umap f
   isFunctor UX  = isf where
-    isf : IsFunctor Cart Grph (λ z → g21 (uobj z)) umap
+    isf : IsFunctor Cart Grph (λ z → (uobj z)) umap
     IsFunctor.identity isf {a} {b} {f} = begin
          umap (id1 Cart a) 
        ≈⟨⟩
          umap {a} {a} (record { cmap = identityFunctor ; ccf = λ x → x })
        ≈⟨⟩
-         record { vmap = λ e → vmap (m21 (uobj a)) (vmap (m12 (uobj a)) e ) ; emap = λ e → emap (m21 (uobj a)) (emap (m12 (uobj a)) e )}
-       ≈⟨ giso← {uobj a} {f} {f}  ⟩
          record { vmap = λ y → y ; emap = λ f → f }
        ≈⟨⟩
-         id1 Grph (g21 (uobj a))
+         id1 Grph ((uobj a))
        ∎ where open ≈-Reasoning Grph 
     IsFunctor.distr isf {a} {b} {c} {f} {g} = begin
          umap ( Cart [ g o f ] )
        ≈⟨⟩
-         ( m21 (uobj c) & ( record { vmap = λ e → FObj (cmap (( Cart [ g o f ] ))) e ; emap = λ e → FMap (cmap (( Cart [ g o f ] ))) e} &  m12 (uobj a) ) )
+         record { vmap = {!!} ; emap = {!!} }
        ≈⟨ {!!} ⟩
---         ( m21 (uobj c) &  (record { vmap = λ e → FObj (cmap g) (FObj (cmap f) e)  ; emap = λ e → FMap (cmap g) (FMap (cmap f) e) }
---            &  m12 (uobj a)))
---       ≈⟨ cdr (cdr (car (giso← {uobj b} )))  ⟩
---         ( m21 (uobj c) &  (record { vmap = λ e → FObj (cmap g) e ; emap = λ e → FMap (cmap g) e}
---            &  ((m12 (uobj b) 
---            &  (m21 (uobj b))) &  (record { vmap = λ e → FObj (cmap f) e ; emap = λ e → FMap (cmap f) e}
---            &  (m12 (uobj a) )))))
---       ≈⟨⟩
+         record { vmap = {!!} ; emap = {!!} }
+       ≈⟨⟩
          Grph [ umap g o umap f ]
        ∎ where open ≈-Reasoning Grph 
     IsFunctor.≈-cong isf {a} {b} {f} {g} f=g e = {!!} where -- lemma ( (extensionality Sets ( λ z → lemma4 (
@@ -440,7 +427,7 @@
 
   open ccc-from-graph g
 
-  FCat : Obj (Cart {suc c₁} {c₁ ⊔ c₂} {c₁ ⊔ c₂})
+  FCat : Obj (Cart {c₁} {c₁ ⊔ c₂} {c₁ ⊔ c₂})
   FCat  = record { cat = record {
           Obj = Obj PL 
           ; Hom = λ a b → Hom B (FObj CS a) (FObj CS b)
@@ -466,8 +453,8 @@
       fcat-eq :  {a b : Obj (cat FCat) } → (f : Hom (cat FCat) a b ) → FMap CS (fcat-pl f) ≡ f
 
 
-ccc-graph-univ :  {c₁ c₂ : Level} → UniversalMapping (Grph {c₁} {c₂}) (Cart {suc c₁ } {c₁ ⊔ c₂} {c₁ ⊔ c₂}) forgetful.UX 
-ccc-graph-univ {c₁} {c₂} = record {
+ccc-graph-univ :  {c₁ : Level} → UniversalMapping (Grph {c₁} {c₁}) (Cart {c₁ } {c₁} {c₁}) forgetful.UX 
+ccc-graph-univ {c₁}  = record {
      F = F ;
      η = η ; 
      _* = solution ;
@@ -490,33 +477,33 @@
        --                          ↓                                                       |
        --  Sets  ((z : vertx g) → C z x)  ----> ((z : vertx g) → C z y)  = h : Hom Sets (fobj (atom x)) (fobj (atom y))
        --
-       F : Obj (Grph {c₁} {c₂}) → Obj (Cart {suc c₁} {c₁ ⊔ c₂} {c₁ ⊔ c₂})
+       F : Obj (Grph {c₁} {c₁}) → Obj (Cart {c₁} {c₁} {c₁})
        F g = FCat  where open fcat g 
-       η : (a : Obj (Grph {c₁} {c₂}) ) → Hom Grph a (FObj UX (F a))
-       η a = record { vmap = λ y → vm y ;  emap = λ f → em f }  where
-            fo : Graph  {suc c₁ } {c₁ ⊔ c₂}
-            fo = uobj {c₁} {c₂} (F a)
-            vm : (y : vertex a ) →  vertex (g21 fo) 
-            vm y =  vmap (m21 fo) (atom y) 
-            em :  { x y : vertex a } (f : edge a x y ) → edge (FObj UX (F a)) (vm x) (vm y)
-            em {x} {y} f = emap (m21 fo) (fmap a (iv (arrow f) (id _)))
-       pl : {c₁ c₂ : Level}  → (g : Graph {c₁} {c₂} ) → Category _ _ _
+       η : (a : Obj (Grph {c₁} {c₁}) ) → Hom Grph a (FObj UX (F a))
+       η a = record { vmap = λ y → {!!} ;  emap = λ f → em f }  where
+            fo : Graph  {c₁ } {c₁}
+            fo = uobj {c₁} (F a)
+            vm : (y : vertex a ) →  vertex {!!}
+            vm y =  {!!} -- vmap (m21 fo) (atom y) 
+            em :  { x y : vertex a } (f : edge a x y ) → edge (FObj UX (F a)) {!!} {!!}
+            em {x} {y} f = {!!} -- emap (m21 fo) (fmap a (iv (arrow f) (id _)))
+       pl : {c₁ c₁ : Level}  → (g : Graph {c₁} {c₁} ) → Category _ _ _
        pl g = PL g
-       cobj  :  {g : Obj (Grph {c₁} {c₂} ) } {c : Obj Cart} → Hom Grph g (FObj UX c)  → Objs g → Obj (cat c)
-       cobj {g} {c} f (atom x) = vmap (m12 (uobj {c₁} {c₂} c)) (vmap f x)
+       cobj  :  {g : Obj (Grph {c₁} {c₁} ) } {c : Obj Cart} → Hom Grph g (FObj UX c)  → Objs g → Obj (cat c)
+       cobj {g} {c} f (atom x) = vmap {!!} (vmap f x)
        cobj {g} {c} f ⊤ = CCC.1 (ccc c)
        cobj {g} {c} f (x ∧ y) = CCC._∧_ (ccc c) (cobj {g} {c} f x) (cobj {g} {c} f y)
        cobj {g} {c} f (b <= a) = CCC._<=_ (ccc c) (cobj {g} {c} f b) (cobj {g} {c} f a) 
        c-map :  {g : Obj (Grph  )} {c : Obj Cart} {A B : Objs g} 
            → (f : Hom Grph g (FObj UX c) ) → (fobj g A → fobj g B) → Hom (cat c) (cobj {g} {c} f A) (cobj {g} {c} f B)
-       c-map {g} {c} {a} {atom b} f y with fcat.fcat-pl {c₁} {c₂} g {a} {atom b} y
+       c-map {g} {c} {a} {atom b} f y with fcat.fcat-pl {c₁} {c₁} g {a} {atom b} y
        c-map {g} {c} {atom b} {atom b} f y | id (atom b) = id1 (cat c) _
        c-map {g} {c} {a} {atom b} f y | iv {_} {_} {d} (arrow x) t = {!!} 
-          -- (cat c) [ emap (m12 (uobj {c₁} {c₂} c)) ( emap f x)  o c-map {g} {c} {a} {d} f (fmap g t) ]
+          -- (cat c) [ emap (m12 (uobj {c₁} {c₁} c)) ( emap f x)  o c-map {g} {c} {a} {d} f (fmap g t) ]
        c-map {g} {c} {a} {atom b} f y | iv {_} {_} {d} π t = {!!} --(cat c) [ CCC.π (ccc c) o c-map {g} {c} {a} {d} f (fmap g t)]
        c-map {g} {c} {a} {atom b} f y | iv {_} {_} {d} π' t = {!!} -- (cat c) [ CCC.π' (ccc c) o c-map {g} {c} {a} {d} f (fmap g t) ]
        c-map {g} {c} {a} {atom b} f y | iv {_} {_} {d} ε t = {!!} -- (cat c) [ CCC.ε (ccc c) o c-map {g} {c} {a} {d} f (fmap g t) ]
-       -- with emap (m12 (uobj {c₁} {c₂} c)) ( emap f {!!} )
+       -- with emap (m12 (uobj {c₁} {c₁} c)) ( emap f {!!} )
        c-map {g} {c} {a} {⊤} f x = CCC.○ (ccc c) (cobj f a)
        c-map {g} {c} {a} {x ∧ y} f z = CCC.<_,_> (ccc c) (c-map f (λ k → proj₁ (z k))) (c-map f (λ k → proj₂ (z k)))
        c-map {g} {c} {d} {b <= a} f x = CCC._* (ccc c) ( c-map f (λ k → x (proj₁ k)  (proj₂ k)))