module A201605.AbelChapmanExtended.Renaming.OPE where
open import Function using (_∘_)
open import Relation.Binary.PropositionalEquality using (_≡_ ; refl ; cong ; cong₂)
open import A201605.AbelChapmanExtended.Syntax
open import A201605.AbelChapmanExtended.OPE
open import A201605.AbelChapmanExtended.Renaming.Syntax
mutual
ren-var-id : ∀ {Δ a} (x : Var Δ a) → ren-var id x ≡ x
ren-var-id x = refl
ren-nev-id : ∀ {Δ a} (v : Ne Val Δ a) → ren-nev id v ≡ v
ren-nev-id (loop v) = cong loop (ren-nev-id v)
ren-nev-id (var x) = refl
ren-nev-id (app v w) = cong₂ app (ren-nev-id v) (ren-val-id w)
ren-nev-id (fst v) = cong fst (ren-nev-id v)
ren-nev-id (snd v) = cong snd (ren-nev-id v)
ren-val-id : ∀ {Δ a} (v : Val Δ a) → ren-val id v ≡ v
ren-val-id (ne v) = cong ne (ren-nev-id v)
ren-val-id (lam t ρ) = cong (lam t) (ren-env-id ρ)
ren-val-id (pair v w) = cong₂ pair (ren-val-id v) (ren-val-id w)
ren-val-id unit = refl
ren-env-id : ∀ {Γ Δ} (ρ : Env Δ Γ) → ren-env id ρ ≡ ρ
ren-env-id ∅ = refl
ren-env-id (ρ , v) = cong₂ _,_ (ren-env-id ρ) (ren-val-id v)
mutual
ren-var-• : ∀ {Δ Δ′ Δ″ a} (η′ : Δ″ ⊇ Δ′) (η : Δ′ ⊇ Δ) (x : Var Δ a) →
(ren-var η′ ∘ ren-var η) x ≡ ren-var (η′ • η) x
ren-var-• id η x = refl
ren-var-• (weak η′) η x = cong pop (ren-var-• η′ η x)
ren-var-• (lift η′) id x = refl
ren-var-• (lift η′) (weak η) x = cong pop (ren-var-• η′ η x)
ren-var-• (lift η′) (lift η) top = refl
ren-var-• (lift η′) (lift η) (pop x) = cong pop (ren-var-• η′ η x)
ren-nev-• : ∀ {Δ Δ′ Δ″ a} (η′ : Δ″ ⊇ Δ′) (η : Δ′ ⊇ Δ) (v : Ne Val Δ a) →
(ren-nev η′ ∘ ren-nev η) v ≡ ren-nev (η′ • η) v
ren-nev-• η′ η (loop v) = cong loop (ren-nev-• η′ η v)
ren-nev-• η′ η (var x) = cong var (ren-var-• η′ η x)
ren-nev-• η′ η (app v w) = cong₂ app (ren-nev-• η′ η v) (ren-val-• η′ η w)
ren-nev-• η′ η (fst v) = cong fst (ren-nev-• η′ η v)
ren-nev-• η′ η (snd v) = cong snd (ren-nev-• η′ η v)
ren-val-• : ∀ {Δ Δ′ Δ″ a} (η′ : Δ″ ⊇ Δ′) (η : Δ′ ⊇ Δ) (v : Val Δ a) →
(ren-val η′ ∘ ren-val η) v ≡ ren-val (η′ • η) v
ren-val-• η′ η (ne w) = cong ne (ren-nev-• η′ η w)
ren-val-• η′ η (lam t ρ) = cong (lam t) (ren-env-• η′ η ρ)
ren-val-• η′ η (pair v w) = cong₂ pair (ren-val-• η′ η v) (ren-val-• η′ η w)
ren-val-• η′ η unit = refl
ren-env-• : ∀ {Γ Δ Δ′ Δ″} (η′ : Δ″ ⊇ Δ′) (η : Δ′ ⊇ Δ) (ρ : Env Δ Γ) →
(ren-env η′ ∘ ren-env η) ρ ≡ ren-env (η′ • η) ρ
ren-env-• η′ η ∅ = refl
ren-env-• η′ η (ρ , v) = cong₂ _,_ (ren-env-• η′ η ρ) (ren-val-• η′ η v)