view src/ToposIL.agda @ 1074:2755bac8d8b9

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sun, 09 May 2021 00:20:48 +0900
parents 785d8b2ba48f
children 10b4d04b734f
line wrap: on
line source

open import CCC
open import Level
open import Category
open import cat-utility
open import HomReasoning
open import Data.List hiding ( [_] )
module ToposIL   {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) (c : CCC A)   where

  open Topos
  open Equalizer
  -- open ≈-Reasoning A hiding (_∙_)
  open CCC.CCC c

  open Functor
  open import Category.Sets hiding (_o_)
  open import Relation.Binary.PropositionalEquality hiding ( [_] ; sym)
  open import Polynominal A c

  record IsLogic (Ω : Obj A) (⊤ : Hom A 1 Ω) (P  : Obj A → Obj A)
         (_==_ : {a : Obj A} (x y : Hom A 1 a ) → Hom A 1 Ω)
         (_∈_ : {a : Obj A} (x :  Hom A 1 a ) (α : Hom A 1 (P a) ) → Hom A 1 Ω)
         (select : {a : Obj A} → ( φ :  Poly a Ω 1 ) → Hom A 1 (P a))
         (apply : {a  : Obj A}  (p : Poly a  Ω 1 )  → ( x : Hom A 1 a ) →  Poly a  Ω 1 )
             :   Set ( suc c₁  ⊔  suc c₂ ⊔ suc ℓ ) where
     field
         isSelect : {a : Obj A} → ( φ :  Poly a Ω 1 ) → {c : Obj A} (h : Hom A c 1 )
            → A [ ( ( Poly.x φ ∈ select φ ) == Poly.f φ )  ∙ h  ≈  ⊤ ∙  ○  c ]
         uniqueSelect : {a : Obj A} → ( φ :  Poly a Ω 1 ) → (α : Hom A 1 (P a) )
            → {c : Obj A} (h : Hom A c 1 )
            → A [ ( Poly.f φ == ( Poly.x φ ∈ α ) )  ∙ h  ≈  ⊤ ∙  ○  c ]
            → A [ ( select φ == α )  ∙ h  ≈  ⊤ ∙  ○  c ]
         isApply : {a : Obj A}  (x y : Hom A 1 a ) → (q p : Poly a  Ω 1 ) 
            → {c : Obj A} (h : Hom A c 1 )  → A [ ( x == y )  ∙ h  ≈  ⊤ ∙  ○  c ] 
            → A [ Poly.f q ∙ h  ≈  ⊤ ∙  ○  c ]
            → A [ Poly.f (apply p x ) ∙ h  ≈  ⊤ ∙  ○  c ] 
            → A [ Poly.f (apply p y ) ∙ h  ≈  ⊤ ∙  ○  c ]  
         applyCong : {a : Obj A}  (x : Hom A 1 a ) → (q p : Poly a  Ω 1 ) 
            → {c : Obj A} (h : Hom A c 1 )  
            → ( A [ Poly.f q ∙ h  ≈  ⊤ ∙  ○  c ] → A [ Poly.f p ∙ h  ≈  ⊤ ∙  ○  c ] )
            → ( A [ Poly.f (apply q x ) ∙ h  ≈  ⊤ ∙  ○  c ] → A [ Poly.f (apply p x ) ∙ h  ≈  ⊤ ∙  ○  c ] )

  record InternalLanguage (Ω : Obj A) (⊤ : Hom A 1 Ω) (P  : Obj A → Obj A)
          :   Set ( suc c₁  ⊔  suc c₂ ⊔ suc ℓ ) where
     field
         _==_ : {a : Obj A} (x y : Hom A 1 a ) → Hom A 1 Ω
         _∈_ : {a : Obj A} (x :  Hom A 1 a ) (α : Hom A 1 (P a) ) → Hom A 1 Ω
         -- { x ∈ a | φ x } : P a
         select : {a : Obj A} → ( φ :  Poly a Ω 1 ) → Hom A 1 (P a)
         apply : {a  : Obj A}  (p : Poly a  Ω 1 )  → ( x : Hom A 1 a ) →  Poly a  Ω 1 
         isIL : IsLogic Ω ⊤ P _==_ _∈_  select apply
     _⊢_  : {a b : Obj A}  (p : Poly a  Ω b ) (q : Poly a  Ω b ) → Set  ( c₁  ⊔  c₂ ⊔ ℓ ) 
     _⊢_  {a} {b} p q = {c : Obj A} (h : Hom A c b ) → A [ Poly.f p ∙  h  ≈  ⊤ ∙  ○  c  ]
         → A [   Poly.f q ∙ h  ≈  ⊤ ∙  ○  c  ] 
     _,_⊢_  : {a b : Obj A}  (p : Poly a  Ω b ) (p1 : Poly a  Ω b ) (q : Poly a  Ω b ) → Set  ( c₁  ⊔  c₂ ⊔ ℓ ) 
     _,_⊢_  {a} {b} p p1 q = {c : Obj A} (h : Hom A c b ) → A [ Poly.f p ∙  h  ≈  ⊤ ∙  ○  c  ]
         → A [   Poly.f p1 ∙ h  ≈  ⊤ ∙  ○  c  ] 
         → A [   Poly.f q  ∙ h  ≈  ⊤ ∙  ○  c  ] 
     expr : {a b c  : Obj A}  (p : Hom A 1 Ω  )  → ( x : Hom A 1 a ) →  Poly a  Ω 1 
     expr p x = record { x = x ;  f = p ; phi = i }
     ⊨_ :   (p : Hom A 1 Ω  ) →  Set  ( c₁  ⊔  c₂ ⊔ ℓ )
     ⊨  p = {c : Obj A} (h : Hom A c 1 )  → A [ p  ∙ h  ≈  ⊤ ∙  ○  c ] 

--             ○ b
--       b -----------→ 1
--       |              |
--     m |              | ⊤
--       ↓    char m    ↓
--       a -----------→ Ω

  -- (n : ToposNat A 1)
  -- open NatD
  -- open ToposNat n

  -- N : Obj A
  -- N = Nat iNat 

  open import ToposEx A c using ( δmono  )

  -- f ≡ λ (x ∈ a) → φ x , ∃ (f : b <= a) →  f ∙ x ≈  φ x  

  -- functional completeness
  FC0 : Set ( suc c₁  ⊔  suc c₂ ⊔ suc ℓ )
  FC0 = {a b : Obj A}  (t : Topos A c) ( φ : Poly a (Ω t) b) → Functional-completeness φ

  FC1 : Set ( suc c₁  ⊔  suc c₂ ⊔ suc ℓ )
  FC1 = {a : Obj A}  (t : Topos A c) ( φ : Poly a (Ω t) 1) → Fc φ

  topos→logic : (t : Topos A c ) → ToposNat A 1 → FC0 →  FC1  → InternalLanguage (Topos.Ω t) (Topos.⊤ t) (λ a → (Topos.Ω t) <= a)
  topos→logic t n fc0 fc = record {
         _==_ = λ {b} f g →   A [ char t < id1 A b , id1 A b > (δmono t n ) o < f , g > ]
      ;  _∈_ = λ {a} x α →  A [ ε o < α , x > ]
      -- { x ∈ a | φ x } : P a
      ;  select = λ {a} φ →  Fc.g ( fc t φ )
      ;  apply = λ {a}  φ x → record { x = x ; f = Functional-completeness.fun (fc0 t φ ) ∙ < x ∙  ○ _ , id1 A _ >  ; phi = i }
      ;  isIL = record {
           isSelect = {!!}
         ; uniqueSelect = {!!}
         ; isApply = {!!}
         ; applyCong = {!!}
        }
    } where
     open ≈-Reasoning A hiding (_∙_)
     _⊢_  : {a b : Obj A}  (p : Poly a  (Topos.Ω t) b ) (q : Poly a  (Topos.Ω t) b ) → Set  ( c₁  ⊔  c₂ ⊔ ℓ ) 
     _⊢_  {a} {b}  p q = {c : Obj A} (h : Hom A c b ) → A [ Poly.f p ∙  h  ≈  (Topos.⊤ t) ∙  ○  c  ]
         → A [   Poly.f q ∙ h  ≈  (Topos.⊤ t) ∙  ○  c  ] 
--
--     iso          ○ c
--  e ⇐====⇒  c -----------→ 1     
--  |         |              |
--  |       h |              | ⊤
--  |         ↓    char h    ↓    
--  + ------→ b -----------→ Ω    
--     ker h       fp / fq
--
     tl01 : {a b : Obj A}  (p q : Poly a  (Topos.Ω t) b ) 
        → p ⊢ q → q ⊢ p →  A [ Poly.f p ≈ Poly.f q ]
     tl01 {a} {b} p q p<q q<p = begin
          Poly.f p ≈↑⟨ {!!}  ⟩
          char t ((equalizer (Ker t (Poly.f p)) ∙  pk ) ∙ qk ) {!!} ≈⟨  {!!}  ⟩
          char t ((equalizer (Ker t (Poly.f q)) ∙  qk ) ∙ pk ) {!!} ≈⟨  {!!}  ⟩
          Poly.f q ∎  where
        ep :  Equalizer A (Poly.f p) (A [ (Topos.⊤ t) o ○ b ])
        ep = Ker t (Poly.f p)
        eq :  Equalizer A (Poly.f q) (A [ (Topos.⊤ t) o ○ b ])
        eq = Ker t (Poly.f q)
        pm : {c : Obj A} (h : Hom A c b ) → A [   Poly.f p ∙ h  ≈  (Topos.⊤ t) ∙  ○  c  ] → A [   Poly.f q ∙ h  ≈  (Topos.⊤ t) ∙  ○  c  ] 
        pm h = p<q h
        qm : {c : Obj A} (h : Hom A c b ) → A [   Poly.f q ∙ h  ≈  (Topos.⊤ t) ∙  ○  c  ] → A [   Poly.f p ∙ h  ≈  (Topos.⊤ t) ∙  ○  c  ] 
        qm h = q<p h
        pp : Hom A b (Topos.Ω t)
        pp =  Poly.f q
        open import equalizer using ( monic )
        pqiso : Iso A (equalizer-c (Ker t (Poly.f p))) (equalizer-c (Ker t (Poly.f q)))
        pqiso = equalizer.equ-iso ( isEqualizer (Ker t (Poly.f p))) {!!} -- (isEqualizer (Ker t (Poly.f q)))
        fp :  A [ A [ Poly.f p o equalizer (Ker t (Poly.f p)) ]  ≈   A [ A [ (Topos.⊤ t) o  ○  b ] o equalizer (Ker t (Poly.f p)) ]  ]
        fp = IsEqualizer.fe=ge (Equalizer.isEqualizer (Ker t (Poly.f p))) 
        fq :  A [ A [ Poly.f q o equalizer (Ker t (Poly.f q)) ]  ≈   A [ A [ (Topos.⊤ t) o  ○  b ] o equalizer (Ker t (Poly.f q)) ]  ]
        fq = IsEqualizer.fe=ge (Equalizer.isEqualizer (Ker t (Poly.f q))) 
        eeq :  A [ A [ Poly.f p o equalizer (Ker t (Poly.f q)) ] ≈ A [ A [ ⊤ t o ○ b ] o equalizer (Ker t (Poly.f q)) ] ]
        eeq = begin
           Poly.f p o equalizer (Ker t (Poly.f q)) ≈⟨ q<p _ ( begin
            Poly.f q ∙ equalizer (Ker t (Poly.f q)) ≈⟨ fq ⟩
            ( ⊤ t ∙ ○ b ) ∙ equalizer (Ker t (Poly.f q)) ≈↑⟨ assoc ⟩
            ⊤ t ∙ ( ○ b  ∙ equalizer (Ker t (Poly.f q))) ≈⟨ cdr e2 ⟩
            ⊤ t ∙ ○ (equalizer-c (Ker t (Poly.f q)))  ∎ ) ⟩
           ⊤ t ∙ ○ (equalizer-c (Ker t (Poly.f q))) ≈↑⟨ cdr e2 ⟩
           ⊤ t ∙ ( ○ b ∙  equalizer (Ker t (Poly.f q) ))  ≈⟨ assoc ⟩
           (⊤ t ∙ ○ b) ∙  equalizer (Ker t (Poly.f q) )  ∎  where
        pk : Hom A (equalizer-c (Ker t (Poly.f q))) (equalizer-c (Ker t (Poly.f p)))
        pk = IsEqualizer.k (isEqualizer (Ker t (Poly.f p))) (equalizer (Ker t (Poly.f q))) eeq 
        epq : A [ equalizer (Ker t (Poly.f p)) ∙
           IsEqualizer.k (Equalizer.isEqualizer (Ker t (Poly.f p))) (equalizer (Ker t (Poly.f q  ))) eeq 
              ≈ equalizer (Ker t (Poly.f q  ))  ]
        epq = IsEqualizer.ek=h (Equalizer.isEqualizer (Ker t (Poly.f p))) 
        eep :  A [ A [ Poly.f q o equalizer (Ker t (Poly.f p)) ] ≈ A [ A [ ⊤ t o ○ b ] o equalizer (Ker t (Poly.f p)) ] ]
        eep = begin
           Poly.f q o equalizer (Ker t (Poly.f p)) ≈⟨ p<q _ ( begin
            Poly.f p ∙ equalizer (Ker t (Poly.f p)) ≈⟨ fp ⟩
            ( ⊤ t ∙ ○ b ) ∙ equalizer (Ker t (Poly.f p)) ≈↑⟨ assoc ⟩
            ⊤ t ∙ ( ○ b  ∙ equalizer (Ker t (Poly.f p))) ≈⟨ cdr e2 ⟩
            ⊤ t ∙ ○ (equalizer-c (Ker t (Poly.f p)))  ∎ ) ⟩
           ⊤ t ∙ ○ (equalizer-c (Ker t (Poly.f p))) ≈↑⟨ cdr e2 ⟩
           ⊤ t ∙ ( ○ b ∙  equalizer (Ker t (Poly.f p) ))  ≈⟨ assoc ⟩
           (⊤ t ∙ ○ b) ∙  equalizer (Ker t (Poly.f p) )  ∎  where
        qk : Hom A (equalizer-c (Ker t (Poly.f p))) (equalizer-c (Ker t (Poly.f q)))
        qk = IsEqualizer.k (isEqualizer (Ker t (Poly.f q))) (equalizer (Ker t (Poly.f p))) eep 
        eqp : A [ equalizer (Ker t (Poly.f q)) ∙
           IsEqualizer.k (Equalizer.isEqualizer (Ker t (Poly.f q))) (equalizer (Ker t (Poly.f p  ))) eep 
              ≈ equalizer (Ker t (Poly.f p  ))  ]
        eqp = IsEqualizer.ek=h (Equalizer.isEqualizer (Ker t (Poly.f q))) 
        mm : (q : Poly a  (Topos.Ω t) b ) → Mono A  (equalizer (Ker t (Poly.f q)))
        mm q = record { isMono = λ f g →  monic (Ker t (Poly.f q)) }
        tt :  (q : Poly a  (Topos.Ω t) b ) → A [ char t (equalizer (Ker t (Poly.f q))) (mm q) ≈  Poly.f q ]
        tt q = IsTopos.char-uniqueness (Topos.isTopos t) {b} {a} 

  module IL1 (Ω : Obj A) (⊤ : Hom A 1 Ω) (P  : Obj A → Obj A) (il : InternalLanguage  Ω ⊤ P) (t : Topos A c) where
     open InternalLanguage il
     il00 : {a : Obj A}  (p : Poly a  Ω 1 )  → p  ⊢ p
     il00 {a}  p h eq = eq

     ---  Poly.f p ∙  h  ≈  ⊤ ∙  ○  c 
     ---  Poly.f q ∙  h  ≈  ⊤ ∙  ○  c 
     il01 : {a b : Obj A}  (p : Poly a  Ω b ) (q : Poly a  Ω b )
        → p ⊢ q → q ⊢ p →  A [ Poly.f p ≈ Poly.f q ]
     il01 {a} p q p<q q<p = {!!} 

     il011 : {a b : Obj A}  (p q q1 : Poly a  Ω b ) 
        → q ⊢ p → q , q1 ⊢ p 
     il011 {a} p q q1 p<q h tq tq1 = p<q h tq

     il012 : {a b : Obj A}  (p q r : Poly a  Ω b ) 
        → q ⊢ p → q , p  ⊢ r → q ⊢ r 
     il012 {a} p q r p<q pq<r h  qt = pq<r h qt (p<q h qt) 
     

     il02 : {a : Obj A} (x : Hom A 1 a ) → ⊨ (x == x) 
     il02 = {!!}

     --- (b : Hom A 1 a) → φ y  ⊢ φ' y  → φ b  ⊢ φ' b
     il03 : {a : Obj A}  (b : Hom A 1 a ) → (q p : Poly a  Ω 1 ) 
        → q ⊢ p → apply q b  ⊢ apply p b
     il03 {a} b q p q<p h = IsLogic.applyCong (InternalLanguage.isIL il ) b q p h (q<p h)

     --- a == b → φ a  ⊢ φ b
     il04 : {a : Obj A}  (x y : Hom A 1 a ) → (q p : Poly a  Ω 1 ) 
        → ⊨ (x == y) 
        → q ⊢ apply p x → q ⊢ apply p y
     il04 {a} x y q p eq q<px h qt = IsLogic.isApply (InternalLanguage.isIL il ) x y q p h (eq h) qt (q<px h qt )
  
     --- ⊨ x ∈ select φ == φ x
     il05 : {a : Obj A}  → (q : Poly a  Ω 1 ) 
        → ⊨ ( ( Poly.x q ∈ select q ) == Poly.f q  )
     il05 {a} = IsLogic.isSelect (InternalLanguage.isIL il )
  
     ---    q ⊢  φ x == x ∈ α 
     ---   ----------------------- 
     ---    q ⊢ select φ == α
     ---
     il06 : {a : Obj A}  → (q : Poly a  Ω 1 )  → (α : Hom A 1 (P a) )
        → ⊨ ( Poly.f q  == ( Poly.x q ∈ α ) ) 
        → ⊨ ( select q == α )
     il06 {a} q p eq h = IsLogic.uniqueSelect (InternalLanguage.isIL il ) q p h (eq h)