finished intro to syntax
This commit is contained in:
parent
626d87804f
commit
aef1fa75ca
2 changed files with 2345 additions and 2347 deletions
4933
out/Stlc.md
4933
out/Stlc.md
File diff suppressed because it is too large
Load diff
|
@ -48,8 +48,10 @@ open import Relation.Binary.PropositionalEquality using (_≡_; _≢_; refl)
|
||||||
## Syntax
|
## Syntax
|
||||||
|
|
||||||
We have just two types.
|
We have just two types.
|
||||||
|
|
||||||
* Functions, `A ⇒ B`
|
* Functions, `A ⇒ B`
|
||||||
* Booleans, `𝔹`
|
* Booleans, `𝔹`
|
||||||
|
|
||||||
We require some form of base type, because otherwise the set of types
|
We require some form of base type, because otherwise the set of types
|
||||||
would be empty. Church used a trivial base type `o` with no operations.
|
would be empty. Church used a trivial base type `o` with no operations.
|
||||||
For us, it is more convenient to use booleans. Later we will consider
|
For us, it is more convenient to use booleans. Later we will consider
|
||||||
|
@ -57,9 +59,7 @@ numbers as a base type.
|
||||||
|
|
||||||
Here is the syntax of types in BNF.
|
Here is the syntax of types in BNF.
|
||||||
|
|
||||||
A, B, C ::=
|
A, B, C ::= A ⇒ B | 𝔹
|
||||||
A ⇒ B -- functions
|
|
||||||
𝔹 -- booleans
|
|
||||||
|
|
||||||
And here it is formalised in Agda.
|
And here it is formalised in Agda.
|
||||||
|
|
||||||
|
@ -72,13 +72,17 @@ data Type : Set where
|
||||||
\end{code}
|
\end{code}
|
||||||
|
|
||||||
Terms have six constructs. Three are for the core lambda calculus:
|
Terms have six constructs. Three are for the core lambda calculus:
|
||||||
|
|
||||||
* Variables, `` ` x ``
|
* Variables, `` ` x ``
|
||||||
* Abstractions, `λ[ x ∶ A ] N`
|
* Abstractions, `λ[ x ∶ A ] N`
|
||||||
* Applications, `L · M`
|
* Applications, `L · M`
|
||||||
|
|
||||||
and three are for the base type, booleans:
|
and three are for the base type, booleans:
|
||||||
|
|
||||||
* True, `true`
|
* True, `true`
|
||||||
* False, `false`
|
* False, `false`
|
||||||
* Conditions, `if L then M else N`
|
* Conditions, `if L then M else N`
|
||||||
|
|
||||||
Abstraction is also called lambda abstraction, and is the construct
|
Abstraction is also called lambda abstraction, and is the construct
|
||||||
from which the calculus takes its name.
|
from which the calculus takes its name.
|
||||||
|
|
||||||
|
@ -91,10 +95,9 @@ correspond to introduction rules and deconstructors to eliminators.
|
||||||
|
|
||||||
Here is the syntax of terms in BNF.
|
Here is the syntax of terms in BNF.
|
||||||
|
|
||||||
L, M, N ::= ` x | λ[ x ∶ A ] N
|
L, M, N ::= ` x | λ[ x ∶ A ] N | L · M | true | false | if L then M else N
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
And here it is formalised in Agda.
|
||||||
|
|
||||||
\begin{code}
|
\begin{code}
|
||||||
infixl 20 _·_
|
infixl 20 _·_
|
||||||
|
@ -110,10 +113,6 @@ data Term : Set where
|
||||||
if_then_else_ : Term → Term → Term → Term
|
if_then_else_ : Term → Term → Term → Term
|
||||||
\end{code}
|
\end{code}
|
||||||
|
|
||||||
Each type introduces its own constructs, which come in pairs,
|
|
||||||
one to introduce (or construct) values of the type, and one to eliminate
|
|
||||||
(or deconstruct) them.
|
|
||||||
|
|
||||||
CONTINUE FROM HERE
|
CONTINUE FROM HERE
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue