| ||
COMS W4115 Programming Languages and Translators Spring 2013 |
||
| Announcements | |||||||||||||||||||||||||||
|
Class meets 2:40-3:55pm on Mondays and Wednesdays, 535 Mudd. Courseworks site: https://courseworks.columbia.edu Piazza bulletin board: https://piazza.com/class#spring2013/comsw4115 On Wednesday, April 24, 2013, Maria Ayako Taku gave a lecture in class on "Functional Programming Languages." Maria discussed the influence of the lambda calculus on functional languages and showed how to implement an interpreter using the functional language OCaml. Important Dates
| |||||||||||||||||||||||||||
| Teaching Staff | |||||||||||||||||||||||||||
| |||||||||||||||||||||||||||
| Course Overview | |||||||||||||||||||||||||||
|
In PLT you will learn the syntactic
and semantic elements and the computational models of the most important modern
programming languages
as well as the algorithms and techniques used
by compilers to translate them into machine and other
target languages.
The course will cover imperative, object-oriented, functional,
logic and scripting languages, as well as trends in the evolution of programming languages.
A highlight of this course is a semester-long programming
project in which you will work in a small team to create
and implement an innovative little language of your own design.
This project will teach you computational thinking in language design as
well as project management, teamwork, and
communication skills that you can apply in all aspects of your
career. The concepts, techniques, and tools that you will learn in this course have broad application to many areas of computer science outside of programming languages and compilers. |
|||||||||||||||||||||||||||
| Prerequisites | |||||||||||||||||||||||||||
| Fluency in C and Java | |||||||||||||||||||||||||||
| COMS W3137 Data Structures and Algorithms | |||||||||||||||||||||||||||
| COMS W3261 Computer Science Theory | |||||||||||||||||||||||||||
| Schedule 2013 | |||||||||||||||||||||||||||
| Required Text | |||||||||||||||||||||||||||
|
Alfred V. Aho, Monica Lam, Ravi Sethi, and Jeffrey D. Ullman Compilers: Principles, Techniques, and Tools, Second Edition Addison-Wesley, 2007, ISBN 978-0321486813 |
|||||||||||||||||||||||||||
| Additional References | |||||||||||||||||||||||||||
|
Alfred V. Aho and Jeffrey D. Ullman Foundations of Computer Science, C Edition W. H. Freeman, 1995 An online version of this book is available here. |
|||||||||||||||||||||||||||
|
Andrew W. Appel Modern Compiler Implementation in Java, Second Edition Cambridge University Press, 2002 |
|||||||||||||||||||||||||||
|
Keith D. Cooper and Linda Torczon Engineering a Compiler, Second Edition Morgan Kaufmann, 2012 |
|||||||||||||||||||||||||||
|
Steven S. Muchnick Advanced Compiler Design and Implementation Morgan Kaufmann, 1997 |
|||||||||||||||||||||||||||
|
Michael L. Scott Programming Language Pragmatics, Third Edition Morgan Kaufmann, 2009 |
|||||||||||||||||||||||||||
|
Robert W. Sebesta Concepts of Programming Languages, Tenth Edition Pearson/Addison-Wesley, 2012 |
|||||||||||||||||||||||||||
|
Stephen Edward's CS4115 Web Page |
|||||||||||||||||||||||||||
| Class Policies | |||||||||||||||||||||||||||
| Grading |
40 % Project 10 % Homework 20 % Midterm 30 % Final | ||||||||||||||||||||||||||
| aho@cs.columbia.edu | Updated January 21, 2013 |