module Order.Semilattice.Meet.NAry where
open is-glb open Glb module _ {o â„“} {P : Poset o â„“} (l : is-meet-semilattice P) where open is-meet-semilattice l open Poset P
n-Ary meets🔗
Let be a meet semilattice, and let be a finite family of elements of We can compute meets of in via induction on the size of the family.
⋂ᶠ: ∀ {n} (f : Fin n → Ob) → Ob ⋂ᶠ{0} f = top ⋂ᶠ{1} f = f fzero ⋂ᶠ{suc (suc n)} f = f fzero ∩ ⋂ᶠ(λ i → f (fsuc i)) ⋂ᶠ-proj : ∀ {n} {f : Fin n → Ob} (i : Fin n) → ⋂ᶠf ≤ f i ⋂ᶠ-proj i with fin-view i ⋂ᶠ-proj {1} .fzero | zero = ≤-refl ⋂ᶠ-proj {suc (suc n)} .fzero | zero = ∩≤l ⋂ᶠ-proj {suc (suc n)} .(fsuc i) | suc i = ≤-trans ∩≤r (⋂ᶠ-proj i) ⋂ᶠ-universal : ∀ {n} {f : Fin n → Ob} (x : Ob) → (∀ i → x ≤ f i) → x ≤ ⋂ᶠf ⋂ᶠ-universal {n = 0} {f = f} x p = ! ⋂ᶠ-universal {n = 1} {f = f} x p = p fzero ⋂ᶠ-universal {n = suc (suc n)} {f = f} x p = ∩-universal _ (p fzero) (⋂ᶠ-universal x (p ⊙ fsuc)) Finite-glbs : ∀ {n} (f : Fin n → Ob) → Glb P f Finite-glbs f .Glb.glb = ⋂ᶠf Finite-glbs f .Glb.has-glb .is-glb.glb≤fam = ⋂ᶠ-proj Finite-glbs f .Glb.has-glb .is-glb.greatest = ⋂ᶠ-universal
Furthermore, must also have meets of finitely indexed sets. Let be a finitely indexed set with enumeration and let be an family in is a finite family in so it must have a meet. Furthermore, is surjective, so it must reflect the meet.
opaque Finitely-indexed-glbs : ∀ {ℓᵢ} {I : Type ℓᵢ} → is-finitely-indexed I → (f : I → Ob) → Glb P f Finitely-indexed-glbs {I = I} fin-indexed f = case fin-indexed of λ cov → cover-reflects-glb (cov .is-cover) (Finite-glbs (f ⊙ cov .cover)) where open Finite-cover
Meet semilattice homomorphisms must also preserve finite meets. This follows from another induction on the size of the family we are taking a meet over.
module _ {o ℓ o' ℓ'} {P : Poset o ℓ} {Q : Poset o' ℓ'} {f : Monotone P Q} {Pl Ql} (hom : is-meet-slat-hom f Pl Ql) where abstract private module Pₗ = is-meet-semilattice Pl module Qₗ = is-meet-semilattice Ql open is-meet-slat-hom hom pres-⋂ᶠ: ∀ {n} (k : Fin n → ⌞ P ⌟) → f # (⋂ᶠPl k) ≡ ⋂ᶠQl (apply f ⊙ k) pres-⋂ᶠ{n = 0} k = pres-top pres-⋂ᶠ{n = 1} k = refl pres-⋂ᶠ{n = suc (suc n)} k = f # (k fzero Pₗ.∩ ⋂ᶠPl (k ⊙ fsuc)) ≡⟨ pres-∩ _ _ ⟩≡ f # (k fzero) Qₗ.∩ f # ⋂ᶠPl (k ⊙ fsuc) ≡⟨ ap₂ Qₗ._∩_ refl (pres-⋂ᶠ(k ⊙ fsuc)) ⟩≡ ⋂ᶠQl (apply f ⊙ k) ∎