wrote Preface

This commit is contained in:
wadler 2018-03-04 12:29:53 -03:00
parent d2c64685db
commit ae26e82dd4
3 changed files with 99 additions and 14 deletions

View file

@ -22,14 +22,22 @@ Please send us comments! Contact details below.
In directory `sf/` run the following: In directory `sf/` run the following:
$ make clobber `$ make macos-setup` (might need sudo, but try it without first)
$ make `$ make build` (builds lagda->markdown and website)
$ make serve & `$ make build-incremental` (builds lagda->markdown and website using incremental)
`$ make server-start` (starts server in detached mode)
`$ make server-stop` (stops the server, uses pkill)
The visible page appears at The visible page appears at
localhost:4000/sf/<permalink> localhost:4000/sf/<permalink>
<!--
$ make clobber
$ make
$ make serve &
-->
## Unicode abbreviations ## Unicode abbreviations

View file

@ -3,23 +3,21 @@ title : Table of Contents
layout : page layout : page
--- ---
This is a rewrite of the text [Software Foundations]( This is a rewrite of the text [Software Foundations][sf]
https://softwarefoundations.cis.upenn.edu/current/index.html
)
from Coq to Agda. The authors are from Coq to Agda. The authors are
[Wen Kokke]( [Wen Kokke][wen]
https://github.com/wenkokke
) )
and and
[Philip Wadler]( [Philip Wadler][phil]
http://homepages.inf.ed.ac.uk/wadler/
(
). ).
## Part 1: Logical Foundations - [Preface](Preface)
<!-- ## Part 1: Logical Foundations
- [Basics: Functional Programming in Agda]({{ "/Basics" | relative_url }})
-->
- [Naturals: Natural numbers](Naturals) - [Naturals: Natural numbers](Naturals)
- [Properties: Proof by induction](Properties) - [Properties: Proof by induction](Properties)
@ -41,3 +39,13 @@ http://homepages.inf.ed.ac.uk/wadler/
- [Stlc: The Simply Typed Lambda-Calculus](Stlc) - [Stlc: The Simply Typed Lambda-Calculus](Stlc)
- [StlcProp: Properties of STLC](StlcProp) - [StlcProp: Properties of STLC](StlcProp)
- [Scoped: Scoped and Typed DeBruijn representation](Scoped) - [Scoped: Scoped and Typed DeBruijn representation](Scoped)
[sf]: https://softwarefoundations.cis.upenn.edu/
[wen]: https://github.com/wenkokke
[phil]: http://homepages.inf.ed.ac.uk/wadler/
<!--
- [Basics: Functional Programming in Agda]({{ "/Basics" | relative_url }})
-->

69
src/Preface.lagda Normal file
View file

@ -0,0 +1,69 @@
---
title : "Preface"
layout : page
permalink : /Preface
---
This book is an introduction to programming language theory, written
in Agda.
Since 2013, I teach a course on Types and Semantics for Programming
Languages to fourth-year undergraduates and masters students at the
University of Edinburgh. That course had been based on the textbook
[Software Foundations][sf], by Pierce and others, written in Coq. I
am convinced of Pierce's claim that basing a course around a proof
assistant aids learning, as summarised in his ICFP Keynote, [Lambda,
The Ultimate TA][ta].
However, after five years of experience, I have come to the conclusion
that Coq may not be the best vehicle. Too much of the course needs to
focus on learning tactics for proof derivation, to the cost of
learning the fundamentals of programming language theory. Every
concept has to be learned twice: both the product data type, and the
corresponding tactics for introduction (`split`) and elimination
(`destruct`) of products. The rules Coq applies to generate induction
hypotheses can sometimes seem mysterious. While the `notation`
construct permits pleasingly flexible syntax, it can be confusing that
the same concept must always be given two names, e.g., both `subst N x
M` and `N [x := M]`. Names of tactics are sometimes short and
sometimes long; naming conventions in the standard library can be
wildly inconsistent. *Propositions as types* as a foundation of proof
is present but hidden.
I found myself keen to recast the course in Agda. In Agda, there is
no longer any need to learn about tactics: there is just
dependently-typed programming, plain and simple. Introduction is
always by a constructor, elimination is always by pattern
matching. Induction is no longer a mysterious separate concept, but
corresponds to familiar recursion. Multifix syntax is flexible while
using just one name for each concept, e.g., substitution is
`_[_:=_]`. The standard library is not perfect, but there is a fair
attempt at consistency. *Propositions as types* as a foundation of
proof is on proud display.
Alas, there is no standard text for programming language theory in
Agda. Stump's [Verified Functional Programming in Agda][stump] covers
related ground, but focusses more on programming with dependent
types than on teaching the theory of programming languages.
The original goal was to simply adapt *Software Foundations*,
maintaining the same text but transposing the code from Coq to Agda.
But it quickly became clear to me that after five years in the
classroom I had my own ideas about how to present the material. They
say you should never write a book unless you cannot not write the
book, and I soon found that this was a book I could not not write.
I am fortunate that my student, [Wen Kokke][wen], was keen to help.
They guided me as a newbie to Agda and provided an infrastructure that
is easy to use and produces pages that are a pleasure to view. Most
of the text was written during a sabbatical in the first half of 2018.
Please send suggestions to improve the text to [me][phil].
-- Philip Wadler, Rio de Janeiro, January--June 2018
[sf]: https://softwarefoundations.cis.upenn.edu/
[ta]: http://www.cis.upenn.edu/~bcpierce/papers/plcurriculum.pdf
[stump]: http://www.morganclaypoolpublishers.com/catalog_Orig/product_info.php?cPath=24&products_id=908
[wen]: https://github.com/wenkokke
[phil]: http://homepages.inf.ed.ac.uk/wadler/