module A201607.BasicIS4.Metatheory.Gentzen-BasicKripkeOno where
open import A201607.BasicIS4.Syntax.Gentzen public
open import A201607.BasicIS4.Semantics.BasicKripkeOno public
mutual
eval : ∀ {A Γ} → Γ ⊢ A → Γ ⊨ A
eval (var i) γ = lookup i γ
eval (lam t) γ = λ ξ a → eval t (mono⊩⋆ ξ γ , a)
eval (app {A} {B} t u) γ = _⟪$⟫_ {A} {B} (eval t γ) (eval u γ)
eval (multibox ts u) γ = λ ζ → eval u (thing ts γ ζ)
eval (down {A} t) γ = ⟪↓⟫ {A} (eval t γ)
eval (pair t u) γ = eval t γ , eval u γ
eval (fst t) γ = π₁ (eval t γ)
eval (snd t) γ = π₂ (eval t γ)
eval unit γ = ∙
thing : ∀ {{_ : Model}} {Δ Γ} {w : World}
→ Γ ⊢⋆ □⋆ Δ → w ⊩⋆ Γ → ∀ {v′ : World} → w R v′ → v′ ⊩⋆ □⋆ Δ
thing {∅} ∙ γ ζ = ∙
thing {Δ , B} (ts , t) γ ζ = thing ts γ ζ , λ ζ′ → eval t γ (transR ζ ζ′)
eval⋆ : ∀ {Ξ Γ} → Γ ⊢⋆ Ξ → Γ ⊨⋆ Ξ
eval⋆ {∅} ∙ γ = ∙
eval⋆ {Ξ , A} (ts , t) γ = eval⋆ ts γ , eval t γ