CSE 425s: Programming Languages (Spring 2022) (Other Semesters)

This course leverages the outstanding materials from Dan Grossman and others at the University of Washington.

jump to:
     Jan 16-Jan 22, Jan 23-Jan 29, Jan 30-Feb 05, Feb 06-Feb 12, Feb 13-Feb 19, Feb 20-Feb 26, Feb 27-Mar 05, Mar 06-Mar 12
    spring break
    Mar 20-Mar 26, Mar 27-Apr 02, Apr 03-Apr 09, Apr 10-Apr 16, Apr 17-Apr 23, Apr 24-Apr 30

Date/SubjectPrepIn Class Assignments
       
Mon Jan 17 MLK (No Class)
       
Wed Jan 19 (#0) Welcome; Setup; OOP Static 1slides: presentation pdf
>>> Assign (Java) WashU Exercise ImList<E>
       
       
       
       
Mon Jan 24 (#1) Functional Static 1axkcd: Editors

Courses and Software Setup
(Optional) PL A 0 reading: start-here
(Optional) PL A 0 video: welcome-and-some-course-mechanics
PL A 0 video: who-i-am-acknowledgments
PL A 0 video: what-the-course-is-about-initial-motivation
(Optional) PL A 0 video: recommended-background
(Optional) PL A 0 video: why-part-a-part-b-part-c
(Optional) PL A 0 video: grading-policy
PL A 0 video: very-high-level-outline
(Optional) PL A 0 reading: about-the-course
(Optional) PL A 0 reading: some-more-perspective-on-recommended-background
(Optional) PL A 0 reading: why-are-there-3-courses-part-a-part-b-part-c
(Optional) PL A 0 reading: grading-policy-details
(Optional) PL A 0 discussionPrompt: discussion-forums-why-are-you-participating
PL A 1 reading: section-1-welcome-message
PL A 1 reading: section-1-reading-notes
PL A 1 video: ml-variable-bindings-and-expressions
PL A 1 video: rules-for-expressions
PL A 1 video: the-repl-and-errors
PL A 1 video: shadowing
PL A 1 video: functions-informally
PL A 1 video: functions-formally
PL A 1 video: pairs-and-other-tuples
PL A 1 video: introducing-lists
PL A 1 video: list-functions
PL A 1 video: let-expressions
PL A 1 video: nested-functions
PL A 1 video: let-and-efficiency
video: Making Sense of SML Error Output
quiz
slides: presentation pdf
DG slides: pptx pdf
DG slides: pptx pdf
>>> Assign (SML) WashU WarmUp List Length
>>> Assign (SML) WashU WarmUp Sum Scan
>>> Assign (SML) UW Exercise Calendar Date
       
Wed Jan 26 (#2) Functional Static 1bxkcd: Side Effect Free

PL A 1 video: options
PL A 1 video: booleans-and-comparison-operations
PL A 1 video: benefits-of-no-mutation
PL A 1 video: java-mutation
PL A 1 video: pieces-of-a-language
video: Shards O' Glass Freeze Pops
quiz
slides: presentation pdf
>>> Assign (SML) WashU WarmUp Is Strictly Ascending
>>> Assign (SML) WarmUp SML Practice Problems A
>>> Assign (Java) WashU Exercise java.util.Optional<T>
       
       
       
       
Mon Jan 31 (#3) Functional Static 2a PL A 2 reading: section-2-welcome-message
PL A 2 reading: section-2-reading-notes
PL A 2 video: building-compound-types
PL A 2 video: records
PL A 2 video: tuples-as-syntactic-sugar
PL A 2 video: datatype-bindings
PL A 2 video: case-expressions
PL A 2 video: useful-datatypes
PL A 2 video: pattern-matching-so-far
PL A 2 video: another-expression-example
quiz
slides: presentation pdf
>>> Assign (SML) WashU WarmUp Sum Scan with Pattern Matching
>>> Assign (SML) WarmUp SML Practice Problems B
       
Wed Feb 2 (#4) Functional Static 2bvideo: Synthesizing Information
PL A 2 video: type-synonyms
PL A 2 video: lists-and-options-are-datatypes
PL A 2 video: polymorphic-datatypes
PL A 2 video: each-of-pattern-matching-truth-about-functions
PL A 2 video: a-little-type-inference
PL A 2 video: polymorphic-and-equality-types
PL A 2 video: nested-patterns
PL A 2 video: more-nested-patterns
PL A 2 video: nested-patterns-precisely
PL A 2 video: function-patterns
quiz
slides: presentation pdf
>>> Assign (SML) WashU WarmUp Remove First Occurrence
>>> Assign (SML) WashU WarmUp Is Strictly Ascending with Pattern Matching
>>> Assign (SML) WashU Exercise Hearts Card Game
       
       
Sat Feb 5<<< Submit (SML) UW Exercise Calendar Date
<<< Submit (Java) WashU Exercise ImList<E>
<<< Submit (Java) WashU Exercise java.util.Optional<T>
       
Mon Feb 7 (#5) Language and Thought; Functional Static 2cTed Talk: Lera Boroditsky: How language shapes the way we think
video: Numbers in Pirahã
video: Recursion in Pirahã?
(Optional) Wikipedia: Pirahã language
xkcd: Tail Recursion

PL A 2 video: exceptions
PL A 2 video: tail-recursion
PL A 2 video: accumulators-for-tail-recursion
PL A 2 video: perspective-on-tail-recursion
quiz
slides: presentation pdf
>>> Assign (SML & Java) WashU Group WarmUp Sum Distances To Origin
>>> Assign (SML) WashU WarmUp Sum Scan with Tail Recursion
>>> Assign (Java) WashU Exercise Tail Recursion
>>> Assign (SML) UW Exercise Card Game
       
Wed Feb 9 (#6) Functional Static 3a PL A 3 reading: section-3-welcome-message
PL A 3 reading: section-3-reading-notes
PL A 3 video: introduction-to-first-class-functions
PL A 3 video: functions-as-arguments
PL A 3 video: polymorphic-types-and-functions-as-arguments
PL A 3 video: anonymous-functions
PL A 3 video: unnecessary-function-wrapping
PL A 3 video: map-and-filter
PL A 3 video: generalizing-prior-topics
quiz
slides: presentation pdf
>>> Assign (Java) WashU Group WarmUp Any and All
>>> Assign (SML) WarmUp SML Practice Problems C
>>> Assign (Java) WashU WarmUp N Times
>>> Assign (Java) WashU Exercise Higher Order Functions Hall of Fame
       
       
Sat Feb 12<<< Submit (SML) WashU Exercise Hearts Card Game
       
Mon Feb 14 (#7) Story of Your Life; Functional Static 3bRead: Story of Your Life
xkcd: College Athletes

PL A 3 video: lexical-scope
PL A 3 video: lexical-scope-and-higher-order-functions
PL A 3 video: why-lexical-scope
PL A 3 video: closures-and-recomputation
PL A 3 video: fold-and-more-closures
PL A 3 video: closure-idiom-combining-functions
PL A 3 video: closure-idiom-currying
PL A 3 video: partial-application
PL A 3 video: currying-wrapup
video: UW3 Pattern Matching Rosetta Stone
quiz
slides: presentation pdf
>>> Assign (SML) WashU Group WarmUp Curried Higher-Order Function Debugging
>>> Assign (SML) WashU WarmUp Sum Scan Using Higher-Order Functions
>>> Assign (SML) UW Exercise Pattern Matching
       
Wed Feb 16 (#8) Functional Static 3c; Course Motivationxkcd: Standards

PL A 3 video: mutable-references
PL A 3 video: closure-idiom-callbacks
PL A 3 video: standard-library-documentation
PL A 3 video: abstract-data-types-with-closures
PL A 3 video: closure-idioms-without-closures
PL A 3 video: java-without-closures
PL A 3 video: c-without-closures
PL A 3 video: course-motivation-introduction
PL A 3 video: why-study-general-pl-concepts
PL A 3 video: are-all-pls-the-same
PL A 3 video: why-functional-languages
PL A 3 video: why-ml-racket-and-ruby
quiz
slides: presentation pdf
>>> Assign (SML) WashU WarmUp Scan Higher Order Function
       
       
Sat Feb 19<<< Submit (SML) UW Exercise Card Game
<<< Submit (Java) WashU Exercise Tail Recursion
<<< Submit (Java) WashU Exercise Higher Order Functions Hall of Fame
       
Mon Feb 21 (#9) Functional Static 4axkcd: Haskell

PL A 4 reading: section-4-welcome-message
PL A 4 reading: section-4-reading-notes
PL A 4 video: section-introduction
PL A 4 video: what-is-type-inference
PL A 4 video: ml-type-inference
PL A 4 video: type-inference-examples
PL A 4 video: polymorphic-examples
PL A 4 video: the-value-restriction-and-other-type-inference-challenges
PL A 4 video: mutual-recursion
video: How To Use Refs In SML
quiz
slides: presentation pdf
>>> Assign (SML) WashU WarmUp Mutable List
       
Wed Feb 23 (#10) Functional Static 4bxkcd: Workflow

PL A 4 video: modules-for-namespace-management
PL A 4 video: signatures-and-hiding-things
PL A 4 video: a-module-example
PL A 4 video: signatures-for-our-example
PL A 4 video: signature-matching
PL A 4 video: an-equivalent-structure
PL A 4 video: another-equivalent-structure
PL A 4 video: different-modules-define-different-types
PL A 4 video: equivalent-functions
PL A 4 video: standard-equivalences
PL A 4 video: equivalence-versus-performance
PL A 4 video: part-a-wrap-up-parts-b-c-preview
video: Binary Search Tree Client Demo
quiz
slides: presentation pdf
>>> Assign (SML) WashU Exercise Binary Search Tree
       
       
Sat Feb 26<<< Submit (SML) UW Exercise Pattern Matching
       
Mon Feb 28 (#11) 1984; FunctorsRead: Chapters 1-5 (inclusive) of 1984
quiz
slides: presentation pdf
>>> Assign (SML) WashU Exercise Chained (Single List and Hashed) Dictionaries
>>> Assign (SML) WashU Exercise Spreadsheet
       
Wed Mar 2 (#12) The Lambda Calculus; Sorted Dictionaryvideo: The Lambda Calculus (Hutton)
video: Y Combinator (Hutton)
(Optional) Wikipedia: Fixed-point combinator
(Optional) Wikipedia: Church encoding
(Optional) video: The Lambda Calculus (Lebec)
video: Sorted Dictionary Scenario
quiz
slides: presentation pdf
>>> Assign (Sml) WashU Exercise Sorted Dictionary
       
       
Sat Mar 5<<< Submit (SML) WashU Exercise Binary Search Tree
       
Mon Mar 7 (#13) Functional Dynamic 1axkcd: (Parentheses)

Read: Low-fidelity Prototyping
(Optional) Wikipedia: L-system
PL B 1 reading: start-here
PL B 1 video: welcome-to-part-b
PL B 1 video: overview-of-part-b-concepts
PL B 1 video: part-b-course-structure
PL B 1 reading: part-b-software-installation-and-use-racket-and-drracket
PL B 1 reading: section-5-welcome-message
PL B 1 reading: section-5-reading-notes
PL B 1 video: introduction-to-racket
PL B 1 video: racket-definitions-functions-conditionals
PL B 1 video: racket-lists
PL B 1 video: syntax-and-parentheses
PL B 1 video: parentheses-matter-debugging-practice
PL B 1 video: dynamic-typing
PL B 1 video: cond
PL B 1 video: local-bindings
PL B 1 video: toplevel-bindings
video: Making Sense of Dr Racket Error Output
video: Racket Image Library Demo: Snowdudes
video: Racket Image Library Recursive Demo: Spiral
quiz
slides: presentation pdf
>>> Assign (Racket) WashU WarmUp Home Is Where The (Racket) Heart Is
>>> Assign (Racket) WashU Exercise Sierpiński and Cantor
       
Wed Mar 9 (#14) Functional Dynamic 1bxkcd: Universe

video: Are C Macros Really That Bad?
video: Thunk That Scenario
PL B 1 video: mutation-with-set
PL B 1 video: the-truth-about-cons
PL B 1 video: mcons-for-mutable-pairs
PL B 1 video: delayed-evaluation-and-thunks
PL B 1 video: avoiding-unnecessary-computations
PL B 1 video: delay-and-force
PL B 1 video: using-streams
PL B 1 video: defining-streams
PL B 1 video: memoization
PL B 1 video: macros-the-key-points
PL B 1 video: tokenization-parenthesization-and-scope
PL B 1 video: racket-macros-with-define-syntax
PL B 1 video: variables-macros-and-hygiene
PL B 1 video: more-macro-examples
quiz
slides: presentation pdf
>>> Assign (Racket) WashU Exercise Snowflake
>>> Assign (Racket) WashU WarmUp Thunks and Streams
>>> Assign (Racket) UW Exercise Streams
       
       
Sat Mar 12<<< Submit (SML) WashU Exercise Chained (Single List and Hashed) Dictionaries
<<< Submit (SML) WashU Exercise Spreadsheet
<<< Submit (Sml) WashU Exercise Sorted Dictionary
       
Mon Mar 14 Spring Break (No Class)
       
Wed Mar 16 Spring Break (No Class)
       
       
       
       
Mon Mar 21 (#15) Functional Dynamic 2aRead: Fire and Ice by Robert Frost
xkcd: Perl or Lisp

PL B 2 reading: section-6-welcome-message
PL B 2 reading: section-6-reading-notes
PL B 2 video: datatype-programming-in-racket-without-structs
PL B 2 video: datatype-programming-in-racket-with-structs
PL B 2 video: advantages-of-structs
quiz
slides: presentation pdf
>>> Assign (Racket) WashU WarmUp Recursive Circles
>>> Assign (Racket) WashU WarmUp Vector Graphics
       
Wed Mar 23 (#16) Functional Dynamic 2b PL B 2 video: implementing-programming-languages
PL B 2 video: what-your-interpreter-can-and-cannot-assume
PL B 2 video: implementing-variables-and-environments
PL B 2 video: implementing-closures
PL B 2 video: are-closures-efficient
PL B 2 video: racket-functions-as-macros-for-interpreted-language
quiz
slides: presentation pdf
>>> Assign (Racket) WashU Exercise MUPL Programs
>>> Assign (Racket) UW Exercise MUPL
       
       
Sat Mar 26<<< Submit (Racket) UW Exercise Streams
<<< Submit (Racket) WashU Exercise Sierpiński and Cantor
<<< Submit (Racket) WashU Exercise Snowflake
       
Mon Mar 28 (#17) Functional Dynamic 3avideo: Reverse Stream Scenario
video: Reverse Stream Scenario Responses
PL B 3 reading: section-7-welcome-message
PL B 3 reading: section-7-reading-notes
PL B 3 video: ml-versus-racket
PL B 3 video: what-is-static-checking
PL B 3 video: soundness-and-completeness
PL B 3 video: weak-typing
quiz
slides: presentation pdf
>>> Assign (Racket) WashU WarmUp Deep Lists
       
Wed Mar 30 (#18) Functional Dynamic 3bvideo: A Champion For C Has Arrived
PL B 3 video: static-versus-dynamic-typing-part-one
PL B 3 video: static-versus-dynamic-typing-part-two
PL B 3 video: eval-and-quote
PL B 3 video: part-b-wrap-up-and-part-c-preview
quiz
slides: presentation pdf
>>> Assign (Racket) WashU WarmUp Dynamic Spreadsheet
       
       
Sat Apr 2<<< Submit (Racket) UW Exercise MUPL
<<< Submit (Racket) WashU Exercise MUPL Programs
       
Mon Apr 4 (#19) OOP Dynamic 1a PL C 1 reading: section-8-welcome-message
PL C 1 reading: section-8-reading-notes
PL C 1 video: introduction-to-ruby
PL C 1 video: classes-and-objects
PL C 1 video: object-state
PL C 1 video: visibility
PL C 1 video: a-longer-example
PL C 1 video: everything-is-an-object
PL C 1 video: class-definitions-are-dynamic
PL C 1 video: duck-typing
quiz
slides: presentation pdf
>>> Assign (Ruby) WashU Exercise Render Part A
       
Wed Apr 6 (#20) OOP Dynamic 1b PL C 1 video: arrays
PL C 1 video: blocks
PL C 1 video: using-blocks
PL C 1 video: procs
PL C 1 video: hashes-and-ranges
quiz
slides: presentation pdf
>>> Assign (Ruby) WashU WarmUp Home Is Where The (Ruby) Heart Is
>>> Assign (Ruby) UW Exercise Tetris
       
       
Sat Apr 9
       
Mon Apr 11 (#21) OOP Dynamic 1cvideo: Composition vs Inheritance
PL C 1 video: subclassing
PL C 1 video: why-use-subclassing
PL C 1 video: overriding-and-dynamic-dispatch
PL C 1 video: method-lookup-rules-precisely
PL C 1 video: dynamic-dispatch-versus-closures
PL C 1 video: dynamic-dispatch-manually-in-racket
quiz
slides: presentation pdf
>>> Assign (Ruby) WashU WarmUp Powers of 2 Range
       
Wed Apr 13 (#22) OOP Dynamic 2avideo: The Matrix: Blue Pill or Red Pill
video: The Matrix: Jump Program
PL C 2 reading: section-9-welcome-message
PL C 2 reading: section-9-reading-notes
PL C 2 video: oop-versus-functional-decomposition
PL C 2 video: adding-operations-or-variants
PL C 2 video: binary-methods-with-functional-decomposition
PL C 2 video: double-dispatch
PL C 2 video: multimethods
quiz
slides: presentation pdf
>>> Assign (Ruby) WashU Exercise Render Part B
       
       
Sat Apr 16<<< Submit (Ruby) WashU Exercise Render Part A
       
Mon Apr 18 (#23) OOP Dynamic 2b PL C 2 video: multiple-inheritance
PL C 2 video: mixins
PL C 2 video: interfaces
PL C 2 video: abstract-methods
quiz
slides: presentation pdf
>>> Assign (Ruby) WashU WarmUp Powers of 2 Range Enumerable Mixin
>>> Assign (Ruby) WashU Exercise Render Part C
>>> Assign (Ruby + SML) UW Exercise Geometry Language
       
Wed Apr 20 (#24) OOP Dynamic 3 PL C 3 reading: section-10-welcome-message
PL C 3 reading: section-10-reading-notes
PL C 3 video: subtyping-from-the-beginning
PL C 3 video: the-subtype-relation
PL C 3 video: depth-subtyping
PL C 3 video: java-c-arrays
PL C 3 video: function-subtyping
PL C 3 video: subtyping-for-oop
PL C 3 video: generics-versus-subtyping
PL C 3 video: bounded-polymorphism
PL C 3 video: summarizing-all-we-have-learned
PL C 3 video: saying-good-bye
quiz
slides: presentation pdf
>>> Assign (Ruby) WashU WarmUp Text File Writer
>>> Assign (Ruby) WashU Exercise Branch
>>> Assign (Ruby) WashU Exercise Render Part D
       
       
Sat Apr 23<<< Submit (Ruby) UW Exercise Tetris
<<< Submit (Ruby) WashU Exercise Render Part B
       
Mon Apr 25 (#25) The Computer Revolution Hasn't Happened Yet; Kingdom of Nouns; OOP Static 2: Interfaces, Classes, Inheritance, Final, Overridevideo: Alan Kay OOPSLA 1997
xkcd: The General Problem

Read: Execution in the Kingdom of Nouns
Read: Java Interfaces
Read: Java Inheritance
quiz
slides: presentation pdf
>>> Assign (Java) WashU WarmUp Integer Range Iterable
>>> Assign (Java) WashU Exercise Iterable ImList<E>
       
Wed Apr 27 (#26) Mostly Wrong History; OOP Static 3: Producer Extends Consumer Super; Teach Yourself Programming in Ten Yearsxkcd: Good Code

Read: A Brief, Incomplete, and Mostly Wrong History of Programming Languages
Read: Uber Programming Languages Story
Read: Producer Extends, Consumer Super
Read: Teach Yourself Programming in Ten Years (Norvig)
Read: How to Teach Yourself Programming (Abstruse Goose)
quiz
slides: presentation pdf
       
       
Sat Apr 30<<< Submit (Ruby + SML) UW Exercise Geometry Language
<<< Submit (Ruby) WashU Exercise Render Part C
<<< Submit (Ruby) WashU Exercise Branch
<<< Submit (Ruby) WashU Exercise Render Part D
Sun May 1<<< Submit (Java) WashU Exercise Iterable ImList<E>