Structure and Interpretation of Computer Programs
Offered By: Massachusetts Institute of Technology via MIT OpenCourseWare
Course Description
Overview
This course introduces students to the principles of computation. Upon completion of 6.001, students should be able to explain and apply the basic methods from programming languages to analyze computational systems, and to generate computational solutions to abstract problems. Substantial weekly programming assignments are an integral part of the course. This course is worth 4 Engineering Design Points.
Syllabus
- 1A: Overview and Introduction to Lisp
- 1B: Procedures and Processes; Substitution Model
- 2A: Higher-order Procedures
- 2B: Compound Data
- 3A: Henderson Escher Example
- 3B: Symbolic Differentiation; Quotation
- 4A: Pattern Matching and Rule-based Substitution
- 4B: Generic Operators
- 5A: Assignment, State, and Side-effects
- 5B: Computational Objects
- 6A: Streams, Part 1
- 6B: Streams, Part 2
- 7A: Metacircular Evaluator, Part 1
- 7B: Metacircular Evaluator, Part 2
- 8A: Logic Programming, Part 1
- 8B: Logic Programming, Part 2
- 9A: Register Machines
- 9B: Explicit-control Evaluator
- 10A: Compilation
- 10B: Storage Allocation and Garbage Collection
Taught by
Prof. Trevor Darrell, Prof. Eric Grimson, and Prof. Peter Szolovits
Tags
Related Courses
Intro to Computer ScienceUniversity of Virginia via Udacity Design of Computer Programs
Stanford University via Udacity Analytic Combinatorics, Part I
Princeton University via Coursera Algorithms, Part I
Princeton University via Coursera Algorithms, Part II
Princeton University via Coursera