changed rule names in Lambda, Prop to match Inference

This commit is contained in:
wadler 2018-06-24 19:45:51 -03:00
parent 2786ffb059
commit 3ba45ceb62
3 changed files with 100 additions and 81 deletions

View file

@ -149,7 +149,7 @@ data _⊢_↑_ where
data _⊢_↓_ where data _⊢_↓_ where
λ : ∀ {Γ x N A B} ƛ : ∀ {Γ x N A B}
→ Γ , x ⦂ A ⊢ N ↓ B → Γ , x ⦂ A ⊢ N ↓ B
----------------------- -----------------------
→ Γ ⊢ ƛ x ⇒ N ↓ A ⇒ B → Γ ⊢ ƛ x ⇒ N ↓ A ⇒ B
@ -246,7 +246,7 @@ synthesize Γ (M ↓ A) =
inherit Γ (ƛ x ⇒ N) (A ⇒ B) = inherit Γ (ƛ x ⇒ N) (A ⇒ B) =
do ⊢N ← inherit (Γ , x ⦂ A) N B do ⊢N ← inherit (Γ , x ⦂ A) N B
return (⊢λ ⊢N) return (⊢ƛ ⊢N)
inherit Γ (ƛ x ⇒ N) ` = inherit Γ (ƛ x ⇒ N) ` =
error⁻ "lambda cannot be of type natural" (ƛ x ⇒ N) [] error⁻ "lambda cannot be of type natural" (ƛ x ⇒ N) []
inherit Γ `zero ` = inherit Γ `zero ` =
@ -289,8 +289,8 @@ x ≠ y with x ≟ y
⊢four = ⊢four =
(⊢↓ (⊢↓
(⊢μ (⊢μ
(⊢λ (⊢ƛ
(⊢λ (⊢ƛ
(⊢case (Ax (S (_≠_ "m" "n") Z)) (⊢↑ (Ax Z) refl) (⊢case (Ax (S (_≠_ "m" "n") Z)) (⊢↑ (Ax Z) refl)
(⊢suc (⊢suc
(⊢↑ (⊢↑
@ -309,13 +309,13 @@ _ = refl
⊢fourCh : ε ⊢ fourCh ↑ ` ⊢fourCh : ε ⊢ fourCh ↑ `
⊢fourCh = ⊢fourCh =
(⊢↓ (⊢λ (⊢↑ (Ax Z · ⊢λ (⊢suc (⊢↑ (Ax Z) refl)) · ⊢zero) refl)) · (⊢↓ (⊢ƛ (⊢↑ (Ax Z · ⊢ƛ (⊢suc (⊢↑ (Ax Z) refl)) · ⊢zero) refl)) ·
⊢↑ ⊢↑
(⊢↓ (⊢↓
(⊢λ (⊢ƛ
(⊢λ (⊢ƛ
(⊢λ (⊢ƛ
(⊢λ (⊢ƛ
(⊢↑ (⊢↑
(Ax (Ax
(S (_≠_ "m" "z") (S (_≠_ "m" "z")
@ -332,16 +332,16 @@ _ = refl
refl) refl)
refl))))) refl)))))
· ·
λ ƛ
(⊢λ (⊢ƛ
(⊢↑ (⊢↑
(Ax (S (_≠_ "s" "z") Z) · (Ax (S (_≠_ "s" "z") Z) ·
⊢↑ (Ax (S (_≠_ "s" "z") Z) · ⊢↑ (Ax Z) refl) ⊢↑ (Ax (S (_≠_ "s" "z") Z) · ⊢↑ (Ax Z) refl)
refl) refl)
refl)) refl))
· ·
λ ƛ
(⊢λ (⊢ƛ
(⊢↑ (⊢↑
(Ax (S (_≠_ "s" "z") Z) · (Ax (S (_≠_ "s" "z") Z) ·
⊢↑ (Ax (S (_≠_ "s" "z") Z) · ⊢↑ (Ax Z) refl) ⊢↑ (Ax (S (_≠_ "s" "z") Z) · ⊢↑ (Ax Z) refl)
@ -391,6 +391,7 @@ _ : synthesize ε (((ƛ "x" ⇒ ⌊ "x" ⌋ ↑) ↓ ` ⇒ (` ⇒ `)))
_ = refl _ = refl
\end{code} \end{code}
## Erasure ## Erasure
\begin{code} \begin{code}
@ -409,7 +410,7 @@ _ = refl
∥ ⊢L · ⊢M ∥⁺ = ∥ ⊢L ∥⁺ DB.· ∥ ⊢M ∥⁻ ∥ ⊢L · ⊢M ∥⁺ = ∥ ⊢L ∥⁺ DB.· ∥ ⊢M ∥⁻
∥ ⊢↓ ⊢M ∥⁺ = ∥ ⊢M ∥⁻ ∥ ⊢↓ ⊢M ∥⁺ = ∥ ⊢M ∥⁻
∥ ⊢λ ⊢N ∥⁻ = DB.ƛ ∥ ⊢N ∥⁻ ∥ ⊢ƛ ⊢N ∥⁻ = DB.ƛ ∥ ⊢N ∥⁻
∥ ⊢zero ∥⁻ = DB.`zero ∥ ⊢zero ∥⁻ = DB.`zero
∥ ⊢suc ⊢M ∥⁻ = DB.`suc ∥ ⊢M ∥⁻ ∥ ⊢suc ⊢M ∥⁻ = DB.`suc ∥ ⊢M ∥⁻
∥ ⊢case ⊢L ⊢M ⊢N ∥⁻ = DB.`case ∥ ⊢L ∥⁺ ∥ ⊢M ∥⁻ ∥ ⊢N ∥⁻ ∥ ⊢case ⊢L ⊢M ⊢N ∥⁻ = DB.`case ∥ ⊢L ∥⁺ ∥ ⊢M ∥⁻ ∥ ⊢N ∥⁻

View file

@ -905,38 +905,38 @@ data _⊢_⦂_ : Context → Term → Type → Set where
→ Γ ⊢ ⌊ x ⌋ ⦂ A → Γ ⊢ ⌊ x ⌋ ⦂ A
-- ⇒-I -- ⇒-I
⇒-I : ∀ {Γ x N A B} ⊢ƛ : ∀ {Γ x N A B}
→ Γ , x ⦂ A ⊢ N ⦂ B → Γ , x ⦂ A ⊢ N ⦂ B
------------------- -------------------
→ Γ ⊢ ƛ x ⇒ N ⦂ A ⇒ B → Γ ⊢ ƛ x ⇒ N ⦂ A ⇒ B
-- ⇒-E -- ⇒-E
⇒-E : ∀ {Γ L M A B} _·_ : ∀ {Γ L M A B}
→ Γ ⊢ L ⦂ A ⇒ B → Γ ⊢ L ⦂ A ⇒ B
→ Γ ⊢ M ⦂ A → Γ ⊢ M ⦂ A
------------- -------------
→ Γ ⊢ L · M ⦂ B → Γ ⊢ L · M ⦂ B
-- -I₁ -- -I₁
-I₁ : ∀ {Γ} ⊢zero : ∀ {Γ}
-------------- --------------
→ Γ ⊢ `zero ⦂ ` → Γ ⊢ `zero ⦂ `
-- -I₂ -- -I₂
-I₂ : ∀ {Γ M} ⊢suc : ∀ {Γ M}
→ Γ ⊢ M ⦂ ` → Γ ⊢ M ⦂ `
--------------- ---------------
→ Γ ⊢ `suc M ⦂ ` → Γ ⊢ `suc M ⦂ `
-- -E -- -E
-E : ∀ {Γ L M x N A} ⊢case : ∀ {Γ L M x N A}
→ Γ ⊢ L ⦂ ` → Γ ⊢ L ⦂ `
→ Γ ⊢ M ⦂ A → Γ ⊢ M ⦂ A
→ Γ , x ⦂ ` ⊢ N ⦂ A → Γ , x ⦂ ` ⊢ N ⦂ A
------------------------------------- -------------------------------------
→ Γ ⊢ `case L [zero⇒ M |suc x ⇒ N ] ⦂ A → Γ ⊢ `case L [zero⇒ M |suc x ⇒ N ] ⦂ A
Fix : ∀ {Γ x M A} ⊢μ : ∀ {Γ x M A}
→ Γ , x ⦂ A ⊢ M ⦂ A → Γ , x ⦂ A ⊢ M ⦂ A
----------------- -----------------
→ Γ ⊢ μ x ⇒ M ⦂ A → Γ ⊢ μ x ⇒ M ⦂ A
@ -1002,9 +1002,9 @@ is a type derivation for the Church numberal two:
Γ₂ ⊢ ⌊ "s" ⌋ ⦂ A ⇒ A Γ₂ ⊢ ⌊ "s" ⌋ · ⌊ "z" ⌋ ⦂ A Γ₂ ⊢ ⌊ "s" ⌋ ⦂ A ⇒ A Γ₂ ⊢ ⌊ "s" ⌋ · ⌊ "z" ⌋ ⦂ A
-------------------------------------------------- _·_ -------------------------------------------------- _·_
Γ₂ ⊢ ⌊ "s" ⌋ · (⌊ "s" ⌋ · ⌊ "z" ⌋) ⦂ A Γ₂ ⊢ ⌊ "s" ⌋ · (⌊ "s" ⌋ · ⌊ "z" ⌋) ⦂ A
---------------------------------------------- ƛ_ ---------------------------------------------- ƛ
Γ₁ ⊢ ƛ "z" ⇒ ⌊ "s" ⌋ · (⌊ "s" ⌋ · ⌊ "z" ⌋) ⦂ A ⇒ A Γ₁ ⊢ ƛ "z" ⇒ ⌊ "s" ⌋ · (⌊ "s" ⌋ · ⌊ "z" ⌋) ⦂ A ⇒ A
---------------------------------------------------------- ƛ_ ---------------------------------------------------------- ƛ
∅ ⊢ ƛ "s" ⇒ ƛ "z" ⇒ ⌊ "s" ⌋ · (⌊ "s" ⌋ · ⌊ "z" ⌋) ⦂ A ⇒ A ∅ ⊢ ƛ "s" ⇒ ƛ "z" ⇒ ⌊ "s" ⌋ · (⌊ "s" ⌋ · ⌊ "z" ⌋) ⦂ A ⇒ A
where `∋s` and `∋z` abbreviate the two derivations: where `∋s` and `∋z` abbreviate the two derivations:
@ -1022,7 +1022,7 @@ Ch : Type → Type
Ch A = (A ⇒ A) ⇒ A ⇒ A Ch A = (A ⇒ A) ⇒ A ⇒ A
⊢twoᶜ : ∀ {A} → ∅ ⊢ twoᶜ ⦂ Ch A ⊢twoᶜ : ∀ {A} → ∅ ⊢ twoᶜ ⦂ Ch A
⊢twoᶜ = ⇒-I (⇒-I (⇒-E (Ax ∋s) (⇒-E (Ax ∋s) (Ax ∋z)))) ⊢twoᶜ = ⊢ƛ (⊢ƛ (Ax ∋s · (Ax ∋s · Ax ∋z)))
where where
∋s = S ("s" ≠ "z") Z ∋s = S ("s" ≠ "z") Z
@ -1032,11 +1032,11 @@ Ch A = (A ⇒ A) ⇒ A ⇒ A
Here are the typings corresponding to our first example. Here are the typings corresponding to our first example.
\begin{code} \begin{code}
⊢two : ∅ ⊢ two ⦂ ` ⊢two : ∅ ⊢ two ⦂ `
⊢two = -I₂ (-I₂ -I₁) ⊢two = ⊢suc (⊢suc ⊢zero)
⊢plus : ∅ ⊢ plus ⦂ ` ⇒ ` ⇒ ` ⊢plus : ∅ ⊢ plus ⦂ ` ⇒ ` ⇒ `
⊢plus = Fix (⇒-I (⇒-I (-E (Ax ∋m) (Ax ∋n) ⊢plus = ⊢μ (⊢ƛ (⊢ƛ (⊢case (Ax ∋m) (Ax ∋n)
(-I₂ (⇒-E (⇒-E (Ax ∋+) (Ax ∋m)) (Ax ∋n)))))) (⊢suc (Ax ∋+ · Ax ∋m · Ax ∋n)))))
where where
∋+ = (S ("+" ≠ "m") (S ("+" ≠ "n") (S ("+" ≠ "m") Z))) ∋+ = (S ("+" ≠ "m") (S ("+" ≠ "n") (S ("+" ≠ "m") Z)))
∋m = (S ("m" ≠ "n") Z) ∋m = (S ("m" ≠ "n") Z)
@ -1045,7 +1045,7 @@ Here are the typings corresponding to our first example.
∋n = (S ("n" ≠ "m") Z) ∋n = (S ("n" ≠ "m") Z)
⊢four : ∅ ⊢ four ⦂ ` ⊢four : ∅ ⊢ four ⦂ `
⊢four = ⇒-E (⇒-E ⊢plus ⊢two) ⊢two ⊢four = ⊢plus · ⊢two · ⊢two
\end{code} \end{code}
The two occcurrences of variable `"n"` in the original term appear The two occcurrences of variable `"n"` in the original term appear
in different contexts, and correspond here to the two different in different contexts, and correspond here to the two different
@ -1057,8 +1057,7 @@ branch of the case expression.
Here are typings for the remainder of the Church example. Here are typings for the remainder of the Church example.
\begin{code} \begin{code}
⊢plusᶜ : ∀ {A} → ∅ ⊢ plusᶜ ⦂ Ch A ⇒ Ch A ⇒ Ch A ⊢plusᶜ : ∀ {A} → ∅ ⊢ plusᶜ ⦂ Ch A ⇒ Ch A ⇒ Ch A
⊢plusᶜ = ⇒-I (⇒-I (⇒-I (⇒-I (⇒-E (⇒-E (Ax ∋m) (Ax ∋s)) ⊢plusᶜ = ⊢ƛ (⊢ƛ (⊢ƛ (⊢ƛ (Ax ∋m · Ax ∋s · (Ax ∋n · Ax ∋s · Ax ∋z)))))
(⇒-E (⇒-E (Ax ∋n) (Ax ∋s)) (Ax ∋z))))))
where where
∋m = S ("m" ≠ "z") (S ("m" ≠ "s") (S ("m" ≠ "n") Z)) ∋m = S ("m" ≠ "z") (S ("m" ≠ "s") (S ("m" ≠ "n") Z))
∋n = S ("n" ≠ "z") (S ("n" ≠ "s") Z) ∋n = S ("n" ≠ "z") (S ("n" ≠ "s") Z)
@ -1066,12 +1065,12 @@ Here are typings for the remainder of the Church example.
∋z = Z ∋z = Z
⊢sucᶜ : ∅ ⊢ sucᶜ ⦂ ` ⇒ ` ⊢sucᶜ : ∅ ⊢ sucᶜ ⦂ ` ⇒ `
⊢sucᶜ = ⇒-I (-I₂ (Ax ∋n)) ⊢sucᶜ = ⊢ƛ (⊢suc (Ax ∋n))
where where
∋n = Z ∋n = Z
⊢fourᶜ : ∅ ⊢ plusᶜ · twoᶜ · twoᶜ · sucᶜ · `zero ⦂ ` ⊢fourᶜ : ∅ ⊢ plusᶜ · twoᶜ · twoᶜ · sucᶜ · `zero ⦂ `
⊢fourᶜ = ⇒-E (⇒-E (⇒-E (⇒-E ⊢plusᶜ ⊢twoᶜ) ⊢twoᶜ) ⊢sucᶜ) -I₁ ⊢fourᶜ = ⊢plusᶜ · ⊢twoᶜ · ⊢twoᶜ · ⊢sucᶜ · ⊢zero
\end{code} \end{code}
@ -1089,20 +1088,20 @@ Typing C-l causes Agda to create a hole and tell us its expected type.
?0 : ∅ ⊢ sucᶜ ⦂ ` ⇒ ` ?0 : ∅ ⊢ sucᶜ ⦂ ` ⇒ `
Now we fill in the hole by typing C-c C-r. Agda observes that Now we fill in the hole by typing C-c C-r. Agda observes that
the outermost term in `sucᶜ` in `ƛ`, which is typed using `⇒-I`. The the outermost term in `sucᶜ` in `⊢ƛ`, which is typed using `ƛ`. The
`⇒-I` rule in turn takes one argument, which Agda leaves as a hole. `ƛ` rule in turn takes one argument, which Agda leaves as a hole.
⊢sucᶜ = ⇒-I { }1 ⊢sucᶜ = ⊢ƛ { }1
?1 : ∅ , "n" ⦂ ` ⊢ `suc ⌊ "n" ⌋ ⦂ ` ?1 : ∅ , "n" ⦂ ` ⊢ `suc ⌊ "n" ⌋ ⦂ `
We can fill in the hole by type C-c C-r again. We can fill in the hole by type C-c C-r again.
⊢sucᶜ = ⇒-I (`-I₂ { }2) ⊢sucᶜ = ⊢ƛ (⊢suc { }2)
?2 : ∅ , "n" ⦂ ` ⊢ ⌊ "n" ⌋ ⦂ ` ?2 : ∅ , "n" ⦂ ` ⊢ ⌊ "n" ⌋ ⦂ `
And again. And again.
⊢suc = ⇒-I (-I₂ (Ax { }3)) ⊢suc = ⊢ƛ (⊢suc (Ax { }3))
?3 : ∅ , "n" ⦂ ` ∋ "n" ⦂ ` ?3 : ∅ , "n" ⦂ ` ∋ "n" ⦂ `
A further attempt with C-c C-r yields the message: A further attempt with C-c C-r yields the message:
@ -1111,7 +1110,7 @@ A further attempt with C-c C-r yields the message:
We can fill in `Z` by hand. If we type C-c C-space, Agda will confirm we are done. We can fill in `Z` by hand. If we type C-c C-space, Agda will confirm we are done.
⊢suc = ⇒-I (-I₂ (Ax Z)) ⊢suc = ⊢ƛ (⊢suc (Ax Z))
The entire process can be automated using Agsy, invoked with C-c C-a. The entire process can be automated using Agsy, invoked with C-c C-a.
@ -1144,7 +1143,7 @@ application is both a natural and a function.
\begin{code} \begin{code}
nope₁ : ∀ {A} → ¬ (∅ ⊢ `zero · `suc `zero ⦂ A) nope₁ : ∀ {A} → ¬ (∅ ⊢ `zero · `suc `zero ⦂ A)
nope₁ (⇒-E () _) nope₁ (() · _)
\end{code} \end{code}
As a second example, here is a formal proof that it is not possible to As a second example, here is a formal proof that it is not possible to
@ -1153,7 +1152,7 @@ doing so requires types `A` and `B` such that `A ⇒ B ≡ A`.
\begin{code} \begin{code}
nope₂ : ∀ {A} → ¬ (∅ ⊢ ƛ "x" ⇒ ⌊ "x" ⌋ · ⌊ "x" ⌋ ⦂ A) nope₂ : ∀ {A} → ¬ (∅ ⊢ ƛ "x" ⇒ ⌊ "x" ⌋ · ⌊ "x" ⌋ ⦂ A)
nope₂ (⇒-I (⇒-E (Ax ∋x) (Ax ∋x))) = contradiction (∋-injective ∋x ∋x) nope₂ (⊢ƛ (Ax ∋x · Ax ∋x)) = contradiction (∋-injective ∋x ∋x)
where where
contradiction : ∀ {A B} → ¬ (A ⇒ B ≡ A) contradiction : ∀ {A B} → ¬ (A ⇒ B ≡ A)
contradiction () contradiction ()

View file

@ -76,12 +76,12 @@ canonical : ∀ {M A}
--------------- ---------------
→ Canonical M ⦂ A → Canonical M ⦂ A
canonical (Ax ()) () canonical (Ax ()) ()
canonical (⇒-I ⊢N) V-ƛ = C-ƛ canonical (⊢ƛ ⊢N) V-ƛ = C-ƛ
canonical (⇒-E ⊢L ⊢M) () canonical (⊢L · ⊢M) ()
canonical -I₁ V-zero = C-zero canonical ⊢zero V-zero = C-zero
canonical (-I₂ ⊢V) (V-suc VV) = C-suc (canonical ⊢V VV) canonical (⊢suc ⊢V) (V-suc VV) = C-suc (canonical ⊢V VV)
canonical (-E ⊢L ⊢M ⊢N) () canonical (⊢case ⊢L ⊢M ⊢N) ()
canonical (Fix ⊢M) () canonical (⊢μ ⊢M) ()
value : ∀ {M A} value : ∀ {M A}
→ Canonical M ⦂ A → Canonical M ⦂ A
@ -116,23 +116,23 @@ progress : ∀ {M A}
---------- ----------
→ Progress M → Progress M
progress (Ax ()) progress (Ax ())
progress (⇒-I ⊢N) = done V-ƛ progress (⊢ƛ ⊢N) = done V-ƛ
progress (⇒-E ⊢L ⊢M) with progress ⊢L progress (⊢L · ⊢M) with progress ⊢L
... | step L⟶L = step (ξ-·₁ L⟶L) ... | step L⟶L = step (ξ-·₁ L⟶L)
... | done VL with progress ⊢M ... | done VL with progress ⊢M
... | step M⟶M = step (ξ-·₂ VL M⟶M) ... | step M⟶M = step (ξ-·₂ VL M⟶M)
... | done VM with canonical ⊢L VL ... | done VM with canonical ⊢L VL
... | C-ƛ = step (β-ƛ· VM) ... | C-ƛ = step (β-ƛ· VM)
progress -I₁ = done V-zero progress ⊢zero = done V-zero
progress (-I₂ ⊢M) with progress ⊢M progress (⊢suc ⊢M) with progress ⊢M
... | step M⟶M = step (ξ-suc M⟶M) ... | step M⟶M = step (ξ-suc M⟶M)
... | done VM = done (V-suc VM) ... | done VM = done (V-suc VM)
progress (-E ⊢L ⊢M ⊢N) with progress ⊢L progress (⊢case ⊢L ⊢M ⊢N) with progress ⊢L
... | step L⟶L = step (ξ-case L⟶L) ... | step L⟶L = step (ξ-case L⟶L)
... | done VL with canonical ⊢L VL ... | done VL with canonical ⊢L VL
... | C-zero = step β-case-zero ... | C-zero = step β-case-zero
... | C-suc CL = step (β-case-suc (value CL)) ... | C-suc CL = step (β-case-suc (value CL))
progress (Fix ⊢M) = step β-μ progress (⊢μ ⊢M) = step β-μ
\end{code} \end{code}
This code reads neatly in part because we consider the This code reads neatly in part because we consider the
@ -205,12 +205,12 @@ rename : ∀ {Γ Δ}
---------------------------------- ----------------------------------
→ (∀ {M A} → Γ ⊢ M ⦂ A → Δ ⊢ M ⦂ A) → (∀ {M A} → Γ ⊢ M ⦂ A → Δ ⊢ M ⦂ A)
rename σ (Ax ∋w) = Ax (σ ∋w) rename σ (Ax ∋w) = Ax (σ ∋w)
rename σ (⇒-I ⊢N) = ⇒-I (rename (ext σ) ⊢N) rename σ (⊢ƛ ⊢N) = ⊢ƛ (rename (ext σ) ⊢N)
rename σ (⇒-E ⊢L ⊢M) = ⇒-E (rename σ ⊢L) (rename σ ⊢M) rename σ (⊢L · ⊢M) = (rename σ ⊢L) · (rename σ ⊢M)
rename σ -I₁ = -I₁ rename σ ⊢zero = ⊢zero
rename σ (-I₂ ⊢M) = -I₂ (rename σ ⊢M) rename σ (⊢suc ⊢M) = ⊢suc (rename σ ⊢M)
rename σ (-E ⊢L ⊢M ⊢N) = -E (rename σ ⊢L) (rename σ ⊢M) (rename (ext σ) ⊢N) rename σ (⊢case ⊢L ⊢M ⊢N) = ⊢case (rename σ ⊢L) (rename σ ⊢M) (rename (ext σ) ⊢N)
rename σ (Fix ⊢M) = Fix (rename (ext σ) ⊢M) rename σ (⊢μ ⊢M) = ⊢μ (rename (ext σ) ⊢M)
\end{code} \end{code}
We have three important corollaries. First, We have three important corollaries. First,
@ -316,18 +316,18 @@ subst {x = y} (Ax {x = x} Z) ⊢V with x ≟ y
subst {x = y} (Ax {x = x} (S x≢y ∋x)) ⊢V with x ≟ y subst {x = y} (Ax {x = x} (S x≢y ∋x)) ⊢V with x ≟ y
... | yes refl = ⊥-elim (x≢y refl) ... | yes refl = ⊥-elim (x≢y refl)
... | no _ = Ax ∋x ... | no _ = Ax ∋x
subst {x = y} (⇒-I {x = x} ⊢N) ⊢V with x ≟ y subst {x = y} (⊢ƛ {x = x} ⊢N) ⊢V with x ≟ y
... | yes refl = ⇒-I (rename-≡ ⊢N) ... | yes refl = ⊢ƛ (rename-≡ ⊢N)
... | no x≢y = ⇒-I (subst (rename-≢ x≢y ⊢N) ⊢V) ... | no x≢y = ⊢ƛ (subst (rename-≢ x≢y ⊢N) ⊢V)
subst (⇒-E ⊢L ⊢M) ⊢V = ⇒-E (subst ⊢L ⊢V) (subst ⊢M ⊢V) subst (⊢L · ⊢M) ⊢V = (subst ⊢L ⊢V) · (subst ⊢M ⊢V)
subst -I₁ ⊢V = -I₁ subst ⊢zero ⊢V = ⊢zero
subst (-I₂ ⊢M) ⊢V = -I₂ (subst ⊢M ⊢V) subst (⊢suc ⊢M) ⊢V = ⊢suc (subst ⊢M ⊢V)
subst {x = y} (-E {x = x} ⊢L ⊢M ⊢N) ⊢V with x ≟ y subst {x = y} (⊢case {x = x} ⊢L ⊢M ⊢N) ⊢V with x ≟ y
... | yes refl = -E (subst ⊢L ⊢V) (subst ⊢M ⊢V) (rename-≡ ⊢N) ... | yes refl = ⊢case (subst ⊢L ⊢V) (subst ⊢M ⊢V) (rename-≡ ⊢N)
... | no x≢y = -E (subst ⊢L ⊢V) (subst ⊢M ⊢V) (subst (rename-≢ x≢y ⊢N) ⊢V) ... | no x≢y = ⊢case (subst ⊢L ⊢V) (subst ⊢M ⊢V) (subst (rename-≢ x≢y ⊢N) ⊢V)
subst {x = y} (Fix {x = x} ⊢M) ⊢V with x ≟ y subst {x = y} (⊢μ {x = x} ⊢M) ⊢V with x ≟ y
... | yes refl = Fix (rename-≡ ⊢M) ... | yes refl = ⊢μ (rename-≡ ⊢M)
... | no x≢y = Fix (subst (rename-≢ x≢y ⊢M) ⊢V) ... | no x≢y = ⊢μ (subst (rename-≢ x≢y ⊢M) ⊢V)
\end{code} \end{code}
@ -345,18 +345,37 @@ preserve : ∀ {M N A}
---------- ----------
→ ∅ ⊢ N ⦂ A → ∅ ⊢ N ⦂ A
preserve (Ax ()) preserve (Ax ())
preserve (⇒-I ⊢N) () preserve (⊢ƛ ⊢N) ()
preserve (⇒-E ⊢L ⊢M) (ξ-·₁ L⟶L) = ⇒-E (preserve ⊢L L⟶L) ⊢M preserve (⊢L · ⊢M) (ξ-·₁ L⟶L) = (preserve ⊢L L⟶L) · ⊢M
preserve (⇒-E ⊢L ⊢M) (ξ-·₂ VL M⟶M) = ⇒-E ⊢L (preserve ⊢M M⟶M) preserve (⊢L · ⊢M) (ξ-·₂ VL M⟶M) = ⊢L · (preserve ⊢M M⟶M)
preserve (⇒-E (⇒-I ⊢N) ⊢V) (β-ƛ· VV) = subst ⊢N ⊢V preserve ((⊢ƛ ⊢N) · ⊢V) (β-ƛ· VV) = subst ⊢N ⊢V
preserve -I₁ () preserve ⊢zero ()
preserve (-I₂ ⊢M) (ξ-suc M⟶M) = -I₂ (preserve ⊢M M⟶M) preserve (⊢suc ⊢M) (ξ-suc M⟶M) = ⊢suc (preserve ⊢M M⟶M)
preserve (-E ⊢L ⊢M ⊢N) (ξ-case L⟶L) = -E (preserve ⊢L L⟶L) ⊢M ⊢N preserve (⊢case ⊢L ⊢M ⊢N) (ξ-case L⟶L) = ⊢case (preserve ⊢L L⟶L) ⊢M ⊢N
preserve (-E -I₁ ⊢M ⊢N) β-case-zero = ⊢M preserve (⊢case ⊢zero ⊢M ⊢N) β-case-zero = ⊢M
preserve (-E (-I₂ ⊢V) ⊢M ⊢N) (β-case-suc VV) = subst ⊢N ⊢V preserve (⊢case (⊢suc ⊢V) ⊢M ⊢N) (β-case-suc VV) = subst ⊢N ⊢V
preserve (Fix ⊢M) (β-μ) = subst ⊢M (Fix ⊢M) preserve (⊢μ ⊢M) (β-μ) = subst ⊢M (⊢μ ⊢M)
\end{code} \end{code}
## Normalisation with streams
codata Lift (A : Set) where
lift : A → Lift A
data _↠_ : Term → Term → Set where
_∎ : ∀ (M : Term)
-----
→ M ↠ M
_↦⟨_⟩_ : ∀ (L : Term) {M N : Term}
→ L ⟶ M
→ Lift (M ↠ N)
------------
→ L ↠ N
## Normalisation ## Normalisation
\begin{code} \begin{code}