Skip to content Skip to navigation

Principles of Programming Languages


The course is aimed at making the student familiar with the general concepts common to all programming languages so as to facilitate learning new languages. Language paradigms (i.e., logic, functional, procedural, object-oriented) are compared and implementation strategies are discussed.

14:332:331 or 01:198:211; 01:198:205 or 14:332:312.
Please note that courses for which a student has received a grade of D cannot be used to satisfy prerequisite requirements.

BNF and context free grammars; Data visibility (i.e., lexical and dynamic scoping);  Procedures and  parameter passing techniques; Types, type checking and type equivalence; Functional programming paradigm: higher-order functions, recursive data structures, programming with recursion (i.e., without iteration);  Logic programming paradigm:  unification, generate and test;  Programming with pointers in C.

Expected Work: 

There are three graded programming projects and textbook homework assignments.

1 hourly, Final Exam
Learning Goals: 
Computer Science majors ...
  • will be prepared to contribute to a rapidly changing field by acquiring a thorough grounding in the core principles and foundations of computer science (e.g., techniques of program design, creation, and testing; key aspects of computer hardware; algorithmic principles).
  • will acquire a deeper understanding on (elective) topics of more specialized interest, and be able to critically review, assess, and communicate current developments in the field.
  • will be prepared for the next step in their careers, for example, by having done a research project (for those headed to graduate school), a programming project (for those going into the software industry), or some sort of business plan (for those going into startups).
Course Type: 

Check the University Schedule of Classes to see if this course is open.

Request an Special Permission Number here if the class is full.