open import Graded.Modality
open import Graded.Usage.Restrictions
open import Definition.Typed.Restrictions
module Graded.FullReduction
{a} {M : Set a}
{𝕄 : Modality M}
(TR : Type-restrictions 𝕄)
(UR : Usage-restrictions 𝕄)
where
open Modality 𝕄
open Type-restrictions TR
open Usage-restrictions UR
open import Tools.Bool
open import Tools.Empty
open import Tools.Fin
open import Tools.Function
open import Tools.Level
open import Tools.Nat using (Nat)
open import Tools.Product
import Tools.PropositionalEquality as PE
import Tools.Reasoning.PartialOrder
import Tools.Reasoning.PropositionalEquality
open import Tools.Relation
open import Tools.Sum using (_⊎_; inj₁; inj₂)
open import Tools.Unit
open import Definition.Untyped M as U
open import Definition.Typed TR
open import Definition.Typed.Eta-long-normal-form TR
open import Definition.Typed.Properties TR
open import Definition.Typed.Weakening TR
open import Definition.Typed.Consequences.DerivedRules TR
open import Definition.Typed.Consequences.InverseUniv TR
open import Definition.Typed.Consequences.Inversion TR
open import Definition.Typed.Consequences.NeTypeEq TR
open import Definition.Typed.Consequences.Substitution TR
open import Definition.Typed.Consequences.Stability TR
open import Definition.Typed.Consequences.Syntactic TR
open import Definition.Conversion TR
open import Definition.Conversion.Consequences.Completeness TR
import Definition.Conversion.FullReduction TR as FR
open import Definition.Conversion.Soundness TR
open import Definition.Conversion.Whnf TR
open import Graded.Context 𝕄
open import Graded.Context.Properties 𝕄
open import Graded.FullReduction.Assumptions TR UR
open import Graded.Modality.Properties 𝕄
open import Graded.Reduction TR UR
open import Graded.Usage 𝕄 UR
open import Graded.Usage.Inversion 𝕄 UR
open import Graded.Usage.Properties 𝕄 UR
open import Graded.Usage.Weakening 𝕄 UR
open import Graded.Mode 𝕄
private
variable
n : Nat
Γ : Con Term n
A A′ t t′ : Term n
p : M
γ : Conₘ n
m : Mode
q r : M
s : Strength
module _ (as : Full-reduction-assumptions) where
open Full-reduction-assumptions as
open Full-reduction-assumptions′
(Full-reduction-assumptions⇔Full-reduction-assumptions′
.proj₁ as)
private
Unitʷ-η→ :
Unitʷ-η → Unitʷ-allowed → Unitrec-allowed 𝟙ᵐ p q →
p ≤ 𝟘
Unitʷ-η→ η ok _ =
case sink⊎𝟙≤𝟘 ok (inj₂ η) of λ where
(inj₁ (() , _))
(inj₂ 𝟙≤𝟘) → ≤𝟘⇔𝟙≤𝟘 .proj₂ 𝟙≤𝟘
Unit-lemma :
Unit-allowed s → Unit-with-η s → γ ▸[ m ] t → γ ▸[ m ] star s
Unit-lemma {s} {γ} {m} ok η ▸t =
case lemma of λ
(δ , prop , γ≤) →
case PE.singleton s of λ where
(𝕤 , PE.refl) → sub (starˢₘ (prop ∘→ inj₂)) γ≤
(𝕨 , PE.refl) → sub starₘ $ begin
γ ≤⟨ γ≤ ⟩
⌜ m ⌝ ·ᶜ δ ≈˘⟨ ·ᶜ-congˡ (prop (inj₁ PE.refl)) ⟩
⌜ m ⌝ ·ᶜ 𝟘ᶜ ≈⟨ ·ᶜ-zeroʳ _ ⟩
𝟘ᶜ ∎
where
open ≤ᶜ-reasoning
lemma :
∃ λ δ → (s PE.≡ 𝕨 ⊎ ¬Starˢ-sink → 𝟘ᶜ ≈ᶜ δ) × γ ≤ᶜ ⌜ m ⌝ ·ᶜ δ
lemma =
case PE.singleton m of λ where
(𝟘ᵐ , PE.refl) →
𝟘ᶜ , (λ _ → ≈ᶜ-refl)
, (begin
γ ≤⟨ ▸-𝟘ᵐ ▸t ⟩
𝟘ᶜ ≈˘⟨ ·ᶜ-zeroˡ _ ⟩
𝟘 ·ᶜ 𝟘ᶜ ∎)
(𝟙ᵐ , PE.refl) → case sink⊎≤𝟘 ok η of λ where
(inj₁ (PE.refl , sink)) →
γ
, (λ where
(inj₁ ())
(inj₂ ¬sink) →
⊥-elim (not-sink-and-no-sink sink ¬sink))
, (begin
γ ≈˘⟨ ·ᶜ-identityˡ _ ⟩
𝟙 ·ᶜ γ ∎)
(inj₂ ≤𝟘) →
𝟘ᶜ
, (λ _ → ≈ᶜ-refl)
, (begin
γ ≤⟨ ≤ᶜ𝟘ᶜ ≤𝟘 ⟩
𝟘ᶜ ≈˘⟨ ·ᶜ-identityˡ _ ⟩
𝟙 ·ᶜ 𝟘ᶜ ∎)
Σ-η-lemma :
∀ m →
Σˢ-allowed p q →
γ ▸[ m ] t →
∃ λ δ → δ ▸[ m ᵐ· p ] fst p t × γ ≤ᶜ p ·ᶜ δ
Σ-η-lemma {p = p} {γ = γ} = λ where
𝟘ᵐ[ ok ] _ ▸t →
𝟘ᶜ
, fstₘ 𝟘ᵐ[ ok ] (▸-𝟘 ▸t) PE.refl (λ ())
, (let open Tools.Reasoning.PartialOrder ≤ᶜ-poset in begin
γ ≤⟨ ▸-𝟘ᵐ ▸t ⟩
𝟘ᶜ ≈˘⟨ ·ᶜ-zeroʳ _ ⟩
p ·ᶜ 𝟘ᶜ ∎)
𝟙ᵐ ok ▸t →
⌜ ⌞ p ⌟ ⌝ ·ᶜ γ
, fstₘ 𝟙ᵐ
(▸-cong
(let open Tools.Reasoning.PropositionalEquality in
⌞ p ⌟ ·ᵐ 𝟙ᵐ ≡⟨ ·ᵐ-identityʳ _ ⟩
⌞ p ⌟ ∎)
(▸-· ▸t))
PE.refl
(⌞⌟≡𝟙ᵐ→≤𝟙 ok)
, (let open Tools.Reasoning.PartialOrder ≤ᶜ-poset in begin
γ ≤⟨ ·ᶜ-increasing (·-increasing ok) ⟩
p ·ᶜ γ ≈˘⟨ ·ᶜ-congʳ ·⌜⌞⌟⌝ ⟩
(p · ⌜ ⌞ p ⌟ ⌝) ·ᶜ γ ≈⟨ ·ᶜ-assoc _ _ _ ⟩
p ·ᶜ ⌜ ⌞ p ⌟ ⌝ ·ᶜ γ ∎)
mutual
fullRedNe :
(⊢t : Γ ⊢ t ~ t′ ↑ A) → γ ▸[ m ] t →
γ ▸[ m ] FR.fullRedNe ⊢t .proj₁
fullRedNe {Γ = Γ} = λ where
(var-refl _ _) ▸x →
▸x
(app-cong t~ u↑) ▸tu →
case inv-usage-app ▸tu of λ {
(invUsageApp ▸t ▸u γ≤) →
sub (fullRedNe~↓ t~ ▸t ∘ₘ fullRedTermConv↑ u↑ ▸u) γ≤ }
(fst-cong t~) ▸fst-t →
case inv-usage-fst ▸fst-t of λ {
(invUsageFst m′ PE.refl ▸t γ≤ ok) →
sub (fstₘ m′ (fullRedNe~↓ t~ ▸t) PE.refl ok) γ≤ }
(snd-cong t~) ▸snd-t →
case inv-usage-snd ▸snd-t of λ {
(invUsageSnd ▸t γ≤) →
sub (sndₘ (fullRedNe~↓ t~ ▸t)) γ≤ }
(natrec-cong A↑ t↑ u↑ v~) ▸natrec →
case inv-usage-natrec ▸natrec of λ {
(invUsageNatrec ▸t ▸u ▸v ▸A γ≤ extra) →
case extra of λ where
invUsageNatrecNr →
sub (natrecₘ (fullRedTermConv↑ t↑ ▸t) (fullRedTermConv↑ u↑ ▸u)
(fullRedNe~↓ v~ ▸v) (fullRedConv↑ A↑ ▸A))
γ≤
(invUsageNatrecNoNr χ≤δ χ≤η χ≤θ fix) →
sub (natrec-no-nrₘ (fullRedTermConv↑ t↑ ▸t)
(fullRedTermConv↑ u↑ ▸u) (fullRedNe~↓ v~ ▸v)
(fullRedConv↑ A↑ ▸A) χ≤δ χ≤η χ≤θ fix)
γ≤ }
(prodrec-cong C↑ u~ v↑) ▸prodrec →
case inv-usage-prodrec ▸prodrec of λ {
(invUsageProdrec ▸u ▸v ▸C ok₁ γ≤) →
sub (prodrecₘ (fullRedNe~↓ u~ ▸u) (fullRedTermConv↑ v↑ ▸v)
(fullRedConv↑ C↑ ▸C) ok₁)
γ≤ }
(emptyrec-cong A↑ t~) ▸emptyrec →
case inv-usage-emptyrec ▸emptyrec of λ {
(invUsageEmptyrec ▸t ▸A ok γ≤) →
sub (emptyrecₘ (fullRedNe~↓ t~ ▸t) (fullRedConv↑ A↑ ▸A) ok) γ≤ }
(unitrec-cong A↑ t~ u↑ _) ▸unitrec →
case inv-usage-unitrec ▸unitrec of λ {
(invUsageUnitrec ▸t ▸u ▸A ok γ≤) →
sub (unitrecₘ (fullRedNe~↓ t~ ▸t) (fullRedTermConv↑ u↑ ▸u)
(fullRedConv↑ A↑ ▸A) ok)
γ≤ }
(J-cong A↑ t↑ B↑ u↑ v↑ w~ _) ▸J →
case inv-usage-J ▸J of λ where
(invUsageJ ok₁ ok₂ ▸A ▸t ▸B ▸u ▸v ▸w γ≤) →
sub (Jₘ ok₁ ok₂ (fullRedConv↑ A↑ ▸A)
(fullRedTermConv↑ t↑ ▸t) (fullRedConv↑ B↑ ▸B)
(fullRedTermConv↑ u↑ ▸u) (fullRedTermConv↑ v↑ ▸v)
(fullRedNe~↓ w~ ▸w))
γ≤
(invUsageJ₀₁ ok p≡𝟘 q≡𝟘 ▸A ▸t ▸B ▸u ▸v ▸w γ≤) →
sub (J₀ₘ₁ ok p≡𝟘 q≡𝟘 (fullRedConv↑ A↑ ▸A)
(fullRedTermConv↑ t↑ ▸t) (fullRedConv↑ B↑ ▸B)
(fullRedTermConv↑ u↑ ▸u) (fullRedTermConv↑ v↑ ▸v)
(fullRedNe~↓ w~ ▸w))
γ≤
(invUsageJ₀₂ ok ▸A ▸t ▸B ▸u ▸v ▸w γ≤) →
sub (J₀ₘ₂ ok (fullRedConv↑ A↑ ▸A) (fullRedTermConv↑ t↑ ▸t)
(fullRedConv↑ B↑ ▸B) (fullRedTermConv↑ u↑ ▸u)
(fullRedTermConv↑ v↑ ▸v) (fullRedNe~↓ w~ ▸w))
γ≤
(K-cong A↑ t↑ B↑ u↑ v~ _ _) ▸K →
case inv-usage-K ▸K of λ where
(invUsageK ok₁ ok₂ ▸A ▸t ▸B ▸u ▸v γ≤) →
sub (Kₘ ok₁ ok₂ (fullRedConv↑ A↑ ▸A)
(fullRedTermConv↑ t↑ ▸t) (fullRedConv↑ B↑ ▸B)
(fullRedTermConv↑ u↑ ▸u) (fullRedNe~↓ v~ ▸v))
γ≤
(invUsageK₀₁ ok p≡𝟘 ▸A ▸t ▸B ▸u ▸v γ≤) →
sub (K₀ₘ₁ ok p≡𝟘 (fullRedConv↑ A↑ ▸A)
(fullRedTermConv↑ t↑ ▸t) (fullRedConv↑ B↑ ▸B)
(fullRedTermConv↑ u↑ ▸u) (fullRedNe~↓ v~ ▸v))
γ≤
(invUsageK₀₂ ok ▸A ▸t ▸B ▸u ▸v γ≤) →
sub (K₀ₘ₂ ok (fullRedConv↑ A↑ ▸A) (fullRedTermConv↑ t↑ ▸t)
(fullRedConv↑ B↑ ▸B) (fullRedTermConv↑ u↑ ▸u)
(fullRedNe~↓ v~ ▸v))
γ≤
([]-cong-cong A↑ t↑ u↑ v~ _ _) ▸[]-cong →
case inv-usage-[]-cong ▸[]-cong of λ {
(invUsage-[]-cong ▸A ▸t ▸u ▸v γ≤) →
sub ([]-congₘ (fullRedConv↑ A↑ ▸A) (fullRedTermConv↑ t↑ ▸t)
(fullRedTermConv↑ u↑ ▸u) (fullRedNe~↓ v~ ▸v))
γ≤ }
fullRedNe~↓ :
(⊢t : Γ ⊢ t ~ t′ ↓ A) → γ ▸[ m ] t →
γ ▸[ m ] FR.fullRedNe~↓ ⊢t .proj₁
fullRedNe~↓ ([~] _ _ k~l) γ▸t =
fullRedNe k~l γ▸t
fullRedConv↑ :
(⊢A : Γ ⊢ A [conv↑] A′) → γ ▸[ m ] A →
γ ▸[ m ] FR.fullRedConv↑ ⊢A .proj₁
fullRedConv↑ ([↑] _ _ (D , _) _ A′<>B′) γ▸A =
fullRedConv↓ A′<>B′ (usagePres* Unitʷ-η→ γ▸A D)
fullRedConv↓ :
(⊢A : Γ ⊢ A [conv↓] A′) → γ ▸[ m ] A →
γ ▸[ m ] FR.fullRedConv↓ ⊢A .proj₁
fullRedConv↓ = λ where
(U-refl _) ▸U → ▸U
(ℕ-refl _) ▸ℕ → ▸ℕ
(Empty-refl _) ▸⊥ → ▸⊥
(Unit-refl _ _) ▸⊤ → ▸⊤
(ne A~) ▸A → fullRedNe~↓ A~ ▸A
(ΠΣ-cong ⊢A A↑ B↑ ok) ▸ΠΣAB →
case inv-usage-ΠΣ ▸ΠΣAB of λ {
(invUsageΠΣ ▸A ▸B γ≤) →
sub (ΠΣₘ (fullRedConv↑ A↑ ▸A) (fullRedConv↑ B↑ ▸B)) γ≤ }
(Id-cong A↑ t↑ u↑) ▸Id →
case inv-usage-Id ▸Id of λ where
(invUsageId ok ▸A ▸t ▸u γ≤) →
sub (Idₘ ok (fullRedConv↑ A↑ ▸A) (fullRedTermConv↑ t↑ ▸t)
(fullRedTermConv↑ u↑ ▸u))
γ≤
(invUsageId₀ ok ▸A ▸t ▸u γ≤) →
sub (Id₀ₘ ok (fullRedConv↑ A↑ ▸A) (fullRedTermConv↑ t↑ ▸t)
(fullRedTermConv↑ u↑ ▸u))
γ≤
fullRedTermConv↑ :
(⊢t : Γ ⊢ t [conv↑] t′ ∷ A) → γ ▸[ m ] t →
γ ▸[ m ] FR.fullRedTermConv↑ ⊢t .proj₁
fullRedTermConv↑ ([↑]ₜ _ _ _ _ (d , _) _ t<>u) γ▸t =
fullRedTermConv↓ t<>u (usagePres*Term Unitʷ-η→ γ▸t d)
fullRedTermConv↓ :
(⊢t : Γ ⊢ t [conv↓] t′ ∷ A) → γ ▸[ m ] t →
γ ▸[ m ] FR.fullRedTermConv↓ ⊢t .proj₁
fullRedTermConv↓ {Γ = Γ} {t = t} {γ = γ} {m = m} = λ where
(ℕ-ins t~) ▸t → fullRedNe~↓ t~ ▸t
(Empty-ins t~) ▸t → fullRedNe~↓ t~ ▸t
(Unit-ins t~) ▸t →
fullRedTermConv↓-Unit-ins t~ ▸t (Unit-with-η? _)
(Σʷ-ins _ _ t~) ▸t → fullRedNe~↓ t~ ▸t
(ne-ins _ _ _ t~↓B) ▸t → fullRedNe~↓ t~↓B ▸t
(univ _ _ A↓) ▸A → fullRedConv↓ A↓ ▸A
(zero-refl _) ▸zero → ▸zero
(starʷ-refl _ _ _) ▸star → ▸star
(suc-cong t↑) ▸suc-t →
case inv-usage-suc ▸suc-t of λ {
(invUsageSuc ▸t γ≤) →
sub (sucₘ (fullRedTermConv↑ t↑ ▸t)) γ≤ }
(prod-cong _ _ t↑ u↑ _) ▸t,u →
case inv-usage-prodʷ ▸t,u of λ {
(invUsageProdʷ ▸t ▸u γ≤) →
sub (prodʷₘ (fullRedTermConv↑ t↑ ▸t) (fullRedTermConv↑ u↑ ▸u))
γ≤ }
(η-eq {p = p} _ _ _ _ t0≡u0) ▸t →
let open Tools.Reasoning.PartialOrder ≤ᶜ-poset in
lamₘ $
sub (fullRedTermConv↑ t0≡u0 (wkUsage (step id) ▸t ∘ₘ var)) $
begin
γ ∙ ⌜ m ⌝ · p ≈⟨ ≈ᶜ-refl ∙ ⌜⌝-·-comm m ⟩
γ ∙ p · ⌜ m ⌝ ≈˘⟨ +ᶜ-identityʳ _ ∙ ·⌜ᵐ·⌝ m ⟩
γ +ᶜ 𝟘ᶜ ∙ p · ⌜ m ᵐ· p ⌝ ≈˘⟨ +ᶜ-congˡ (·ᶜ-zeroʳ _) ∙ +-identityˡ _ ⟩
γ +ᶜ p ·ᶜ 𝟘ᶜ ∙ 𝟘 + p · ⌜ m ᵐ· p ⌝ ∎
(Σ-η {p = p} ⊢t _ _ _ fst-t↑ snd-t↑) ▸t →
case inversion-ΠΣ (syntacticTerm ⊢t) of λ {
(_ , _ , ok) →
case Σ-η-lemma m ok ▸t of λ {
(δ , ▸fst-t , γ≤) →
let open Tools.Reasoning.PartialOrder ≤ᶜ-poset in
sub (prodˢₘ (fullRedTermConv↑ fst-t↑ ▸fst-t)
(fullRedTermConv↑ snd-t↑ (sndₘ ▸t))) $
begin
γ ≤⟨ ∧ᶜ-greatest-lower-bound γ≤ ≤ᶜ-refl ⟩
p ·ᶜ δ ∧ᶜ γ ∎ }}
(η-unit ⊢t _ _ _ η) ▸t →
Unit-lemma (⊢∷Unit→Unit-allowed ⊢t) η ▸t
(Id-ins _ v~) ▸v → fullRedNe~↓ v~ ▸v
(rfl-refl _) ▸rfl → sub rflₘ (inv-usage-rfl ▸rfl)
private
fullRedTermConv↓-Unit-ins :
(⊢t : Γ ⊢ t ~ t′ ↓ Unit s) → γ ▸[ m ] t →
(Unit-with-η? : Unit-with-η s ⊎ s PE.≡ 𝕨 × ¬ Unitʷ-η) →
γ ▸[ m ] FR.fullRedTermConv↓-Unit-ins ⊢t Unit-with-η? .proj₁
fullRedTermConv↓-Unit-ins t~ ▸t = λ where
(inj₂ (PE.refl , _)) → fullRedNe~↓ t~ ▸t
(inj₁ η) →
case syntacticEqTerm (soundness~↓ t~) of λ
(⊢Unit , _ , _) →
Unit-lemma (inversion-Unit ⊢Unit) η ▸t
fullRed :
Full-reduction-assumptions →
Γ ⊢ A → γ ▸[ m ] A →
∃ λ B → Γ ⊢nf B × Γ ⊢ A ≡ B × γ ▸[ m ] B
fullRed as ⊢A ▸A =
let B , ⊢B , A≡B = FR.fullRedConv↑ A≡A in
B , ⊢B , A≡B , fullRedConv↑ as A≡A ▸A
where
A≡A = completeEq (refl ⊢A)
Full-reduction-term : Set a
Full-reduction-term =
∀ {n} {Γ : Con Term n} {t A γ m} →
Γ ⊢ t ∷ A → γ ▸[ m ] t →
∃ λ u → Γ ⊢nf u ∷ A × Γ ⊢ t ≡ u ∷ A × γ ▸[ m ] u
fullRedTerm :
Full-reduction-assumptions →
Full-reduction-term
fullRedTerm as ⊢t ▸t =
let u , ⊢u , t≡u = FR.fullRedTermConv↑ t≡t in
u , ⊢u , t≡u , fullRedTermConv↑ as t≡t ▸t
where
t≡t = completeEqTerm (refl ⊢t)
Full-reduction-term⇔Full-reduction-assumptions :
Full-reduction-term ⇔ Full-reduction-assumptions
Full-reduction-term⇔Full-reduction-assumptions =
(λ red → λ where
.sink⊎𝟙≤𝟘 {s} ok η → $⟨ η-long-nf-for-0⇔sink⊎𝟙≤𝟘 ok η ⟩
(let Γ = ε ∙ Unit s
γ = ε ∙ 𝟙
A = Unit s
t = var x0
u = star s
in
Γ ⊢ t ∷ A ×
γ ▸[ 𝟙ᵐ ] t ×
Γ ⊢nf u ∷ A ×
Γ ⊢ t ≡ u ∷ A ×
(γ ▸[ 𝟙ᵐ ] u ⇔ (s PE.≡ 𝕤 × Starˢ-sink ⊎ 𝟙 ≤ 𝟘))) →⟨ (λ (⊢t , ▸t , ⊢u , t≡u , ▸u⇔) →
⊢u , t≡u , ▸u⇔ , red ⊢t ▸t) ⟩
(let Γ = ε ∙ Unit s
γ = ε ∙ 𝟙
A = Unit s
t = var x0
u = star s
in
Γ ⊢nf u ∷ A ×
Γ ⊢ t ≡ u ∷ A ×
(γ ▸[ 𝟙ᵐ ] u ⇔ (s PE.≡ 𝕤 × Starˢ-sink ⊎ 𝟙 ≤ 𝟘)) ×
∃ λ v → Γ ⊢nf v ∷ A × Γ ⊢ t ≡ v ∷ A × γ ▸[ 𝟙ᵐ ] v) →⟨ (λ (⊢u , t≡u , ▸u⇔ , v , ⊢v , t≡v , ▸v) →
v ,
PE.subst (λ u → _ ▸[ _ ] u ⇔ _)
(normal-terms-unique ⊢u ⊢v (trans (sym t≡u) t≡v))
▸u⇔ ,
▸v) ⟩
(∃ λ v →
(ε ∙ 𝟙 ▸[ 𝟙ᵐ ] v ⇔ (s PE.≡ 𝕤 × Starˢ-sink ⊎ 𝟙 ≤ 𝟘)) ×
ε ∙ 𝟙 ▸[ 𝟙ᵐ ] v) →⟨ (λ (_ , ▸v⇔ , ▸v) → ▸v⇔ .proj₁ ▸v) ⟩
s PE.≡ 𝕤 × Starˢ-sink ⊎ 𝟙 ≤ 𝟘 □
.≡𝟙⊎𝟙≤𝟘 {p = p} {q = q} →
Σˢ-allowed p q →⟨ η-long-nf-for-0⇔≡𝟙⊎≡𝟘 ⟩
(let Γ = ε ∙ (Σˢ p , q ▷ ℕ ▹ ℕ)
γ = ε ∙ 𝟙
A = Σˢ p , q ▷ ℕ ▹ ℕ
t = var x0
u = prodˢ p (fst p (var x0)) (snd p (var x0))
in
Γ ⊢ t ∷ A ×
γ ▸[ 𝟙ᵐ ] t ×
Γ ⊢nf u ∷ A ×
Γ ⊢ t ≡ u ∷ A ×
(γ ▸[ 𝟙ᵐ ] u ⇔ (p PE.≡ 𝟙 ⊎ p PE.≡ 𝟘 × T 𝟘ᵐ-allowed × 𝟙 ≤ 𝟘))) →⟨ (λ (⊢t , ▸t , ⊢u , t≡u , ▸u⇔) →
⊢u , t≡u , ▸u⇔ , red ⊢t ▸t) ⟩
(let Γ = ε ∙ (Σˢ p , q ▷ ℕ ▹ ℕ)
γ = ε ∙ 𝟙
A = Σˢ p , q ▷ ℕ ▹ ℕ
t = var x0
u = prodˢ p (fst p (var x0)) (snd p (var x0))
in
Γ ⊢nf u ∷ A ×
Γ ⊢ t ≡ u ∷ A ×
(γ ▸[ 𝟙ᵐ ] u ⇔ (p PE.≡ 𝟙 ⊎ p PE.≡ 𝟘 × T 𝟘ᵐ-allowed × 𝟙 ≤ 𝟘)) ×
∃ λ v → Γ ⊢nf v ∷ A × Γ ⊢ t ≡ v ∷ A × γ ▸[ 𝟙ᵐ ] v) →⟨ (λ (⊢u , t≡u , ▸u⇔ , v , ⊢v , t≡v , ▸v) →
v ,
PE.subst (λ u → _ ▸[ _ ] u ⇔ _)
(normal-terms-unique ⊢u ⊢v (trans (sym t≡u) t≡v))
▸u⇔ ,
▸v) ⟩
(∃ λ v →
(ε ∙ 𝟙 ▸[ 𝟙ᵐ ] v ⇔
(p PE.≡ 𝟙 ⊎ p PE.≡ 𝟘 × T 𝟘ᵐ-allowed × 𝟙 ≤ 𝟘)) ×
ε ∙ 𝟙 ▸[ 𝟙ᵐ ] v) →⟨ (λ (_ , ▸v⇔ , ▸v) → ▸v⇔ .proj₁ ▸v) ⟩
p PE.≡ 𝟙 ⊎ p PE.≡ 𝟘 × T 𝟘ᵐ-allowed × 𝟙 ≤ 𝟘 □)
, fullRedTerm
where
open Full-reduction-assumptions
open Tools.Reasoning.PartialOrder ≤-poset
Full-reduction-term-ε : Set a
Full-reduction-term-ε =
∀ {t A m} →
ε ⊢ t ∷ A → ε ▸[ m ] t →
∃ λ u → ε ⊢nf u ∷ A × ε ⊢ t ≡ u ∷ A × ε ▸[ m ] u
Full-reduction-term-ε→Full-reduction-assumptions :
Π-allowed 𝟙 r →
Full-reduction-term-ε →
Full-reduction-assumptions
Full-reduction-term-ε→Full-reduction-assumptions
{r = r} ok red = λ where
.sink⊎𝟙≤𝟘 {s} Unit-ok η → $⟨ η-long-nf-for-id⇔sink⊎𝟙≤𝟘 ok Unit-ok η ⟩
(let A = Π 𝟙 , r ▷ Unit s ▹ Unit s
t = lam 𝟙 (var x0)
u = lam 𝟙 (star s)
in
ε ⊢ t ∷ A ×
ε ▸[ 𝟙ᵐ ] t ×
ε ⊢nf u ∷ A ×
ε ⊢ t ≡ u ∷ A ×
(ε ▸[ 𝟙ᵐ ] u ⇔ (s PE.≡ 𝕤 × Starˢ-sink ⊎ 𝟙 ≤ 𝟘))) →⟨ (λ (⊢t , ▸t , ⊢u , t≡u , ▸u⇔) →
⊢u , t≡u , ▸u⇔ , red ⊢t ▸t) ⟩
(let A = Π 𝟙 , r ▷ Unit s ▹ Unit s
t = lam 𝟙 (var x0)
u = lam 𝟙 (star s)
in
ε ⊢nf u ∷ A ×
ε ⊢ t ≡ u ∷ A ×
(ε ▸[ 𝟙ᵐ ] u ⇔ (s PE.≡ 𝕤 × Starˢ-sink ⊎ 𝟙 ≤ 𝟘)) ×
∃ λ v → ε ⊢nf v ∷ A × ε ⊢ t ≡ v ∷ A × ε ▸[ 𝟙ᵐ ] v) →⟨ (λ (⊢u , t≡u , ▸u⇔ , v , ⊢v , t≡v , ▸v) →
v ,
PE.subst (λ u → _ ▸[ _ ] u ⇔ _)
(normal-terms-unique ⊢u ⊢v (trans (sym t≡u) t≡v))
▸u⇔ ,
▸v) ⟩
(∃ λ v →
(ε ▸[ 𝟙ᵐ ] v ⇔ (s PE.≡ 𝕤 × Starˢ-sink ⊎ 𝟙 ≤ 𝟘)) ×
ε ▸[ 𝟙ᵐ ] v) →⟨ (λ (_ , ▸v⇔ , ▸v) → ▸v⇔ .proj₁ ▸v) ⟩
s PE.≡ 𝕤 × Starˢ-sink ⊎ 𝟙 ≤ 𝟘 □
.≡𝟙⊎𝟙≤𝟘 {p = p} {q = q} →
Σˢ-allowed p q →⟨ η-long-nf-for-id⇔≡𝟙⊎≡𝟘 ok ⟩
(let A = Π 𝟙 , r ▷ Σˢ p , q ▷ ℕ ▹ ℕ ▹ Σˢ p , q ▷ ℕ ▹ ℕ
t = lam 𝟙 (var x0)
u = lam 𝟙 (prodˢ p (fst p (var x0)) (snd p (var x0)))
in
ε ⊢ t ∷ A ×
ε ▸[ 𝟙ᵐ ] t ×
ε ⊢nf u ∷ A ×
ε ⊢ t ≡ u ∷ A ×
(ε ▸[ 𝟙ᵐ ] u ⇔ (p PE.≡ 𝟙 ⊎ p PE.≡ 𝟘 × T 𝟘ᵐ-allowed × 𝟙 ≤ 𝟘))) →⟨ (λ (⊢t , ▸t , ⊢u , t≡u , ▸u⇔) →
⊢u , t≡u , ▸u⇔ , red ⊢t ▸t) ⟩
(let A = Π 𝟙 , r ▷ Σˢ p , q ▷ ℕ ▹ ℕ ▹ Σˢ p , q ▷ ℕ ▹ ℕ
t = lam 𝟙 (var x0)
u = lam 𝟙 (prodˢ p (fst p (var x0)) (snd p (var x0)))
in
ε ⊢nf u ∷ A ×
ε ⊢ t ≡ u ∷ A ×
(ε ▸[ 𝟙ᵐ ] u ⇔ (p PE.≡ 𝟙 ⊎ p PE.≡ 𝟘 × T 𝟘ᵐ-allowed × 𝟙 ≤ 𝟘)) ×
∃ λ v → ε ⊢nf v ∷ A × ε ⊢ t ≡ v ∷ A × ε ▸[ 𝟙ᵐ ] v) →⟨ (λ (⊢u , t≡u , ▸u⇔ , v , ⊢v , t≡v , ▸v) →
v ,
PE.subst (λ u → _ ▸[ _ ] u ⇔ _)
(normal-terms-unique ⊢u ⊢v (trans (sym t≡u) t≡v))
▸u⇔ ,
▸v) ⟩
(∃ λ v →
(ε ▸[ 𝟙ᵐ ] v ⇔ (p PE.≡ 𝟙 ⊎ p PE.≡ 𝟘 × T 𝟘ᵐ-allowed × 𝟙 ≤ 𝟘)) ×
ε ▸[ 𝟙ᵐ ] v) →⟨ (λ (_ , ▸v⇔ , ▸v) → ▸v⇔ .proj₁ ▸v) ⟩
p PE.≡ 𝟙 ⊎ p PE.≡ 𝟘 × T 𝟘ᵐ-allowed × 𝟙 ≤ 𝟘 □
where
open Full-reduction-assumptions
open Tools.Reasoning.PartialOrder ≤-poset
Full-reduction-term⇔Full-reduction-term-ε :
Π-allowed 𝟙 r →
Full-reduction-term ⇔ Full-reduction-term-ε
Full-reduction-term⇔Full-reduction-term-ε ok =
(λ red → red)
, (Full-reduction-term-ε →⟨ Full-reduction-term-ε→Full-reduction-assumptions ok ⟩
Full-reduction-assumptions →⟨ fullRedTerm ⟩
Full-reduction-term □)