135 lines
3.7 KiB
Agda
135 lines
3.7 KiB
Agda
module Lattice.Unit where
|
||
|
||
open import Data.Empty using (⊥-elim)
|
||
open import Data.Product using (_,_)
|
||
open import Data.Nat using (ℕ; _≤_; z≤n)
|
||
open import Data.Unit using (⊤; tt) public
|
||
open import Data.Unit.Properties using (_≟_; ≡-setoid)
|
||
open import Relation.Binary using (Setoid)
|
||
open import Relation.Binary.PropositionalEquality as Eq using (_≡_)
|
||
open import Relation.Binary.Definitions using (Decidable)
|
||
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 : Decidable _≈_
|
||
≈-dec = _≟_
|
||
|
||
instance
|
||
≈-Decidable : IsDecidable _≈_
|
||
≈-Decidable = record { R-dec = ≈-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
|
||
|
||
instance
|
||
isJoinSemilattice : IsSemilattice ⊤ _≈_ _⊔_
|
||
isJoinSemilattice = record
|
||
{ ≈-equiv = ≈-equiv
|
||
; ≈-⊔-cong = ≈-⊔-cong
|
||
; ⊔-assoc = ⊔-assoc
|
||
; ⊔-comm = ⊔-comm
|
||
; ⊔-idemp = ⊔-idemp
|
||
}
|
||
|
||
≈-⊓-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
|
||
|
||
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
|
||
}
|
||
|
||
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
|
||
isLongest {tt} {tt} (step (tt⊔tt≈tt , tt̷≈tt) _ _) = ⊥-elim (tt̷≈tt refl)
|
||
isLongest (done _) = z≤n
|
||
|
||
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
|
||
}
|