Assignment Assigned Due Notes Solutions
Project 1 9/2/16
9/8/16
9/25/16
Checkpoint 1: 9/9/16
Checkpoint 2: 9/23/16
Checkpoint 3: 10/7/16
Please go through all the links in Checkpoint 3 the link. This CP is harder than CP2 so please start early
Grade distribution
Homework 1 Sep 25 at 5:00PM on Gradescope Oct 02 at 11:59PM on Gradescope
Homework 2 Oct 7 at 01:00AM on Gradescope Oct 13 at 11:59PM on Gradescope Solution
Project 2 10/11/16 Checkpoint 1: 10/24/16
Please read through the entire handout. CP1 has 2 weeks so it doesn't interfere with the midterm, but it is only a small portion of the work
Starter Code
Project 2 FAQ
Checkpoint 1 Test Script
Final Checkpoint 1 Test Script
Homework 3 Nov 10 at 01:00PM on Gradescope Nov 18 at 11:59PM on Gradescope Solution
Project 3 11/11/16 Checkpoint 1: 11/25/16
Final Version: 12/09/16
Please read through the entire handout before starting on the project. Please use the following links for downloading starter code and VM images.
Big VM image
Minimal VM image
VM Setup Script
CP1 Grader
CP2 Grader
Homework 4 Dec 1 at 1:30PM on Gradescope Dec 8 at 11:59PM on Gradescope

There will be three programming projects and (roughly) four written homework assignments.

All homework and the first project is to be done individually. The second and third programming projects will be done in groups of two students for two reasons: the first is the size of the class. The second (and more important) reason is that this is an opportunity to experience the joys and frustrations of working with others. It's a skill you only get better at with practice.

Since 15-441 fulfills the project-class requirement of the CS degree, you will be expected to learn and practice good software engineering, as well as demonstrate mastery of the networking concepts. Both partners in a project group will need to fully understand the project and your solution in order to do well on those exam questions relating to the projects. For example, a typical question might be: "When you implemented X, you came across a particular situation Y that required some care. Explain why this simple solution Z doesn't work and describe how you solved it." We'll pick questions such that it will take some effort to figure out Y. If you didn't take the time to work the problem yourself and just relied on your partner, you won't have enough time during the test to figure it out. Be careful, the insights you'll need will come only from actually solving the problem as opposed to just seeing the solution.

By their nature, the assignments aren't going to be completely comprehensive of everything you'll encounter in the real world or in class. To assist you, we've compiled a list of suggested study problems that you may want to do in addition to the normal homework. They're not graded, but they'd make great topics to discuss with the course staff during office hours.

Notes on the Programming Projects

A key objective of 15-441 is to provide a significant experience with system programming, where you must write programs that are robust and that must integrate with a large, installed software base. Oftentimes, these programs are the ones that other people will build upon or use as tools. Systems programming is very different from the application program development you have done in earlier courses:

Finally, please note that, by design, the 15-441 projects do not always specify every corner case bit of behavior or every design decision you may have to make. A major challenge in implementing real systems is in making the leap from a specification that is often somewhat incomplete (e.g., the IRC spec) to a real-world implementation. Don't get frustrated --- our grading will not dock you for making reasonable design decisions! We suggest three general guidelines to follow:

We'll go into more detail about each of these points during the recitation sections. But keep in mind: the programming assignments in 15-441 are larger and more open-ended than in other courses. Doing a good job on the project requires more than just producing code that runs: it should have a good overall organization, be well implemented and documented, and be thoroughly tested.


Last updated: 2016-12-15 17:49:04 -0500 [validate xhtml]