2019 Fall - 301 - Organization of Programming Languages - Syllabus
1 Important Course Details
2 Schedule
Day |
| Date |
| Topic |
| Notes | ||
1 |
| Thu |
| 09/05 |
| Big Step |
|
|
2 |
| Tue |
| 09/10 |
| Little Step & Contexts |
|
|
3 |
| Thu |
| 09/12 |
| Evaluation Contexts & CC |
|
|
4 |
| Tue |
| 09/17 |
| CK: Continuations & Stacks |
|
|
5 |
| Thu |
| 09/19 |
| Functions & Tail Calls |
|
|
6 |
| Tue |
| 09/24 |
| Closures & Environments (CEK) |
|
|
7 |
| Thu |
| 09/26 |
| The Lambda Calculus |
|
|
8 |
| Tue |
| 10/01 |
| Recursion |
|
|
9 |
| Thu |
| 10/03 |
| Data |
|
|
10 |
| Tue |
| 10/08 |
| Mutation |
|
|
11 |
| Thu |
| 10/10 |
| Variables |
|
|
| Tue |
| 10/15 |
| No class | |||
12 |
| Thu |
| 10/17 |
| Errors |
|
|
13 |
| Tue |
| 10/22 |
| Control |
|
|
14 |
| Thu |
| 10/24 |
| Concurrency |
|
|
15 |
| Tue |
| 10/29 |
| Safety & Contracts |
|
|
16 |
| Thu |
| 10/31 |
| Macros |
|
|
17 |
| Tue |
| 11/05 |
| Logic Programming |
|
|
18 |
| Thu |
| 11/07 |
| Memory Management: Manual & Reference Counting |
|
|
19 |
| Tue |
| 11/12 |
| Memory Management: Mark & Sweep |
|
|
20 |
| Thu |
| 11/14 |
| Memory Management: Stop & Copy |
|
|
21 |
| Tue |
| 11/19 |
| Memory Management: Generational Collection |
|
|
22 |
| Thu |
| 11/21 |
| Types: Basics & Gradual Typing |
|
|
23 |
| Tue |
| 11/26 |
| Types: Extensions |
|
|
| Thu |
| 11/28 |
| No class | |||
24 |
| Tue |
| 12/03 |
| Types: Polymorphism |
|
|
25 |
| Thu |
| 12/05 |
| Types: Subtyping |
|
|
26 |
| Tue |
| 12/10 |
| Types: Inference |
|
|
27 |
| Thu |
| 12/12 |
| Everything Else |
|
|
3 Work in this Course
3.1 Checkpoints
3.1.1 Checkpoint #1
Prepare a presentation (see Presentation Policy for how to submit) that presents an argument for which tasks you completed in your project. If this argument is not well-formulated, or if you present work that is not your own, then you will get an F on the assignment.
3.1.2 Checkpoint #2
Prepare a presentation (see Presentation Policy for how to submit) that presents an argument for which tasks you completed in your project. If this argument is not well-formulated, or if you present work that is not your own, then you will get an F on the assignment.
3.2 Course Grade
Your course grade is based on how many tasks you complete in the course project on the second checkpoint. However, this grade is modified by two things: first, if you are a graduate student or Honors-by-Contract student, then you are expected to do more, so it will be reduced by one rank (i.e., A becomes B, S becomes A, and so on.); second, if you did not achieve a grade with the letter C in it on the first checkpoint, then your grade is also reduced by one rank.
3.3 Course Project
Your main project in this course is to implement a virtual machine for a programming language with features similar to JavaScript & Python. The lectures (and textbook) will walk through the specification of the various features of this language and various implementation techniques.
There is a lot of flexibility about how you do this; in particular, you can implement it in whatever language you want. However, we mandate the language itself, as well as a few key design points (which are noted below.) In general, we always restrict you from using the implementation language’s feature X to implement feature X.
I highly recommend that you split your program into two related programs. One in a high-level language (like Racket, Python, Java, etc) that manages your test suite and implements some features and one in a low-level language (like C) that is the actual virtual machine. The best case scenario is to eventually re-implement the first program in the language you are implementing so it bootstraps itself. This is the implementation technique I used and I will reference it in the notes below. HL stands for the high-level program. LL stands for the low-level program.
|
| Grade |
| Time |
| Lines | ||
1 |
| (HL) Define data structures to represent J0 programs. |
| F- |
| 1m (0.14%) (1h) |
| +9 / -1 (0.36%) (8) |
2 |
| (HL) Write a pretty-printer for J0 programs. |
| F- |
| 2m (0.28%) (1h) |
| +15 / -1 (0.98%) (22) |
3 |
| (HL) Write a test-suite of a dozen J0 programs. |
| F |
| 1m (0.14%) (1h) |
| +15 / -2 (1.56%) (35) |
4 |
| (HL) Implement a big-step interpreter for J0. |
| F |
| 2m (0.28%) (1h) |
| +21 / -10 (2.06%) (46) |
5 |
| (HL) Define a data structure to represent Sexprs. |
| F |
| 1m (0.14%) (1h) |
| +6 / -1 (2.28%) (51) |
6 |
| (HL) Convert your J0 test-suite into Sexprs. |
| F+ |
| 1m (0.14%) (1h) |
| +11 / -7 (2.46%) (55) |
7 |
| (HL) Implement a desugar function that converts Sexprs into J0. |
| F+ |
| 2m (0.28%) (1h) |
| +13 / -3 (2.90%) (65) |
8 |
| (HL) Define data structures to represent J1 programs, with pretty printers. |
| F+ |
| 2m (0.28%) (1h) |
| +14 / -9 (3.13%) (70) |
9 |
| (HL) Write a test-suite of a dozen J1 programs. |
| F+ |
| 2m (0.28%) (1h) |
| +23 / -8 (3.80%) (85) |
10 |
| (HL) Extend desugar to emit J1 programs. |
| F+ |
| 2m (0.28%) (1h) |
| +15 / -4 (4.29%) (96) |
11 |
| (HL) Extend your interpreter for J1. |
| D- |
| 1m (0.14%) (1h) |
| +9 / -5 (4.47%) (100) |
12 |
| (HL) Define data structures to represent contexts. |
| D- |
| 1m (0.14%) (1h) |
| +11 / -1 (4.92%) (110) |
13 |
| (HL) Implement plug, a function that fills the hole in a context with a program. |
| D |
| 2m (0.28%) (1h) |
| +13 / -1 (5.45%) (122) |
14 |
| (HL) Implement find-redex, a function that breaks a term into a context and a redex. |
| D |
| 7m (0.97%) (1h) |
| +32 / -2 (6.79%) (152) |
15 |
| (HL) Implement a small-step interpreter for J1 using contexts. |
| D |
| 6m (0.83%) (1h) |
| +40 / -13 (8.00%) (179) |
16 |
| (HL) Refine your definition of contexts to only allow evaluation contexts. |
| D+ |
| 1m (0.14%) (1h) |
| +5 / -3 (8.09%) (181) |
17 |
| (HL) Refine find-redex so that it looks for evaluation contexts. |
| D+ |
| 5m (0.69%) (1h) |
| +19 / -30 (7.60%) (170) |
18 |
| (HL) Implement the CC0 machine interpreter for J1. |
| D+ |
| 12m (1.66%) (1h) |
| +49 / -5 (9.56%) (214) |
19 |
| (LL) Define data structures to represent J1 programs. |
| D+ |
| 4m (0.55%) (1h) |
| +39 / -0 (11.30%) (253) |
20 |
| (HL) Write a function that emit HL-J1 programs as LL-J1 programs. |
| D+ |
| 12m (1.66%) (2h) |
| +60 / -13 (13.40%) (300) |
21 |
| (LL) Define data structures to represent continuations. |
| C- |
| 4m (0.55%) (2h) |
| +80 / -36 (15.37%) (344) |
22 |
| (LL) Implement the CK0 machine interpreter for J1. |
| C- |
| 35m (4.83%) (2h) |
| +106 / -4 (19.93%) (446) |
23 |
| (HL) Connect your test-suite to your CK0 interpreter to verify that it works. |
| C |
| 18m (2.49%) (3h) |
| +64 / -6 (22.52%) (504) |
24 |
| (HL & LL) Define data structures to represent J2 programs and function definitions. |
| C |
| 13m (1.80%) (3h) |
| +54 / -20 (24.04%) (538) |
25 |
| (HL) Write a test-suite of a dozen J2 programs. |
| C |
| 5m (0.69%) (3h) |
| +40 / -6 (25.56%) (572) |
26 |
| (HL) Define a substitution function that plugs the value of a variable into references to that variable. |
| C+ |
| 2m (0.28%) (3h) |
| +13 / -1 (26.09%) (584) |
27 |
| (HL) Extend your big-step interpreter to evaluate J2 programs. |
| C+ |
| 9m (1.24%) (3h) |
| +54 / -48 (26.36%) (590) |
28 |
| (LL) Define a substitution function that plugs the value of a variable into references to that variable. |
| C+ |
| 7m (0.97%) (3h) |
| +32 / -2 (27.70%) (620) |
29 |
| (LL) Extend your CK0 machine into the CK1 to evaluate J2 programs. |
| C+ |
| 15m (2.07%) (3h) |
| +44 / -14 (29.04%) (650) |
30 |
| (LL) Modify your CK1 machine into the CEK0 machine. |
| C+ |
| 5m (0.69%) (3h) |
| +25 / -39 (28.42%) (636) |
31 |
| (LL) Write test cases that verify your CEK0 machine does NOT have dynamic scope. |
| B- |
| 4m (0.55%) (4h) |
| +12 / -1 (28.91%) (647) |
32 |
| (LL) Make a tweak to the CEK0 machine to give it dynamic scope, commit that, then revert it. |
| B- |
| 1m (0.14%) (4h) |
| +4 / -3 (28.95%) (648) |
33 |
| (HL) Remove your big-step interpreter from the HL. |
| B |
| 1m (0.14%) (4h) |
| +7 / -27 (28.06%) (628) |
34 |
| (HL & LL) Define data structures to represent J3 programs and runtime values. |
| B |
| 6m (0.83%) (4h) |
| +24 / -29 (27.84%) (623) |
35 |
| (HL) Write a test-suite of a dozen J3 programs. |
| B |
| 2m (0.28%) (4h) |
| +11 / -1 (28.28%) (633) |
36 |
| (HL) Extend desugar to support let expressions. |
| B+ |
| 2m (0.28%) (4h) |
| +16 / -1 (28.95%) (648) |
37 |
| (LL) Extend CEK0 to CEK1 to evaluate J3 programs. |
| B+ |
| 7m (0.97%) (4h) |
| +28 / -16 (29.49%) (660) |
38 |
| (HL) Write a test program that evaluates factorial using only functions, except for a final conversion to numbers. |
| B+ |
| 28m (3.87%) (4h) |
| +97 / -33 (32.35%) (724) |
39 |
| (HL & LL) Extend your J3 data structures to J4. |
| B+ |
| 4m (0.55%) (4h) |
| +23 / -31 (31.99%) (716) |
40 |
| (HL) Extend desugar to allow not mentioning the recursive name, as well as provide a default. |
| B+ |
| 1m (0.14%) (4h) |
| +6 / -1 (32.22%) (721) |
41 |
| (HL) Write a dozen test J3 programs, including extensions to your standard library. |
| A- |
| 6m (0.83%) (5h) |
| +34 / -8 (33.38%) (747) |
42 |
| (LL) Extend the CEK1 machine to CEK2 to evaluate J4. |
| A- |
| 10m (1.38%) (5h) |
| +22 / -8 (34.00%) (761) |
43 |
| (HL) Extend your J4 data structures to J5. |
| A |
| 2m (0.28%) (5h) |
| +8 / -1 (34.32%) (768) |
44 |
| (HL) Write a dozen test programs in J5 using the raw extensions. |
| A |
| 5m (0.69%) (5h) |
| +27 / -1 (35.48%) (794) |
45 |
| (HL) Extend your standard library to include options and basic list functions, like map, filter, and fold. |
| A |
| 9m (1.24%) (5h) |
| +51 / -13 (37.18%) (832) |
46 |
| (HL) Write a dozen test J5 programs that use the standard library. |
| A+ |
| 2m (0.28%) (5h) |
| +20 / -1 (38.03%) (851) |
47 |
| (LL) Extend your J4 data structures to J5 and extend the CEK2 machine to CEK3 to evaluate J5. |
| A+ |
| 27m (3.73%) (5h) |
| +94 / -41 (40.39%) (904) |
48 |
| (HL) Extend your data structures to represent J6 programs. |
| A+ |
| 1m (0.14%) (5h) |
| +7 / -2 (40.62%) (909) |
49 |
| (HL) Extend your desugar standard library with mutation helpers. |
| A+ |
| 7m (0.97%) (6h) |
| +35 / -15 (41.51%) (929) |
50 |
| (HL) Write a dozen example J6 programs. |
| S- |
| 5m (0.69%) (6h) |
| +41 / -24 (42.27%) (946) |
51 |
| (LL) Extend your data structures to J6 and the CEK3 machine to CEK4 to handle J6 programs. |
| S |
| 6m (0.83%) (6h) |
| +24 / -4 (43.16%) (966) |
52 |
| (HL) Write a dozen example J7 programs. |
| S+ |
| 4m (0.55%) (6h) |
| +28 / -1 (44.37%) (993) |
53 |
| (HL) Extend desugar so that J7 programs are elaborated into J6 programs. |
| S+ |
| 24m (3.31%) (6h) |
| +71 / -20 (46.65%) (1044) |
54 |
| (HL) Extend desugar to support letrec. |
| SS- |
| 5m (0.69%) (6h) |
| +26 / -14 (47.18%) (1056) |
55 |
| (HL & LL) Extend your data structures to represent J9 programs. |
| SS- |
| 4m (0.55%) (6h) |
| +31 / -13 (47.99%) (1074) |
56 |
| (HL) Write a dozen example J9 programs. |
| SS- |
| 1m (0.14%) (6h) |
| +36 / -1 (49.55%) (1109) |
57 |
| (LL) Extend your CEK4 machine to CEK5 to support J9 programs. |
| SS- |
| 11m (1.52%) (7h) |
| +68 / -1 (52.55%) (1176) |
58 |
| (HL & LL) Extend your data structures to represent J10 programs, and remove support for J9 programs. |
| SS- |
| 2m (0.28%) (7h) |
| +9 / -9 (52.55%) (1176) |
59 |
| (HL) Write a dozen example J10 programs. |
| SS- |
| 1m (0.14%) (7h) |
| +9 / -1 (52.90%) (1184) |
60 |
| (HL) Modify your standard library and desugar to support J9 programs as J10 programs. |
| SS- |
| 4m (0.55%) (7h) |
| +23 / -8 (53.57%) (1199) |
61 |
| (LL) Extend your CEK4 machine to CEK6. |
| SS- |
| 28m (3.87%) (7h) |
| +37 / -62 (52.46%) (1174) |
62 |
| (HL) Extend your desugar to provide control constructs. |
| SS- |
| 8m (1.10%) (7h) |
| +26 / -5 (53.40%) (1195) |
63 |
| (HL) Extend your standard library to support generators and write some example generators. |
| SS- |
| 8m (1.10%) (7h) |
| +43 / -2 (55.23%) (1236) |
64 |
| (HL) Implement message-passing concurrency in your standard library. |
| SS- |
| 10m (1.38%) (8h) |
| +74 / -10 (58.09%) (1300) |
65 |
| (HL) Write a dozen examples programs that use concurrency. |
| SS- |
| 17m (2.35%) (8h) |
| +50 / -28 (59.07%) (1322) |
66 |
| (HL) Implement locks using message-passing concurrency. |
| SS- |
| 6m (0.83%) (8h) |
| +40 / -1 (60.81%) (1361) |
67 |
| (HL) Implement futures (i.e. promises) using message-passing concurrency. |
| SS- |
| 4m (0.55%) (8h) |
| +26 / -1 (61.93%) (1386) |
68 |
| (HL) Write a dozen example J12 programs. |
| SS- |
| 2m (0.28%) (8h) |
| +33 / -1 (63.36%) (1418) |
69 |
| (HL & LL) Extend your system from J11 to J12, thereby supporting runtime type inspection. |
| SS- |
| 11m (1.52%) (8h) |
| +49 / -4 (65.37%) (1463) |
70 |
| (HL) Update your standard library to check types before performing operations. |
| SS |
| 18m (2.49%) (9h) |
| +143 / -45 (69.75%) (1561) |
71 |
| (HL) Extend your standard library and desugar to support contracts. |
| SS |
| 38m (5.25%) (9h) |
| +183 / -55 (75.47%) (1689) |
72 |
| (HL) Implement a basic syntax-rules macro system. |
| SS |
| 13m (1.80%) (9h) |
| +116 / -10 (80.21%) (1795) |
73 |
| (HL) Refactor your desugar function so that many of its features are now implemented in the standard library as macros. |
| SS |
| 28m (3.87%) (10h) |
| +130 / -106 (81.28%) (1819) |
74 |
| (*) Download teachlog and write an interesting logic program. |
| SS |
| 3m (0.41%) (10h) |
| +37 / -1 (82.89%) (1855) |
75 |
| (HL) Write an example program that uses an obscene amount of memory without garbage collection. |
| SS |
| 8m (1.10%) (10h) |
| +17 / -1 (83.60%) (1871) |
76 |
| (LL) Modify your virtual machine to perform stop & copy garbage collection. |
| SS |
| 56m (7.73%) (11h) |
| +156 / -14 (89.95%) (2013) |
77 |
| (HL) Write a dozen programs that fail to type check. |
| SS |
| 1m (0.14%) (11h) |
| +11 / -1 (90.39%) (2023) |
78 |
| (HL) Write a dozen programs that fail at runtime due to contract violations on untyped boundaries. |
| SS |
| 2m (0.28%) (11h) |
| +9 / -1 (90.75%) (2031) |
79 |
| (HL) Write a dozen programs that contain valid typed regions. |
| SS |
| 1m (0.14%) (11h) |
| +9 / -1 (91.11%) (2039) |
80 |
| (HL) Implement a gradual type checker and elaborator that runs after your desugar function. |
| SS |
| 43m (5.94%) (12h) |
| +175 / -35 (97.36%) (2179) |
81 |
| Note. After this, most tasks can be done in any order. |
| SS |
| 1m (0.14%) (12h) |
| +5 / -1 (97.54%) (2183) |
82 |
| (HL & LL) Modify your LL representation to use static variable offsets. |
| SS |
| 28m (3.87%) (12h) |
| +49 / -49 (97.54%) (2183) |
83 |
| (HL & LL) Modify your LL representation to use flat closures, rather than the nested ones we’ve used so far. |
| SS |
| 18m (2.49%) (13h) |
| +71 / -16 (100.00%) (2238) |
84 |
| (HL & LL) Create a bytecode format that enables your machine to instantly start without parsing. |
| SS |
|
| ||
85 |
| (HL & LL) Add seals to your language. |
| SS |
|
| ||
86 |
| (HL) Extend your macro system to support hygiene via sets-of-scopes. |
| SS |
|
| ||
87 |
| (HL & LL) Implement NaN boxing. |
| SS+ |
|
| ||
88 |
| (HL) Modify your type elaborator to optimize programs using type information. |
| SS+ |
|
| ||
89 |
| (HL) Implement a reader for your language and give it a real syntax. |
| SS+ |
|
| ||
90 |
| (HL) Extend your type system (and examples & violations) to support polymorphism. |
| SS+ |
|
| ||
91 |
| (HL) Extend your type system (and examples & violations) to support structural subtyping of object types. |
| SS+ |
|
| ||
92 |
| (HL) Extend your type system (and examples & violations) to use constraint-solving inference. |
| SS+ |
|
| ||
93 |
| (HL) Implement a teachlog-style logic programming environment in your language using the non-determinism monad. |
| SS+ |
|
| ||
94 |
| (HL & LL) Extend your system to support continuation marks. |
| SS+ |
|
| ||
95 |
| (HL) Use continuation marks to make parameters. |
| SS+ |
|
| ||
96 |
| (LL) Extend your virtual machine to support mark-and-sweep as an option. |
| SS+ |
|
| ||
97 |
| (HL) Extend your type system to support F-bounded polymorphism. |
| SS+ |
|
| ||
98 |
| (HL) Change your implementation of polymorphism to monomorphize. |
| SS+ |
|
| ||
99 |
| (HL) Extend your type system (and examples & violations) to support iso-recursive types. |
| SS+ |
|
| ||
100 |
| (HL) Implement a logic programming environment in your language using first-class continuations and continuation marks. |
| SS+ |
|
| ||
101 |
| (HL) Use continuation marks to make exceptions work correctly with concurrency. |
| SS+ |
|
| ||
102 |
| (HL) Use continuation marks to make space-efficient contracts. |
| SS+ |
|
| ||
103 |
| (HL) Use continuation marks (with keys) to implement sandboxed evaluation via security-through-stack-inspection. |
| SS+ |
|
| ||
104 |
| (HL) Implement select and asynchronous channels using message-passing concurrency. |
| SS+ |
|
| ||
105 |
| (HL & LL) Extend your system to support IO via special channels. |
| SS+ |
|
| ||
106 |
| (HL) Extend your macro system to support procedural macros. |
| SS+ |
|
| ||
107 |
| (HL) Implement a match macro. |
| SS+ |
|
| ||
108 |
| (HL) Extend your macro system to support syntax-local-value. |
| SS+ |
|
| ||
109 |
| (LL) Extend your virtual machine to support generational garbage collection. |
| SS+ |
|
|