m1-internship/IFOLKripke.agda

78 lines
2.7 KiB
Agda
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

{-# OPTIONS --prop --rewriting #-}
open import PropUtil
module IFOLKripke (Term : Set) (R : Nat Set) where
open import ListUtil
open import IFOL Term R
private
variable
x : Term
y : Term
F : Form
G : Form
Γ : Con
Γ' : Con
Η : Con
Η' : Con
record Kripke : Set where
field
Worlds : Set
_≤_ : Worlds Worlds Prop
refl≤ : {w : Worlds} w w
tran≤ : {a b c : Worlds} a b b c a c
_⊩_[_] : Worlds {n : Nat} R n Args n Prop
mon⊩ : {a b : Worlds} a b {n : Nat} {r : R n} {A : Args n} a r [ A ] b r [ A ]
private
variable
w : Worlds
w' : Worlds
w₁ : Worlds
w₂ : Worlds
w₃ : Worlds
{- Extending ⊩ to Formulas and Contexts -}
_⊩ᶠ_ : Worlds Form Prop
w ⊩ᶠ (Rel r A) = w r [ A ]
w ⊩ᶠ (fp fq) = {w' : Worlds} w w' w' ⊩ᶠ fp w' ⊩ᶠ fq
w ⊩ᶠ (fp ∧∧ fq) = w ⊩ᶠ fp w ⊩ᶠ fq
w ⊩ᶠ =
w ⊩ᶠ F = { t : Term } w ⊩ᶠ F t
_⊩ᶜ_ : Worlds Con Prop
w ⊩ᶜ [] =
w ⊩ᶜ (p c) = (w ⊩ᶠ p) (w ⊩ᶜ c)
-- The extensions are monotonous
mon⊩ᶠ : w w' w ⊩ᶠ F w' ⊩ᶠ F
mon⊩ᶠ {F = Rel r A} ww' wF = mon⊩ ww' wF
mon⊩ᶠ {F = F G} ww' wF w'w'' w''F = wF (tran≤ ww' w'w'') w''F
mon⊩ᶠ {F = F ∧∧ G} ww' wF , wG = mon⊩ᶠ {F = F} ww' wF , mon⊩ᶠ {F = G} ww' wG
mon⊩ᶠ {F = } ww' wF = tt
mon⊩ᶠ {F = F} ww' wF {t} = mon⊩ᶠ {F = F t} ww' (wF {t})
mon⊩ᶜ : w w' w ⊩ᶜ Γ w' ⊩ᶜ Γ
mon⊩ᶜ {Γ = []} ww' =
mon⊩ᶜ {Γ = F Γ} ww' = mon⊩ᶠ {F = F} ww' (proj₁ ) , mon⊩ᶜ ww' (proj₂ )
{- General operator matching the shape of ⊢ -}
_⊫_ : Con Form Prop
Γ F = {w : Worlds} w ⊩ᶜ Γ w ⊩ᶠ F
{- Soundness -}
⟦_⟧ : Γ F Γ F
zero zero∈ = proj₁
zero (next∈ h) = zero h (proj₂ )
lam p = λ w≤ w'A p w'A , mon⊩ᶜ w≤
app p p₁ = p refl≤ ( p₁ )
andi p₁ p₂ = ( p₁ ) , ( p₂ )
ande₁ p = proj₁ $ p
ande₂ p = proj₂ $ p
true = tt
i p {t} = p {t}
e p {t} = p {t}