2023-09-23 12:33:48 -07:00
|
|
|
|
module Lattice.Unit where
|
|
|
|
|
|
|
|
|
|
open import Data.Empty using (⊥-elim)
|
|
|
|
|
open import Data.Product using (_,_)
|
|
|
|
|
open import Data.Nat using (ℕ; _≤_; z≤n)
|
2023-09-23 17:12:12 -07:00
|
|
|
|
open import Data.Unit using (⊤; tt) public
|
2023-09-23 12:33:48 -07:00
|
|
|
|
open import Data.Unit.Properties using (_≟_; ≡-setoid)
|
|
|
|
|
open import Relation.Binary using (Setoid)
|
|
|
|
|
open import Relation.Binary.PropositionalEquality as Eq using (_≡_)
|
|
|
|
|
open import Relation.Nullary using (Dec; ¬_; yes; no)
|
|
|
|
|
open import Equivalence
|
|
|
|
|
open import Lattice
|
|
|
|
|
import Chain
|
|
|
|
|
|
|
|
|
|
open Setoid ≡-setoid using (refl; sym; trans)
|
|
|
|
|
|
|
|
|
|
_≈_ : ⊤ → ⊤ → Set
|
|
|
|
|
_≈_ = _≡_
|
|
|
|
|
|
|
|
|
|
≈-equiv : IsEquivalence ⊤ _≈_
|
|
|
|
|
≈-equiv = record
|
|
|
|
|
{ ≈-refl = refl
|
|
|
|
|
; ≈-sym = sym
|
|
|
|
|
; ≈-trans = trans
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
≈-dec : IsDecidable _≈_
|
|
|
|
|
≈-dec = _≟_
|
|
|
|
|
|
|
|
|
|
_⊔_ : ⊤ → ⊤ → ⊤
|
|
|
|
|
tt ⊔ tt = tt
|
|
|
|
|
|
|
|
|
|
_⊓_ : ⊤ → ⊤ → ⊤
|
|
|
|
|
tt ⊓ tt = tt
|
|
|
|
|
|
|
|
|
|
≈-⊔-cong : ∀ {ab₁ ab₂ ab₃ ab₄} → ab₁ ≈ ab₂ → ab₃ ≈ ab₄ → (ab₁ ⊔ ab₃) ≈ (ab₂ ⊔ ab₄)
|
|
|
|
|
≈-⊔-cong {tt} {tt} {tt} {tt} _ _ = Eq.refl
|
|
|
|
|
|
|
|
|
|
⊔-assoc : (x y z : ⊤) → ((x ⊔ y) ⊔ z) ≈ (x ⊔ (y ⊔ z))
|
|
|
|
|
⊔-assoc tt tt tt = Eq.refl
|
|
|
|
|
|
|
|
|
|
⊔-comm : (x y : ⊤) → (x ⊔ y) ≈ (y ⊔ x)
|
|
|
|
|
⊔-comm tt tt = Eq.refl
|
|
|
|
|
|
|
|
|
|
⊔-idemp : (x : ⊤) → (x ⊔ x) ≈ x
|
|
|
|
|
⊔-idemp tt = Eq.refl
|
|
|
|
|
|
2025-01-04 17:27:38 -08:00
|
|
|
|
instance
|
|
|
|
|
isJoinSemilattice : IsSemilattice ⊤ _≈_ _⊔_
|
|
|
|
|
isJoinSemilattice = record
|
|
|
|
|
{ ≈-equiv = ≈-equiv
|
|
|
|
|
; ≈-⊔-cong = ≈-⊔-cong
|
|
|
|
|
; ⊔-assoc = ⊔-assoc
|
|
|
|
|
; ⊔-comm = ⊔-comm
|
|
|
|
|
; ⊔-idemp = ⊔-idemp
|
|
|
|
|
}
|
2023-09-23 12:33:48 -07:00
|
|
|
|
|
|
|
|
|
≈-⊓-cong : ∀ {ab₁ ab₂ ab₃ ab₄} → ab₁ ≈ ab₂ → ab₃ ≈ ab₄ → (ab₁ ⊓ ab₃) ≈ (ab₂ ⊓ ab₄)
|
|
|
|
|
≈-⊓-cong {tt} {tt} {tt} {tt} _ _ = Eq.refl
|
|
|
|
|
|
|
|
|
|
⊓-assoc : (x y z : ⊤) → ((x ⊓ y) ⊓ z) ≈ (x ⊓ (y ⊓ z))
|
|
|
|
|
⊓-assoc tt tt tt = Eq.refl
|
|
|
|
|
|
|
|
|
|
⊓-comm : (x y : ⊤) → (x ⊓ y) ≈ (y ⊓ x)
|
|
|
|
|
⊓-comm tt tt = Eq.refl
|
|
|
|
|
|
|
|
|
|
⊓-idemp : (x : ⊤) → (x ⊓ x) ≈ x
|
|
|
|
|
⊓-idemp tt = Eq.refl
|
|
|
|
|
|
2025-01-04 17:27:38 -08:00
|
|
|
|
instance
|
|
|
|
|
isMeetSemilattice : IsSemilattice ⊤ _≈_ _⊓_
|
|
|
|
|
isMeetSemilattice = record
|
|
|
|
|
{ ≈-equiv = ≈-equiv
|
|
|
|
|
; ≈-⊔-cong = ≈-⊓-cong
|
|
|
|
|
; ⊔-assoc = ⊓-assoc
|
|
|
|
|
; ⊔-comm = ⊓-comm
|
|
|
|
|
; ⊔-idemp = ⊓-idemp
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
instance
|
|
|
|
|
isLattice : IsLattice ⊤ _≈_ _⊔_ _⊓_
|
|
|
|
|
isLattice = record
|
|
|
|
|
{ joinSemilattice = isJoinSemilattice
|
|
|
|
|
; meetSemilattice = isMeetSemilattice
|
|
|
|
|
; absorb-⊔-⊓ = λ { tt tt → Eq.refl }
|
|
|
|
|
; absorb-⊓-⊔ = λ { tt tt → Eq.refl }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
lattice : Lattice ⊤
|
|
|
|
|
lattice = record
|
|
|
|
|
{ _≈_ = _≈_
|
|
|
|
|
; _⊔_ = _⊔_
|
|
|
|
|
; _⊓_ = _⊓_
|
|
|
|
|
; isLattice = isLattice
|
|
|
|
|
}
|
2024-02-11 21:20:05 -08:00
|
|
|
|
|
2023-09-23 12:33:48 -07:00
|
|
|
|
open Chain _≈_ ≈-equiv (IsLattice._≺_ isLattice) (IsLattice.≺-cong isLattice)
|
|
|
|
|
|
|
|
|
|
private
|
|
|
|
|
longestChain : Chain tt tt 0
|
|
|
|
|
longestChain = done refl
|
|
|
|
|
|
|
|
|
|
isLongest : ∀ {t₁ t₂ : ⊤} {n : ℕ} → Chain t₁ t₂ n → n ≤ 0
|
2024-02-07 21:04:13 -08:00
|
|
|
|
isLongest {tt} {tt} (step (tt⊔tt≈tt , tt̷≈tt) _ _) = ⊥-elim (tt̷≈tt refl)
|
2023-09-23 12:33:48 -07:00
|
|
|
|
isLongest (done _) = z≤n
|
|
|
|
|
|
2025-01-04 17:27:38 -08:00
|
|
|
|
instance
|
|
|
|
|
fixedHeight : IsLattice.FixedHeight isLattice 0
|
|
|
|
|
fixedHeight = record
|
|
|
|
|
{ ⊥ = tt
|
|
|
|
|
; ⊤ = tt
|
|
|
|
|
; longestChain = longestChain
|
|
|
|
|
; bounded = isLongest
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
isFiniteHeightLattice : IsFiniteHeightLattice ⊤ 0 _≈_ _⊔_ _⊓_
|
|
|
|
|
isFiniteHeightLattice = record
|
|
|
|
|
{ isLattice = isLattice
|
|
|
|
|
; fixedHeight = fixedHeight
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
finiteHeightLattice : FiniteHeightLattice ⊤
|
|
|
|
|
finiteHeightLattice = record
|
|
|
|
|
{ height = 0
|
|
|
|
|
; _≈_ = _≈_
|
|
|
|
|
; _⊔_ = _⊔_
|
|
|
|
|
; _⊓_ = _⊓_
|
|
|
|
|
; isFiniteHeightLattice = isFiniteHeightLattice
|
|
|
|
|
}
|