Course website: https://github.com/OUCompilers/cs4100-sp20
An upper-level course for CS majors on formal languages theory and compilers.
Topics (subject to revision): regular expressions; finite automata; context-free grammars; predictive parsing; LR parsing; abstract syntax; type systems and type-checking; stack layout and activation records; intermediate representations; control-flow graphs; dataflow/liveness analysis; register allocation; garbage collection/runtimes; virtual machines; assemblers. Over the course of the semester, students will implement a full functioning compiler for a small programming language, targeting a bespoke virtual machine. The course requires a significant amount of programming.
Details | |
---|---|
Lecture | T/Th 3:05-4:20pm Walter 235 |
Instructor | Gordon Stewart (gstewart@ohio.edu) |
Office Hours | T/Th 2-3pm Stocker 355 |
TA | Tim Steinberger (ts409415@ohio.edu) |
GA | Marc Baltes (mb800915@ohio.edu) |
Lab Hours | T 4:30-5:30pm in Stocker 190, Th 4:30-6:30pm in Stocker 307 |
Piazza Page | https://piazza.com/ohio/spring2020/cs41005100/home |
GitHub Classroom | https://classroom.github.com/classrooms/58786651-cs4100-sp20 |
There's no one textbook that covers everything we'll be talking about in this course. Instead, I'll assign readings each week from the following sources (and maybe others):
- Modern Compiler Implementation in ML, Andrew W. Appel
- Types and Programming Languages, Benjamin Pierce
- The Rust Book
- Crafting Interpreters, Nystrom
This is a demanding course that requires extensive programming work, in the form of a series of (often increasingly) difficult assignments. Expect to put in at least 10 hours (sometimes much more) per programming assignment.
The course consists of weekly lectures (MWF), attendance at which is required. To help get you up to speed with the course programming assignments, we'll also hold biweekly lab hours (Stocker 307, Tuesdays 3-5pm). Although attendance at the lab hours is optional, I highly recommend that you participate — at least for the first few weeks. The programming assignments for this course are extensive and time consuming, so be prepared!
In addition to biweekly homework assignments, there will be a midterm exam (Week 8, approximately 15% of your grade) and a final (approximately 25%). The biweekly homeworks (programming assignments) are worth approximately 40%. We'll have weekly in-class quizzes every Friday with probability 1/2, along with bi-weekly offline Blackboard quizzes (total 10%). You get an additional 10% for free, just for signing up for the course.
Component | Percentage |
---|---|
Programming assignments | 40% |
Quizzes | 10% |
Midterm exam | 15% |
Final exam | 25% |
Free points | 10% |
Blackboard will be used only to report grades and to post lecture notes. Up-to-date information on all other aspects of the course (assignment due dates, etc.) will be posted either on this website or on the Piazza page or both.
The schedule is subject to revision.
Week | Topic | Reading | Assignment |
---|---|---|---|
Week 1 (13 Jan) | Intro. to the course, compilers, Rust | The Rust Book 1-3 | Q0 (18 Jan) |
Week 2 (20 Jan) | Rust contd. | The Rust Book 4-6, 8 | PA0: Intro. to Rust (23 Jan) |
Week 3 (27 Jan) | Rust contd. Thu: Intro. to PA1 (Tim) | ||
Week 4 (3 Feb) | Virtual machines, bytecode, assemblers | Crafting Interpreters 14, 15 | Q1 (6 Feb) |
Week 5 (10 Feb) | Garbage collection, concurrency | Appel 13 | PA1: Assembler (13 Feb) |
Week 6 (17 Feb) | Intermediate representations, code generation | Intermediate Representations, Code Generation | Q2 (20 Feb) |
Week 7 (24 Feb) | Regular languages, regular expressions | Appel 2 (through 2.2), RE Derivatives | Q3 (27 Feb) |
Week 8 (2 Mar) | DFAs, NFAs, lexers and lexer generators | Appel 2.3-2.5 | PA2: VM (3 Mar), Midterm Exam (5 Mar) |
Week 9 (9 Mar-13 Mar) | SPRING BREAK | ||
Week 10 (16 Mar) | SPRING BREAK | Q4 (17 Mar) | |
Week 11 (23 Mar) | Context-free languages, pushdown automata | Appel 3 | PA3: Runtime (26 Mar) |
Week 12 (30 Mar) | Recursive descent and predictive parsing, parser generators | Appel 7.1, Appel 18.1 | No quiz -- work on PA4! |
Week 13 (6 Apr) | Control-flow graphs, dominators | Appel 7.1, Appel 18.1 | |
Week 14 (13 Apr) | Dataflow/liveness analysis | Appel 10.1, Appel 19 (up to but not including 19.1) | Q5 (14 Apr), PA4: IR (16 Apr) |
Week 15 (20 Apr) | Register allocation | Appel 11 | No quiz -- study for final |
Apr. 27-May 1 | FINAL EXAM (Thu., April 30 at 12:20pm) | PA5: Optimizations (30 Apr at 12:20pm) |
Assignments are due in Blackboard at 11:59pm unless otherwise specified. Q0, Q1, etc., denote quizzes in Blackboard, generally due on the Wednesdays of weeks without due programming assignments (PAs).
This and later weeks, we'll do lectures directly in Teams.
Instructor/GA | Noninstructor (e.g., Another Student) | |
---|---|---|
You | All collaboration allowed | High-level discussion (of the problems, not your code!) allowed but only after you've started the assignment; must be documented in README as described below |
Unless otherwise noted, homeworks are due Tuesdays by 11:59 p.m. Late homework assignments will be penalized according to the following formula:
- Up to 24 hours late: no deduction, for a max 2 late homeworks per student across the entire semester
- Homeworks later than 24 hours, or from students who have already turned in 2 late homeworks, will receive 0 points.
You may discuss the homework with other students in the class, but only after you've attempted the problems on your own first. If you do discuss the homework problems with others, write the names of the students you spoke with, along with a brief summary of what you discussed, in a README comment at the top of each submission. Example:
(* README Gordon Stewart, Assn #1
I worked with X and Y. We swapped tips regarding the use of pattern-matching in Rust. *)
However, under no circumstances are you permitted to share or directly copy code or other written homework material, except with course instructors. The code and proofs you turn in must be your own. Remember: homework is there to give you practice in the new ideas and techniques covered by the course; it does you no good if you don't engage!
That said, if we find that you have cheated on an assignment in this course, you will immediately:
- Be referred to the Office of Community Standards (which may take disciplinary action against you, possibly expulsion); and
- Flunk the course (receive a final grade of F).
Students in EECS courses such as this one must adhere to the Russ College of Engineering and Technology Honor Code, and to the OU Student Code of Conduct. If you haven't read these policies, do so now.
If you suspect you may need an accommodation based on the impact of a disability, please contact me privately to discuss your specific needs. If you're not yet registered as a student with a disability, contact the Office of Student Accessibility Services first.
- Analyze a complex computing problem and to apply principles of computing and other relevant disciplines to identify solutions.
- Students will be able to appraise the tradeoffs, in terms of asymptotic complexity and precision, of distinct algorithms used in compiler construction (e.g., for garbage collection).
- Design, implement, and evaluate a computing-based solution to meet a given set of computing requirements in the context of the program’s discipline.
- Students will be able to construct a compiler, over the course of a series of course assignments, for a small programming language.
- Apply computer science theory and software development fundamentals to produce computing-based solutions.
- Students will be able to determine whether a given language is recognizable (e.g., by a regular expression, deterministic finite automaton, or context-free grammar).
- Students will be able to construct a finite state machine to recognize a given language.
- Students will be able to apply computer science theory to determine whether a given grammar is parseable by recursive descent.