COMP 311 / COMP 544: Functional Programming (Fall 20172018)
Instructors | Dr. Nick Vrvilo (2σ) Dr. Corky Cartwright | Graduate TAsTA | — | Undergraduate TAs | Ryuichi Sai ryuichi@rice.edu | —|
---|---|---|---|---|---|---|
Lectures | Duncan Hall 1075 | Lecture Times | 4pm–5:15pm TR | |||
Course Instructor Email | {nick.vrvilo,cork}@rice.edu | Online Discussion | Piazza – Rice Comp 311 |
...
Description
Grading will be based on your performance on weekly programming assignments. All work in this class is expected to be your own, and you are expected not to post your solutions or share your work with other students, even after you have taken the course. Please read the Comp 311 Honor Code Policy for more details on how you are expected to work on your assignments. There will also be a final exam, as described in the syllabus.
All students will be held to the standards of the Rice Honor Code, a code that you pledged to honor when you matriculated at this institution. If you are unfamiliar with the details of this code and how it is administered, you should consult the Honor System Handbook. This handbook outlines the University's expectations for the integrity of your academic work, the procedures for resolving alleged violations of those expectations, and the rights and responsibilities of students and faculty members throughout the process.
Students with disabilities are encouraged to contact me during the first two weeks of class regarding special needs. Students with disabilities should also contact Disabled Student Services in the the Ley Student Center and and the Rice Disability Support Services.
General Information
...
Week | Day | Date | Topic | Work Assigned | Work Due | ||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | Tu | Aug 2221 | |||||||||||
Th | Aug 24 | What are Types, Core Scala* | 23 | Computation by Reduction, Types | Homework Hwk 0 | ||||||||
2 | Tu | Aug 29—*28 | |||||||||||
Th | Aug 31 | —* | 3 | Tu | Sep 05 | Doubles, 30 | Programming with Intention, The Design Recipe | *||||||
3 | ThTu | Sep 0704 | Conditionals, Functions on Ranges , Datatypes* | ||||||||||
Tu | Th | Sep | 1206 | Methods, Objects, Grading | , DrScala*Homework 0 | ||||||||
4 | ThTu | Sep 1411 | Static Type Checking, Abstract Datatypes* & DrScala | Hwk Homework 1 | |||||||||
| TuTh | Sep | 1913 | 2 | * | ||||||||
5 | ThTu | Sep 2118 | |||||||||||
| TuTh | Sep | 2620 | , Variable & Named Args* | |||||||||
6 | Tu | Sep 25 | Homework 2 | Homework 1 | |||||||||
| Th | Sep 2827 | Hwk 2 Hwk 1 | ||||||||||
7 | Tu | Oct 0302 | Type Hierarchy, Variance, Generic Map FunctionCovariance and Contravariance, ...* | ||||||||||
| Th | Oct 0504 | Fold, Zip, Flatten, For Expressions... Currying, Fold, Flatmap, and For Expressions* | ||||||||||
8 | Tu | Oct 10MIDTERM RECESS*09 | Midterm Recess (no classes) | ||||||||||
| Th | Oct 12 | Hwk 3 | 11 | Homework 3 | Homework Hwk 2 | |||||||
9 | Tu | Oct 1716 | Accumulators | For Expressions, Monads, The Environment Model* | |||||||||
| Th | Oct 1918 | Call-by-Name/Value, Scala Immutable CollectionsScala Collections Classes, Traits* | ||||||||||
10 | Tu | Oct 24Generative Recursion*23 | Growing a Language, by Guy L. Steele, Jr. | ||||||||||
| Th | Oct 26 | Hwk 4 | 25 | Hwk 3 | ||||||||
11 | Tu | Oct 3130 | |||||||||||
| Th | Nov 02 | 01 | Homework 4 | Homework 3 | ||||||||
12 | Tu | Nov 0706 | |||||||||||
| Th | Nov 09 | 08 | ... | Hwk 4 | ||||||||
13 | Tu | Nov 1413 | |||||||||||
| Th | Nov 16 | Hwk 5 | 15 | Homework 5 | Homework 4 | |||||||
14 | Tu | Nov 21 | More Parser Combinators, Actors and Concurrency* | 20 | Videos: What to Leave Implicit and Impromptu | Hwk 6 (Optional) | |||||||
| Th | Nov 23THANKSGIVING*22 | Thanksgiving Holiday (no classes) | ||||||||||
15 | Tu | Nov 2827 | |||||||||||
Th | Nov 3029 | Course Wrap-upVideos: What to Leave Implicit and Impromptu* | Hwk Homework 5 & 6 | ||||||||||
16 | Tu | Dec 0504 | Study Days Day (no classes)* | ||||||||||
| ? | F | Dec 07??? | Final Exam: 2–5pm in Duncan Hall 1075 |
* Lectures slides not yet updated from last year are marked with an asterisk.
** The place and time of the final exam is set by the registrar. The current scheduling details are available on the registrar's page for this course.