diff options
| author | Chloe Brown <chloe.brown.00@outlook.com> | 2021-03-05 15:21:28 +0000 | 
|---|---|---|
| committer | Chloe Brown <chloe.brown.00@outlook.com> | 2021-03-05 15:21:28 +0000 | 
| commit | a17b12baa957d7563a4240c8b46a12bf4e465423 (patch) | |
| tree | 2e4fbc41187e3b9b57c9febfee82eaf106709d9d | |
| parent | 8fa61609ca049d960922128f32d7509e4055227d (diff) | |
Prove satisfiability for τ⊥.
| -rw-r--r-- | src/Cfe/Type.agda | 3 | ||||
| -rw-r--r-- | src/Cfe/Type/Properties.agda | 47 | 
2 files changed, 49 insertions, 1 deletions
| diff --git a/src/Cfe/Type.agda b/src/Cfe/Type.agda index 06a64c5..1c1a05a 100644 --- a/src/Cfe/Type.agda +++ b/src/Cfe/Type.agda @@ -6,4 +6,5 @@ module Cfe.Type    {c ℓ} (over : Setoid c ℓ)    where -open import Cfe.Type.Base public +open import Cfe.Type.Base over public +open import Cfe.Type.Properties over public diff --git a/src/Cfe/Type/Properties.agda b/src/Cfe/Type/Properties.agda new file mode 100644 index 0000000..14e871b --- /dev/null +++ b/src/Cfe/Type/Properties.agda @@ -0,0 +1,47 @@ +{-# OPTIONS --without-K --safe #-} + +open import Relation.Binary using (Setoid) + +module Cfe.Type.Properties +  {c ℓ} (over : Setoid c ℓ) +  where + +open Setoid over using () renaming (Carrier to C; _≈_ to _∼_) + +open import Cfe.Language over +open import Cfe.Type.Base over +open import Data.Empty +open import Data.List +open import Data.Product +open import Function + +⊨-anticongˡ : ∀ {a aℓ b bℓ fℓ lℓ} {A : Language a aℓ} {B : Language b bℓ} {τ : Type fℓ lℓ} → B ≤ A → A ⊨ τ → B ⊨ τ +⊨-anticongˡ B≤A A⊨τ = record +  { n⇒n = A⊨τ.n⇒n ∘ B≤A.f +  ; f⇒f = A⊨τ.f⇒f ∘ map₂ B≤A.f +  ; l⇒l = A⊨τ.l⇒l ∘ map₂ (map₂ (map₂ B≤A.f)) +  } +  where +  module B≤A = _≤_ B≤A +  module A⊨τ = _⊨_ A⊨τ + +L⊨τ⊥⇒L≈∅ : ∀ {a aℓ} {L : Language a aℓ} → L ⊨ τ⊥ → L ≈ ∅ +L⊨τ⊥⇒L≈∅ {L = L} L⊨τ⊥ = record +  { f = λ {l} l∈L → elim l l∈L +  ; f⁻¹ = λ () +  ; cong₁ = λ {l} {_} {l∈L} → ⊥-elim (elim l l∈L) +  ; cong₂ = λ {_} {_} {} +  } +  where +  module L⊨τ⊥ = _⊨_ L⊨τ⊥ + +  elim : ∀ l (l∈L : l ∈ L) → l ∈ ∅ +  elim [] []∈L = L⊨τ⊥.n⇒n []∈L +  elim (x ∷ l) xl∈L = L⊨τ⊥.f⇒f (-, xl∈L) + +∅⊨τ⊥ : ∅ ⊨ τ⊥ +∅⊨τ⊥ = record +  { n⇒n = λ () +  ; f⇒f = λ () +  ; l⇒l = λ () +  } | 
