# HG changeset patch # User Shinji KONO # Date 1614057072 -32400 # Node ID 50d8750d32c0ef549eebf9ac55e7fba074eddf24 # Parent 9cf91e7735177bcd1969295575889407c87c3f57 ... diff -r 9cf91e773517 -r 50d8750d32c0 src/CCC.agda --- a/src/CCC.agda Mon Feb 22 21:31:38 2021 +0900 +++ b/src/CCC.agda Tue Feb 23 14:11:12 2021 +0900 @@ -126,17 +126,16 @@ -- -- Sub Object Classifier as Topos -- pull back on --- ○ b --- b ----------------------→ 1 --- | | --- | | --- m | | ⊤ --- | | --- ↓ ↓ --- a ----------------------→ Ω --- h +-- ○ b +-- b -----------→ 1 +-- | | +-- m | | ⊤ +-- ↓ char m ↓ +-- a -----------→ Ω +-- h -- open Equalizer +open import equalizer record Mono {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) {b a : Obj A} (mono : Hom A b a) : Set (c₁ ⊔ c₂ ⊔ ℓ) where field @@ -144,8 +143,6 @@ open Mono -open import equalizer - record IsTopos {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) (○ : (a : Obj A ) → Hom A a 1) ( Ω : Obj A ) ( ⊤ : Hom A 1 Ω ) @@ -153,7 +150,7 @@ (char : {a b : Obj A} → (m : Hom A b a) → Mono A m → Hom A a Ω) : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where field char-ker : {a b : Obj A } {h : Hom A a Ω} - → A [ char (equalizer (Ker h)) record { isMono = monic (Ker h) } ≈ h ] + → A [ char (equalizer (Ker h)) record { isMono = λ f g → monic (Ker h) } ≈ h ] ker-char : {a b : Obj A} → (m : Hom A b a) → (mono : Mono A m) → Iso A b ( equalizer-c (Ker ( char m mono ))) record Topos {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) (○ : (a : Obj A ) → Hom A a 1) : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where @@ -166,10 +163,29 @@ ker : {a : Obj A} → ( h : Hom A a Ω ) → Hom A ( equalizer-c (Ker h) ) a ker h = equalizer (Ker h) +record NatD {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where + field + Nat : Obj A + nzero : Hom A 1 Nat + nsuc : Hom A Nat Nat + +open NatD + +record IsToposNat {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) (TNat : NatD A 1 ) + ( gNat : (nat : NatD A 1 ) → Hom A (Nat TNat) (Nat nat) ) + : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where + field + izero : (nat : NatD A 1 ) → A [ A [ gNat nat o nzero TNat ] ≈ nzero nat ] + isuc : (nat : NatD A 1 ) → A [ A [ gNat nat o nsuc TNat ] ≈ A [ nsuc nat o gNat nat ] ] + +record ToposNat {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) : Set ( suc c₁ ⊔ suc c₂ ⊔ suc ℓ ) where + field + TNat : NatD A 1 + gNat : (nat : NatD A 1 ) → Hom A (Nat TNat) (Nat nat) + isToposN : IsToposNat A 1 TNat gNat - diff -r 9cf91e773517 -r 50d8750d32c0 src/ToposEx.agda --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/ToposEx.agda Tue Feb 23 14:11:12 2021 +0900 @@ -0,0 +1,49 @@ +module ToposEx where +open import CCC +open import Level +open import Category +open import cat-utility +open import HomReasoning + +open Topos +open Equalizer + +-- ○ b +-- b -----------→ 1 +-- | | +-- m | | ⊤ +-- ↓ char m ↓ +-- a -----------→ Ω +-- h + + +topos-pullback : {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) (○ : (a : Obj A ) → Hom A a 1) + → (e2 : {a : Obj A} → ∀ { f : Hom A a 1 } → A [ f ≈ ○ a ] ) + → (t : Topos A 1 ○ ) → {a : Obj A} → (h : Hom A a (Ω t)) → Pullback A h (⊤ t) +topos-pullback A 1 ○ e2 t {a} h = record { + -- Ker t h : Equalizer A h (A [ ⊤ o (○ a) ]) + ab = equalizer-c (Ker t h) -- b + ; π1 = equalizer (Ker t h) -- m + ; π2 = ○ ( equalizer-c (Ker t h) ) -- ○ b + ; isPullback = record { + commute = comm + ; pullback = λ {d} {p1} {p2} eq → IsEqualizer.k (isEqualizer (Ker t h)) p1 (lemma1 p1 p2 eq ) + ; π1p=π1 = {!!} + ; π2p=π2 = {!!} + ; uniqueness = {!!} + } + } where + open ≈-Reasoning A + comm : A [ A [ h o equalizer (Ker t h) ] ≈ A [ ⊤ t o ○ (equalizer-c (Ker t h)) ] ] + comm = begin + h o equalizer (Ker t h) ≈⟨ {!!} ⟩ + ⊤ t o ○ (equalizer-c (Ker t h)) ∎ + lemma1 : {d : Obj A} (p1 : Hom A d a) (p2 : Hom A d 1) (eq : A [ A [ h o p1 ] ≈ A [ ⊤ t o p2 ] ] ) + → A [ A [ h o p1 ] ≈ A [ A [ ⊤ t o ○ a ] o p1 ] ] + lemma1 {d} p1 p2 eq = begin + h o p1 ≈⟨ eq ⟩ + ⊤ t o p2 ≈⟨ cdr e2 ⟩ + ⊤ t o (○ d) ≈↑⟨ cdr e2 ⟩ + ⊤ t o ( ○ a o p1 ) ≈⟨ assoc ⟩ + (⊤ t o ○ a ) o p1 ∎ + diff -r 9cf91e773517 -r 50d8750d32c0 src/equalizer.agda --- a/src/equalizer.agda Mon Feb 22 21:31:38 2021 +0900 +++ b/src/equalizer.agda Tue Feb 23 14:11:12 2021 +0900 @@ -82,10 +82,10 @@ -- || -- d -monoic : { c a b d : Obj A } {f g : Hom A a b } → ( eqa : Equalizer A f g) +monic : { a b d : Obj A } {f g : Hom A a b } → ( eqa : Equalizer A f g) → { i j : Hom A d (equalizer-c eqa) } → A [ A [ equalizer eqa o i ] ≈ A [ equalizer eqa o j ] ] → A [ i ≈ j ] -monoic {c} {a} {b} {d} {f} {g} eqa {i} {j} ei=ej = let open ≈-Reasoning (A) in begin +monic {a} {b} {d} {f} {g} eqa {i} {j} ei=ej = let open ≈-Reasoning (A) in begin i ≈↑⟨ uniqueness (isEqualizer eqa) ( begin equalizer eqa o i @@ -332,7 +332,7 @@ -- Bourroni equations gives an Equalizer -- -lemma-equ2 : {a b : Obj A} (f g : Hom A a b) → ( bur : Burroni ) → → IsEqualizer A {equ bur f g} {a} {b} (α bur f g ) f g +lemma-equ2 : {a b : Obj A} (f g : Hom A a b) → ( bur : Burroni ) → IsEqualizer A {equ bur f g} {a} {b} (α bur f g ) f g lemma-equ2 {a} {b} f g bur = record { fe=ge = fe=ge1 ; k = k1 ;