module A202401.STLC-Naturals-SWNF-NBE3 where
open import A202401.STLC-Naturals-SWNF public
open import A202401.Kit4 public
recTy : ∀ {𝓍} {X : Set 𝓍} → Ty → (Ty → X → Ty → X → X) → X → X
recTy (A ⌜⊃⌝ B) f⊃ fℕ = f⊃ A (recTy A f⊃ fℕ) B (recTy B f⊃ fℕ)
recTy ⌜ℕ⌝ f⊃ fℕ = fℕ
record Model : Set₁ where
infix 4 _≤_
field
World : Set
_≤_ : World → World → Set
refl≤ : ∀ {W} → W ≤ W
trans≤ : ∀ {W W′ W″} → W ≤ W′ → W′ ≤ W″ → W ≤ W″
⟦ℕ⟧ : World → Set
ren⟦ℕ⟧ : ∀ {W W′} → W ≤ W′ → ⟦ℕ⟧ W → ⟦ℕ⟧ W′
⟦zero⟧ : ∀ {W} → ⟦ℕ⟧ W
⟦suc⟧ : ∀ {W} → ⟦ℕ⟧ W → ⟦ℕ⟧ W
infix 3 _⊩_
_⊩_ : World → Ty → Set
W ⊩ A = recTy {X = World → Set} A
(λ A recA B recB W → ∀ {W′} → W ≤ W′ → recA W′ → recB W′)
(λ W → ⟦ℕ⟧ W)
W
field
⟦rec⟧ : ∀ {W A} → W ⊩ ⌜ℕ⌝ → W ⊩ A → W ⊩ ⌜ℕ⌝ ⌜⊃⌝ A ⌜⊃⌝ A → W ⊩ A
open Model public
module _ {ℳ : Model} where
private
module ℳ = Model ℳ
vren : ∀ {A W W′} → W ℳ.≤ W′ → W ℳ.⊩ A → W′ ℳ.⊩ A
vren {A ⌜⊃⌝ B} ϱ v = λ ϱ′ → v (ℳ.trans≤ ϱ ϱ′)
vren {⌜ℕ⌝} ϱ v = ℳ.ren⟦ℕ⟧ ϱ v
open ModelKit (kit (λ {ℳ} → _⊩_ ℳ) (λ {ℳ} {A} → vren {ℳ} {A})) public
⟦_⟧ : ∀ {Γ A} → Γ ⊢ A → Γ ⊨ A
⟦ var i ⟧ γ = ⟦ i ⟧∋ γ
⟦ ⌜λ⌝ t ⟧ γ = λ ϱ v → ⟦ t ⟧ (vren§ ϱ γ , v)
⟦ t₁ ⌜$⌝ t₂ ⟧ {ℳ = ℳ} γ = ⟦ t₁ ⟧ γ (refl≤ ℳ) $ ⟦ t₂ ⟧ γ
⟦ ⌜zero⌝ ⟧ {ℳ = ℳ} γ = ⟦zero⟧ ℳ
⟦ ⌜suc⌝ t ⟧ {ℳ = ℳ} γ = ⟦suc⟧ ℳ (⟦ t ⟧ γ)
⟦ ⌜rec⌝ {A = A} tₙ t₀ tₛ ⟧ {ℳ = ℳ} γ = ⟦rec⟧ ℳ {A = A} (⟦ tₙ ⟧ γ) (⟦ t₀ ⟧ γ) λ ϱ vₙ ϱ′ vₐ →
⟦ tₛ ⟧ ((vren§ (trans≤ ℳ ϱ ϱ′) γ , ren⟦ℕ⟧ ℳ ϱ′ vₙ) , vₐ)
𝒞 : Model
𝒞⟦rec⟧ : ∀ {W A} → 𝒞 / W ⊩ ⌜ℕ⌝ → 𝒞 / W ⊩ A → 𝒞 / W ⊩ ⌜ℕ⌝ ⌜⊃⌝ A ⌜⊃⌝ A → 𝒞 / W ⊩ A
𝒞 .World = Ctx
𝒞 ._≤_ = _⊑_
𝒞 .refl≤ = refl⊑
𝒞 .trans≤ = trans⊑
𝒞 .⟦ℕ⟧ = λ Γ → Σ (Γ ⊢ ⌜ℕ⌝) NF
𝒞 .ren⟦ℕ⟧ = λ { e (_ , p) → _ , renNF e p }
𝒞 .⟦zero⟧ = _ , ⌜zero⌝
𝒞 .⟦suc⟧ = λ { (_ , p) → _ , ⌜suc⌝ p }
𝒞 .⟦rec⟧ {A = A} = 𝒞⟦rec⟧ {A = A}
↑ : ∀ {A Γ} → Σ (Γ ⊢ A) NNF → 𝒞 / Γ ⊩ A
↓ : ∀ {A Γ} → 𝒞 / Γ ⊩ A → Σ (Γ ⊢ A) NF
𝒞⟦rec⟧ (_ , ⌜zero⌝) v₀ vₛ = v₀
𝒞⟦rec⟧ (_ , ⌜suc⌝ pₙ) v₀ vₛ = vₛ id⊑ (_ , pₙ) id⊑ v₀
𝒞⟦rec⟧ {A = A} (_ , nnf pₙ) v₀ vₛ = let _ , p₀ = ↓ {A} v₀
_ , pₛ = ↓ (vₛ (wk⊑ (wk⊑ id⊑))
(↑ {⌜ℕ⌝} (var (wk∋ zero) , var-))
id⊑ (↑ {A} (var zero , var-)))
in ↑ (_ , ⌜rec⌝ pₙ p₀ pₛ)
↑ {A ⌜⊃⌝ B} (_ , p₁) = λ e v₂ → let _ , p₂ = ↓ v₂ in
↑ (_ , renNNF e p₁ ⌜$⌝ p₂)
↑ {⌜ℕ⌝} (_ , p) = _ , nnf p
↓ {A ⌜⊃⌝ B} v = let t , p = ↓ (v (wk⊑ id⊑) (↑ {A} (var zero , var-))) in
⌜λ⌝ t , ⌜λ⌝-
↓ {⌜ℕ⌝} v = v
vid§ : ∀ {Γ} → 𝒞 / Γ ⊩§ Γ
vid§ {∙} = ∙
vid§ {Γ , A} = vren§ (wk⊑ id⊑) vid§ , ↑ {A} (var zero , var-)
⟦_⟧⁻¹ : ∀ {Γ A} → Γ ⊨ A → Σ (Γ ⊢ A) NF
⟦ v ⟧⁻¹ = ↓ (v vid§)
nbe : ∀ {Γ A} → Γ ⊢ A → Σ (Γ ⊢ A) NF
nbe t = ⟦ ⟦ t ⟧ ⟧⁻¹