aboutsummaryrefslogtreecommitdiff
path: root/Cospan.agda
diff options
context:
space:
mode:
authorJacques Comeaux <jacquesrcomeaux@protonmail.com>2024-06-11 11:22:59 -0500
committerJacques Comeaux <jacquesrcomeaux@protonmail.com>2024-06-11 11:22:59 -0500
commite293371f59d1d8d2786cde5ef29182499d560d42 (patch)
treefcecc27fcf1605affe0fb9523e478d54c7cbe8a0 /Cospan.agda
parentc3982b7fd9561fec34e60b28c0f20f03e9926f81 (diff)
Begin defining category of cospans
Diffstat (limited to 'Cospan.agda')
-rw-r--r--Cospan.agda124
1 files changed, 124 insertions, 0 deletions
diff --git a/Cospan.agda b/Cospan.agda
new file mode 100644
index 0000000..651d883
--- /dev/null
+++ b/Cospan.agda
@@ -0,0 +1,124 @@
+{-# OPTIONS --without-K --safe #-}
+
+open import Categories.Category using (Category)
+open import Categories.Diagram.Pushout using (Pushout)
+open import Categories.Diagram.Pushout.Properties using (glue; swap)
+open import Categories.Object.Coproduct using (Coproduct)
+open import Category.Cocomplete.Bundle using (FinitelyCocompleteCategory)
+open import Function using (flip)
+open import Level using (_⊔_)
+
+open import Relation.Binary.PropositionalEquality using (_≡_; refl; cong; sym)
+
+module Cospan {o ℓ e} (𝒞 : FinitelyCocompleteCategory o ℓ e) where
+
+open FinitelyCocompleteCategory 𝒞
+open import Categories.Morphism U
+
+private
+
+ variable
+ A B C D X Y Z : Obj
+ f g h : A ⇒ B
+
+record Cospan (A B : Obj) : Set (o ⊔ ℓ) where
+
+ field
+ {N} : Obj
+ f₁ : A ⇒ N
+ f₂ : B ⇒ N
+
+compose : Cospan A B → Cospan B C → Cospan A C
+compose c₁ c₂ = record { f₁ = p.i₁ ∘ C₁.f₁ ; f₂ = p.i₂ ∘ C₂.f₂ }
+ where
+ module C₁ = Cospan c₁
+ module C₂ = Cospan c₂
+ module p = pushout C₁.f₂ C₂.f₁
+
+identity : Cospan A A
+identity = record { f₁ = id ; f₂ = id }
+
+compose-3 : Cospan A B → Cospan B C → Cospan C D → Cospan A D
+compose-3 c₁ c₂ c₃ = record { f₁ = P₃.i₁ ∘ P₁.i₁ ∘ C₁.f₁ ; f₂ = P₃.i₂ ∘ P₂.i₂ ∘ C₃.f₂ }
+ where
+ module C₁ = Cospan c₁
+ module C₂ = Cospan c₂
+ module C₃ = Cospan c₃
+ module P₁ = pushout C₁.f₂ C₂.f₁
+ module P₂ = pushout C₂.f₂ C₃.f₁
+ module P₃ = pushout P₁.i₂ P₂.i₁
+
+record Same (P P′ : Cospan A B) : Set (ℓ ⊔ e) where
+
+ field
+ iso : Cospan.N P ≅ Cospan.N P′
+ from∘f₁≈f₁′ : _≅_.from iso ∘ Cospan.f₁ P ≈ Cospan.f₁ P′
+ from∘f₂≈f₂′ : _≅_.from iso ∘ Cospan.f₂ P ≈ Cospan.f₂ P′
+
+glue-i₁ : (p : Pushout U f g) → Pushout U h (Pushout.i₁ p) → Pushout U (h ∘ f) g
+glue-i₁ p = glue U p
+
+glue-i₂ : (p₁ : Pushout U f g) → Pushout U (Pushout.i₂ p₁) h → Pushout U f (h ∘ g)
+glue-i₂ p₁ p₂ = swap U (glue U (swap U p₁) (swap U p₂))
+
+compose-3-right
+ : {c₁ : Cospan A B}
+ {c₂ : Cospan B C}
+ {c₃ : Cospan C D}
+ → Same (compose c₁ (compose c₂ c₃)) (compose-3 c₁ c₂ c₃)
+compose-3-right {A} {_} {_} {_} {c₁} {c₂} {c₃} = record
+ { iso = record
+ { from = P₄′.universal P₄.commute
+ ; to = P₄.universal P₄′.commute
+ ; iso = {! !}
+ }
+ ; from∘f₁≈f₁′ = sym-assoc ○ P₄′.universal∘i₁≈h₁ ⟩∘⟨refl ○ assoc
+ ; from∘f₂≈f₂′ = sym-assoc ○ P₄′.universal∘i₂≈h₂ ⟩∘⟨refl
+ }
+ where
+ open HomReasoning
+ module C₁ = Cospan c₁
+ module C₂ = Cospan c₂
+ module C₃ = Cospan c₃
+ P₁ = pushout C₁.f₂ C₂.f₁
+ P₂ = pushout C₂.f₂ C₃.f₁
+ module P₁ = Pushout P₁
+ module P₂ = Pushout P₂
+ P₃ = pushout P₁.i₂ P₂.i₁
+ module P₃ = Pushout P₃
+ P₄ : Pushout U C₁.f₂ (P₂.i₁ ∘ C₂.f₁)
+ P₄ = glue-i₂ P₁ P₃
+ module P₄ = Pushout P₄
+ P₄′ : Pushout U C₁.f₂ (P₂.i₁ ∘ C₂.f₁)
+ P₄′ = pushout C₁.f₂ (P₂.i₁ ∘ C₂.f₁)
+ module P₄′ = Pushout P₄′
+
+compose-assoc
+ : {c₁ : Cospan A B}
+ {c₂ : Cospan B C}
+ {c₃ : Cospan C D}
+ → Same (compose c₁ (compose c₂ c₃)) (compose (compose c₁ c₂) c₃)
+compose-assoc = ?
+
+compose-sym-assoc
+ : {c₁ : Cospan A B}
+ {c₂ : Cospan B C}
+ {c₃ : Cospan C D}
+ → Same (compose (compose c₁ c₂) c₃) (compose c₁ (compose c₂ c₃))
+compose-sym-assoc = ?
+
+CospanC : Category _ _ _
+CospanC = record
+ { Obj = Obj
+ ; _⇒_ = Cospan
+ ; _≈_ = Same
+ ; id = identity
+ ; _∘_ = flip compose
+ ; assoc = ?
+ ; sym-assoc = compose-sym-assoc
+ ; identityˡ = ?
+ ; identityʳ = {! !}
+ ; identity² = {! !}
+ ; equiv = {! !}
+ ; ∘-resp-≈ = {! !}
+ }