From c3982b7fd9561fec34e60b28c0f20f03e9926f81 Mon Sep 17 00:00:00 2001 From: Jacques Comeaux Date: Thu, 25 Apr 2024 17:38:21 -0500 Subject: Define coequalizers and pushouts in Nat --- Coeq.agda | 4 +-- Nat/Properties.agda | 80 +++++++++++++++++++++++++++++++---------------------- 2 files changed, 49 insertions(+), 35 deletions(-) diff --git a/Coeq.agda b/Coeq.agda index ad21587..1414dad 100644 --- a/Coeq.agda +++ b/Coeq.agda @@ -28,7 +28,7 @@ open Category Nat open Coproduct (IsCoproduct⇒Coproduct coprod) open HomReasoning -iterated-coequalizer +coequalizer-on-coproduct : {A B A+B C Q₁ Q₂ : Obj} → (i₁ : A ⇒ A+B) → (i₂ : B ⇒ A+B) @@ -39,7 +39,7 @@ iterated-coequalizer → IsCoequalizer (f ∘ i₁) (g ∘ i₁) q₁ → IsCoequalizer (q₁ ∘ f ∘ i₂) (q₁ ∘ g ∘ i₂) q₂ → IsCoequalizer f g (q₂ ∘ q₁) -iterated-coequalizer {C = C} {Q₁} {Q₂} i₁ i₂ f g q₁ q₂ coprod coeq₁ coeq₂ = record +coequalizer-on-coproduct {C = C} {Q₁} {Q₂} i₁ i₂ f g q₁ q₂ coprod coeq₁ coeq₂ = record { equality = ≈-i₁-i₂ (q₂ ∘ q₁ ∘ f) (q₂ ∘ q₁ ∘ g) diff --git a/Nat/Properties.agda b/Nat/Properties.agda index 3e1e0b4..a6fb060 100644 --- a/Nat/Properties.agda +++ b/Nat/Properties.agda @@ -10,23 +10,22 @@ open import Relation.Binary.PropositionalEquality using (_≡_; refl; sym; cong) open import Relation.Binary.PropositionalEquality.Properties using (module ≡-Reasoning) open import Categories.Category.Core using (Category) -open import Categories.Category.Instance.Nat using (Nat) +open import Categories.Category.Instance.Nat using (Nat; Coprod) open import Categories.Diagram.Coequalizer Nat using (IsCoequalizer; Coequalizer) +open import Categories.Diagram.Pushout Nat using (Pushout) +open import Categories.Diagram.Pushout.Properties Nat using (Coproduct×Coequalizer⇒Pushout) open import Categories.Object.Coproduct Nat using (Coproduct; IsCoproduct; IsCoproduct⇒Coproduct) -open import Coeq using (iterated-coequalizer) +open import Coeq using (coequalizer-on-coproduct) open import FinMerge using (glue-iter; glue-unglue-once) open import FinMerge.Properties using (lemma₂; merge-unmerge; unmerge-merge) open import Util using (compare; less; equal; greater; _<_<_) - open Category Nat -makeZeroCoequalizer - : {B : ℕ} - → (f g : 0 ⇒ B) - → Coequalizer f g -makeZeroCoequalizer f g = record + +makeZeroCoequalizer : {B : ℕ} {f g : 0 ⇒ B} → Coequalizer f g +makeZeroCoequalizer = record { arr = id ; isCoequalizer = record { equality = λ() @@ -36,12 +35,9 @@ makeZeroCoequalizer f g = record } } -makeSimpleCoequalizer - : {B : ℕ} - → (f g : 1 ⇒ B) - → Coequalizer f g -makeSimpleCoequalizer {ℕ.zero} f g = ⊥-elim (¬Fin0 (f (# 0))) -makeSimpleCoequalizer {ℕ.suc B} f g = record +makeSimpleCoequalizer : {B : ℕ} {f g : 1 ⇒ B} → Coequalizer f g +makeSimpleCoequalizer {ℕ.zero} {f} = ⊥-elim (¬Fin0 (f (# 0))) +makeSimpleCoequalizer {ℕ.suc B} {f} {g} = record { arr = proj₂ (glue-iter f g id) ; isCoequalizer = record { equality = λ { Fin.zero → lemma₂ f g } @@ -96,28 +92,46 @@ makeSimpleCoequalizer {ℕ.suc B} f g = record split : {n : ℕ} → IsCoproduct {1} {n} {ℕ.suc n} (λ _ → Fin.zero) Fin.suc split = record - { [_,_] = λ { z _ Fin.zero → z Fin.zero - ; _ s (Fin.suc x) → s x } + { [_,_] = λ + { z _ Fin.zero → z Fin.zero + ; _ s (Fin.suc x) → s x + } ; inject₁ = λ { Fin.zero → refl } ; inject₂ = λ { _ → refl } ; unique = λ { h∘i₁≈f _ Fin.zero → (Equiv.sym h∘i₁≈f) Fin.zero ; h∘i₁≈f h∘i₂≈g (Fin.suc x) → (Equiv.sym h∘i₂≈g) x } } --- makeCoequalizer --- : {A B : ℕ} --- → (f g : A ⇒ B) --- → Coequalizer f g --- makeCoequalizer {ℕ.zero} f g = {! !} --- makeCoequalizer {ℕ.suc A} f g = record --- { arr = {! !} --- ; isCoequalizer = --- iterated-coequalizer --- (λ _ → Fin.zero) --- Fin.suc --- f g --- ? ? --- (split {A}) --- ? --- ? --- } +-- Coequalizers for Nat +Coeq : {A B : ℕ} (f g : A ⇒ B) → Coequalizer f g +Coeq {ℕ.zero} _ _ = makeZeroCoequalizer +Coeq {ℕ.suc A} f g = record + { arr = Q₂.arr ∘ Q₁.arr + ; isCoequalizer = + coequalizer-on-coproduct + (λ _ → Fin.zero) + Fin.suc + f + g + Q₁.arr + Q₂.arr + split + Q₁.isCoequalizer + Q₂.isCoequalizer + } + where + simpleCoeq : Coequalizer (λ _ → f (# 0)) (λ _ → g (# 0)) + simpleCoeq = makeSimpleCoequalizer + module Q₁ = Coequalizer simpleCoeq + recursiveCoeq : Coequalizer (Q₁.arr ∘ f ∘ Fin.suc) (Q₁.arr ∘ g ∘ Fin.suc) + recursiveCoeq = Coeq _ _ + module Q₂ = Coequalizer recursiveCoeq + +-- Pushouts for Nat +Push : {A B C : ℕ} (f : A ⇒ B) (g : A ⇒ C) → Pushout f g +Push {A} {B} {C} f g = + Coproduct×Coequalizer⇒Pushout B+C (Coeq (B+C.i₁ ∘ f) (B+C.i₂ ∘ g)) + where + B+C : Coproduct B C + B+C = Coprod B C + module B+C = Coproduct B+C -- cgit v1.2.3