Mercurial > hg > Members > kono > Proof > category
view src/CCC.agda @ 964:0128a662eb02
Topos as pull back
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 23 Feb 2021 16:32:06 +0900 |
parents | 50d8750d32c0 |
children | 396bf884f5e7 |
line wrap: on
line source
open import Level open import Category module CCC where open import HomReasoning open import cat-utility open import Relation.Binary.PropositionalEquality open import HomReasoning record IsCCC {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A ) ( ○ : (a : Obj A ) → Hom A a 1 ) ( _∧_ : Obj A → Obj A → Obj A ) ( <_,_> : {a b c : Obj A } → Hom A c a → Hom A c b → Hom A c (a ∧ b) ) ( π : {a b : Obj A } → Hom A (a ∧ b) a ) ( π' : {a b : Obj A } → Hom A (a ∧ b) b ) ( _<=_ : (a b : Obj A ) → Obj A ) ( _* : {a b c : Obj A } → Hom A (a ∧ b) c → Hom A a (c <= b) ) ( ε : {a b : Obj A } → Hom A ((a <= b ) ∧ b) a ) : Set ( c₁ ⊔ c₂ ⊔ ℓ ) where field -- cartesian e2 : {a : Obj A} → ∀ { f : Hom A a 1 } → A [ f ≈ ○ a ] e3a : {a b c : Obj A} → { f : Hom A c a }{ g : Hom A c b } → A [ A [ π o < f , g > ] ≈ f ] e3b : {a b c : Obj A} → { f : Hom A c a }{ g : Hom A c b } → A [ A [ π' o < f , g > ] ≈ g ] e3c : {a b c : Obj A} → { h : Hom A c (a ∧ b) } → A [ < A [ π o h ] , A [ π' o h ] > ≈ h ] π-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' > ] -- closed e4a : {a b c : Obj A} → { h : Hom A (c ∧ b) a } → A [ A [ ε o < A [ (h *) o π ] , π' > ] ≈ h ] e4b : {a b c : Obj A} → { k : Hom A c (a <= b ) } → A [ ( A [ ε o < A [ k o π ] , π' > ] ) * ≈ k ] *-cong : {a b c : Obj A} → { f f' : Hom A (a ∧ b) c } → A [ f ≈ f' ] → A [ f * ≈ f' * ] e'2 : A [ ○ 1 ≈ id1 A 1 ] e'2 = let open ≈-Reasoning A in begin ○ 1 ≈↑⟨ e2 ⟩ id1 A 1 ∎ e''2 : {a b : Obj A} {f : Hom A a b } → A [ A [ ○ b o f ] ≈ ○ a ] e''2 {a} {b} {f} = let open ≈-Reasoning A in begin ○ b o f ≈⟨ e2 ⟩ ○ a ∎ π-id : {a b : Obj A} → A [ < π , π' > ≈ id1 A (a ∧ b ) ] π-id {a} {b} = let open ≈-Reasoning A in begin < π , π' > ≈↑⟨ π-cong idR idR ⟩ < π o id1 A (a ∧ b) , π' o id1 A (a ∧ b) > ≈⟨ e3c ⟩ id1 A (a ∧ b ) ∎ distr-π : {a b c d : Obj A} {f : Hom A c a }{g : Hom A c b } {h : Hom A d c } → A [ A [ < f , g > o h ] ≈ < A [ f o h ] , A [ g o h ] > ] distr-π {a} {b} {c} {d} {f} {g} {h} = let open ≈-Reasoning A in begin < f , g > o h ≈↑⟨ e3c ⟩ < π o < f , g > o h , π' o < f , g > o h > ≈⟨ π-cong assoc assoc ⟩ < ( π o < f , g > ) o h , (π' o < f , g > ) o h > ≈⟨ π-cong (car e3a ) (car e3b) ⟩ < f o h , g o h > ∎ _×_ : { a b c d : Obj A } ( f : Hom A a c ) (g : Hom A b d ) → Hom A (a ∧ b) ( c ∧ d ) f × g = < (A [ f o π ] ) , (A [ g o π' ]) > distr-* : {a b c d : Obj A } { h : Hom A (a ∧ b) c } { k : Hom A d a } → A [ A [ h * o k ] ≈ ( A [ h o < A [ k o π ] , π' > ] ) * ] distr-* {a} {b} {c} {d} {h} {k} = begin h * o k ≈↑⟨ e4b ⟩ ( ε o < (h * o k ) o π , π' > ) * ≈⟨ *-cong ( begin ε o < (h * o k ) o π , π' > ≈↑⟨ cdr ( π-cong assoc refl-hom ) ⟩ ε o ( < h * o ( k o π ) , π' > ) ≈↑⟨ cdr ( π-cong (cdr e3a) e3b ) ⟩ ε o ( < h * o ( π o < k o π , π' > ) , π' o < k o π , π' > > ) ≈⟨ cdr ( π-cong assoc refl-hom) ⟩ ε o ( < (h * o π) o < k o π , π' > , π' o < k o π , π' > > ) ≈↑⟨ cdr ( distr-π ) ⟩ ε o ( < h * o π , π' > o < k o π , π' > ) ≈⟨ assoc ⟩ ( ε o < h * o π , π' > ) o < k o π , π' > ≈⟨ car e4a ⟩ h o < k o π , π' > ∎ ) ⟩ ( h o < k o π , π' > ) * ∎ where open ≈-Reasoning A α : {a b c : Obj A } → Hom A (( a ∧ b ) ∧ c ) ( a ∧ ( b ∧ c ) ) α = < A [ π o π ] , < A [ π' o π ] , π' > > α' : {a b c : Obj A } → Hom A ( a ∧ ( b ∧ c ) ) (( a ∧ b ) ∧ c ) α' = < < π , A [ π o π' ] > , A [ π' o π' ] > β : {a b c d : Obj A } { f : Hom A a b} { g : Hom A a c } { h : Hom A a d } → A [ A [ α o < < f , g > , h > ] ≈ < f , < g , h > > ] β {a} {b} {c} {d} {f} {g} {h} = begin α o < < f , g > , h > ≈⟨⟩ ( < ( π o π ) , < ( π' o π ) , π' > > ) o < < f , g > , h > ≈⟨ distr-π ⟩ < ( ( π o π ) o < < f , g > , h > ) , ( < ( π' o π ) , π' > o < < f , g > , h > ) > ≈⟨ π-cong refl-hom distr-π ⟩ < ( ( π o π ) o < < f , g > , h > ) , ( < ( ( π' o π ) o < < f , g > , h > ) , ( π' o < < f , g > , h > ) > ) > ≈↑⟨ π-cong assoc ( π-cong assoc refl-hom ) ⟩ < ( π o (π o < < f , g > , h >) ) , ( < ( π' o ( π o < < f , g > , h > ) ) , ( π' o < < f , g > , h > ) > ) > ≈⟨ π-cong (cdr e3a ) ( π-cong (cdr e3a ) e3b ) ⟩ < ( π o < f , g > ) , < ( π' o < f , g > ) , h > > ≈⟨ π-cong e3a ( π-cong e3b refl-hom ) ⟩ < f , < g , h > > ∎ where open ≈-Reasoning A record CCC {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) : Set ( c₁ ⊔ c₂ ⊔ ℓ ) where field 1 : Obj A ○ : (a : Obj A ) → Hom A a 1 _∧_ : Obj A → Obj A → Obj A <_,_> : {a b c : Obj A } → Hom A c a → Hom A c b → Hom A c (a ∧ b) π : {a b : Obj A } → Hom A (a ∧ b) a π' : {a b : Obj A } → Hom A (a ∧ b) b _<=_ : (a b : Obj A ) → Obj A _* : {a b c : Obj A } → Hom A (a ∧ b) c → Hom A a (c <= b) ε : {a b : Obj A } → Hom A ((a <= b ) ∧ b) a isCCC : IsCCC A 1 ○ _∧_ <_,_> π π' _<=_ _* ε ---- -- -- Sub Object Classifier as Topos -- pull back on -- ○ 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 isMono : {c : Obj A} ( f g : Hom A c b ) → A [ A [ mono o f ] ≈ A [ mono o g ] ] → A [ f ≈ g ] open Mono record IsTopos {c₁ c₂ ℓ : Level} (A : Category c₁ c₂ ℓ) ( 1 : Obj A) (○ : (a : Obj A ) → Hom A a 1) ( Ω : Obj A ) ( ⊤ : Hom A 1 Ω ) (Ker : {a : Obj A} → ( h : Hom A a Ω ) → Equalizer A h (A [ ⊤ o (○ a) ])) (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 = λ 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 field Ω : Obj A ⊤ : Hom A 1 Ω Ker : {a : Obj A} → ( h : Hom A a Ω ) → Equalizer A h (A [ ⊤ o (○ a) ]) char : {a b : Obj A} → (m : Hom A b a ) → Mono A m → Hom A a Ω isTopos : IsTopos A 1 ○ Ω ⊤ Ker char 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