Prerequisites | Students should feel comfortable programming in some object oriented language (e.g., Java, C++) or functional language (Haskell, ML, Scheme). A rudimentary knowledge of basic logic design (6.004) and undergraduate-level knowledge of Computer Architecture (Hennessy & Patterson books) is assumed. As with all project courses the end of term crunch can be a problem, so it would be unwise to take this course with another which also has a significant design project due at the end of the term. |
---|---|
Lectures | Lectures will be from 1:00 PM to 2:30 PM every Monday, Wednesday, and Friday in Room 5-234. Most of Friday class sessions in the first half of the term are designated as Q&A sessions and tutorials. The course schedule is subject to change, so please visit Schedule regularly. In the second half of the term each project team will be expected to meet once per week with the instructor. These meetings will be scheduled during the normal lecture times. |
Grades | Grades will be based on labs (30%), project milestones (25%), a final project demonstration (20%), and the final completed project (25%). |
Lab Assignments | Labs are to be done individually and are designed to help you learn the skills you'll need to complete the final project. Some of the labs are too long to be done the night before the due date, so plan accordingly. Late labs will not be accepted. See the schedule for details on when labs are due. Feel free to get help from others, but the work you hand in should be your own. |
Final Project | Projects will be done in groups of 2 students. Each group will be assigned a senior graduate student as a mentor. The mentor will provide oversight and advice to the project group. Several milestone reports (two to three pages) will be due periodically. These milestone reports are (1) Project Proposal, (2) High-level Design and Test Strategy, (3) Detailed Micro-Architectural Design, (4) Design Space Exploration. Final project presentations will take place during the last week of classes. The final report (15 to 20 pages) is due Dec 11. There are no extensions. |
TQE | Course 6.375 may satisfy one of your Technical Qualifying Examination (TQE) requirements for the Systems Group. See Graduate Office TQE Instruction for more info on the TQE. |
Lab Resources | Dedicated Athena servers, some with FPGAs attached, can be used for the labs. All tools can be run out of the course locker on any Athena/Linux machine. See Lab Resources for more information on the computing resources available for the class. |
Collaboration and Academic Honesty Policy |
Collaboration amongst students to understand the course material is strongly encouraged, however any work you turn in must be your own. |
Course Reading Material | There is no text book for the course. Books and links which would provide useful reference are listed on the resources page. |
Communications | Questions can be made on piazza publicly and privately. In addition, the instructor can be reached by email. |