SICP Overview (Tracker)
Fortitudine vincimus
Through endurance, we conquer
Book
Structure and Interpretation of Computer Programs
- 2nd Edition, 1996
- ISBN 10: 0262510871
Courseware
Downloading mit-scheme for mac
brew install mit-scheme
I also tried installing the racket language and environment as it has the sicp version of scheme. Which is a subset of scheme fifth revision of scheme R5RS. This is also having issues with the first
and last
string functions. I will go with this for now as it says sicp.
Useful links
Useful course notes uploaded to github
The source of the above providing stucture
My process for learning SICP with 61A
- Read the section of the book and take notes
- Reread notes and make sure they make sense, rewrite if needed
- Write up flashcards for that section
- Watch the lectures and take notes
- Reread notes and make sure they make sense, rewrite if needed
- Write up flashcards for that section
- Do a project based on that section
- Do the homework
- Go through my notes page and make sure it's good
Tracker
Week 1, Section 1 - Functional Programming
- Functional programming - Reading (SICP Section 1.1)
- read and take notes
- exercises
- reviewed notes & create flashcards
- Functional programming - Video lecture 1
- reviewed notes
- flashcards
- pluralizer
- Functional programming - Video lecture 2
- reviewed notes
- flashcards
- Create the Buzz game
- Create a pig latin generator
- Functional programming - Homework
- Check answers and add feedback
- Personal projects
Week 2, Section 2
- Higher-order procedures - Reading (SICP Section 1.3)
- reviewed notes
- exercises
- flashcards
- Higher-order procedures - Video lecture 3
- reviewed notes
- flashcards
- project
- Higher-order procedures - Video lecture 4
- reviewed notes
- flashcards
- project
- Higher-order procedures - Homework
- Check answers and add feedback
- Personal project
Week 3, Section 3
- Recursion and iteration - Reading (SICP Section 1.2 - 1.2.4)
- Recursion and iteration - Video lecture 7
- Recursion and iteration - Video lecture 8
- Recursion and iteration - Homework
- Project 1 - Twenty-One
- Data abstraction - Reading (SICP Sections 2.1 and 2.2.1)
- Data abstraction - Video lecture 9
- Data abstraction - Video lecture 10
- Data abstraction - Video lecture 11
- Data abstraction - Homework
- Exam - Midterm 1
- Hierarchical data/Scheme interpreter - Reading (SICP 2.2.2, 2.2.3, 2. 3.1, 2.- [ ] 3.3)
- Hierarchical data/Scheme interpreter - Video lecture 12
- Hierarchical data/Scheme interpreter - Video lecture 13
- Hierarchical data/Scheme interpreter - Video lecture 14
- Hierarchical data/Scheme interpreter - Homework
- Project 2 - A Picture Language (SICP section 2.2.4)
- Generic operators - Reading (SICP 2.4, 2.5 - 2.5.2)
- Generic operators - Video lecture 16
- Generic operators - Video lecture 17
- Generic operators - Homework
- Object-oriented programming - Reading (OOP above-the-line view in course - [ ] reader)
- Object-oriented programming - Lecture 18
- Object-oriented programming - Lecture 19
- Object-oriented programming - Lecture 20
- Object-oriented programming - Homework
- Exam - Midterm 2
- Assignment, state, environments - Reading (SICP 3.1, 3.2)
- Assignment and state - Lecture 21
- Environments - Lecture 22
- Environments - Lecture 23
- Assignment, state, environments - Homework
- [-] Project 3a
- Mutable data, vectors - Reading (SICP 3.3.1-3)
- Mutable data - Lecture 24
- Mutable data - Lecture 25
- Vectors - Lecture 26
- Mutable data, vectors - Homework
- [-] Project 3b
- Client/server, concurrency - Reading (SICP 3.4)
- Client/server - Lecture 30
- Concurrency - Lecture 31
- Concurrency - Lecture 32
- Client/server, concurrency - Homework
- Streams, Therac-25 - Reading (SICP 3.5.1-3, 3.5.5, Therac-25 paper)
- Streams - Lecture 33
- Streams - Lecture 34
- Therac-25 - Lecture 35
- Streams, Therac-25 - Homework
- [-] Exam - Midterm 3
- Metacircular evaluation, mapreduce - Reading (SICP 4.1.1–6)
- Metacircular evaluation - Lecture 36
- Mapreduce - Lecture 37
- Metacircular evaluation, mapreduce - Homework
- Mapreduce, analyzing, lazy evals - Reading (SICP 4.1.7, 4.2)
- Mapreduce - Lecture 38
- Analyzing, lazy evals - Lecture 39
- Mapreduce, analyzing, lazy evals - Homework
- Project 4a
- Logic programming - Reading (SICP 4.4.1-3)
- Logic programming - Lecture 40
- Review - Lecture 41
- Project 4b
- Final