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)