EECS 485: Web Systems Syllabus
The University of Michigan, Fall 2023
A holistic course of modern web systems and technologies, covering front end and back end. Build an Instagram clone in the first half of the semester and a Google clone in the second.
Lectures will be in-person. You may attend any lecture section or watch any of the recordings, even if it's different from your registered section. We don't take attendance in lecture.
Labs will be in-person, and one lab will be recorded. Expect hands-on practice with concepts from lecture and project introduction material. You may attend any lab section or watch the recordings, even if it's different from your registered section. We don't take attendance in lab.
Projects will be completed in groups and turned in to an autograder. If you'd like, we'll help you find a group.
Exams will be in-person on paper.
Office hours will be hybrid, with in-person on Mondays, Wednesday, and Thursdays, and remote on Tuesdays and Fridays.
Computer and network recommendations
Make sure you have a laptop consistent with CAEN recommendations.
Test your internet connection with the U-M Custom Speedtest website and make sure it meets the minimum requirements for all UM or CAEN services. You'll need more bandwidth if there will be multiple simultaneous users in your household.
Resources for help with computing equipment:
- Information and Technology Services (ITS) Laptop loaner program
- College of Engineering (CoE) Office of Student Affairs, email requests to email@example.com
eecs485.org links to all course resources and is required reading.
Piazza is the course discussion forum, best for technical questions and project updates. Do not publicly post your code.
firstname.lastname@example.org reaches the course staff, best for non-technical questions.
Individual professor email addresses are best for confidential matters.
EECS 485 integrates concepts from multiple computer science disciplines used in web applications ("front end"), web services ("back end") and web semantics ("extracting knowledge and information"). Within these three themes, the course covers concepts such as:
|Web Applications||Web Distributed Systems||Web Semantics|
Students build a social media application similar to Instagram or Facebook and a search engine like Google or Bing. They gain experience with practical web technologies such as:
By the end of this course, successful students will feel comfortable learning a new web technology independently using developer documentation. They will able to:
The prerequisite for EECS 485 is EECS 281.
There will be one midterm and one final examination. Exam dates are posted on eecs485.org. There will be no make-up exams. It is your responsibility to verify you can attend both exams.
Practice exams for many previous semesters are in the EECS 485 Exam Repository. We'll support exams from the most recent two semesters in office hours.
Labs will contain hands-on practice with concepts from lecture and helpful project introduction material.
This course contains 5 programming projects. The first three focus on web apps, while the last two focus on web distributed systems and web semantics.
Project 1: Templated Static Site Generator. An Instagram clone implemented with a templated static site generator.
Project 2: Server-side Dynamic Pages. An Instagram clone implemented with server-side dynamic pages.
Project 3: Client-side Dynamic Pages. An Instagram clone implemented with client-side dynamic pages.
Project 4: MapReduce. A single machine, multi-process, multi-threaded server that executes user-submitted MapReduce jobs.
Project 5: Search Engine. A scalable search engine similar to Google or Bing.
We improve the projects each semester, so they may change any time before the project release date.
Project 1 is independent. The remaining projects are completed in groups of 2-3.
You may modify group membership between projects. You must not modify group membership during a project. In exceptional cases, you may request group dissolution via email to the faculty. If the dissolution is granted, all group members may use previously shared code and no group member may join another group for remainder of the project.
Each group turns in one solution to the autograder. You must register your group on the autograder. All group members earn the same grade on a project. We may adjust the grades of students who substantially under-participate based on feedback from their group members.
For those retaking the course: if you submitted an assignment in a previous term, you must not work in a group on that same assignment this term.
We use a web-based autograder to evaluate correctness and style.
Before the deadline, you may submit up to 3 times per day. After each submission, the autograder shows the results of the public tests released with the project.
After the deadline, the autograder shows the results of private tests.
Your final project score is a combination of public and private tests. We use the submission that received the combined best score. If multiple submissions share the best score, we grade the last.
Letter grades are assigned on a curve. In general, our goal is be consistent with past semesters.
We calculate your total weighted score using these weights.
|Assignment||Percentage of Grade|
|Programming Projects||5 projects x 10% each = 50%|
Sometimes the difficulty of exams varies from semester to semester. We use a curve to maintain consistent letter grades despite exam variation. In general, our goal is be consistent with past semesters, where a median grade is 3.3 (B+).
You are guaranteed to pass EECS 485 with a C or better if:
- Your total weighted project score is at least 73.0%; and
- Your total weighted exam score is within 1.5 standard deviations of the mean or above 60%, whichever is in your favor.
Deadlines and Extensions
We do not accept late work.
We will consider extension requests made at least two weeks in advance, for example, for religious holidays or planned medical procedures.
For medical or personal emergencies we will consider exceptions on a case-by-case basis. Please provide documentation of the emergency.
Projects are due on Sunday, but staff will support projects through Friday 5PM in office hours and Piazza. If you choose to work on the project after Friday 5PM, staff will not be available during that time for questions.
Exams are graded by hand. Request a regrade via Gradescope. Your score may go up or down.
Projects are automatically graded. We do not accept regrade requests.
In all cases regrade requests are due no later than 7 days after a grade is released unless a shorter deadline is specified.
We encourage collaboration in EECS 485, especially on concepts, tool, specifications, and strategies.
All work you submit must be your own or your group's. Collaboration must not result in code that is identifiably similar to other solutions, past or present.
You are still responsible for following these rules even after finishing the course.
If you are unsure about what constitutes an honor code violation, please contact the course staff with questions.
If you are retaking the course, you may reuse your own code, provided it was wholly written according to rules outlined in this syllabus. It is possible for instructors to miss an honor code violation in a previous term, but catch and report it when the code is reused.
You may not make your code publicly available in any form, for example, in a public GitHub repository or personal website. You are still responsible for following these rules even after finishing the course.
If you are recruiting and would like to show companies your work in EECS 485, our recommendation is to create a Git repository with only a README file and no code. Take a screenshots of your solution put those in the README. Include a description of the languages, libraries, frameworks, and technologies you used. Another option is to privately demo or send your code to a recruiter.
Generative AI (Copilot, ChatGPT)
The use of generative AI tools such as GitHub Copilot and ChatGPT is permitted for projects. Some examples of responsible use of generative AI include autocompleting repetitive/boilerplate code and generating usage examples for library functions. Creating large sections of code you do not understand yourself is using generative AI in an irresponsible way.
Remember that during the exams you will write code without the help of generative AI tools.
Course lectures may be audio/video recorded and made available to other students in this course. As part of your participation in this course, you may be recorded. If you do not wish to be recorded, please contact your instructor the first week of class to discuss alternative arrangements.
Students may not record or distribute any class activity without written permission from the instructor, except as necessary as part of approved accommodations for students with disabilities. Any approved recordings may only be used for the student’s own private use.
Accommodations for Students with Disabilities
If you think you need an accommodation for a disability, please let your instructor know during the first three weeks of the semester. Some aspects of this course may be modified to facilitate your participation and progress. As soon as you make us aware of your needs, we can work with the Services for Students with Disabilities (SSD) office to help us determine appropriate academic accommodations. SSD (734-763-3000; https://ssd.umich.edu) typically recommends accommodations through a Verified Individualized Services and Accommodations (VISA) form. Any information you provide is private and confidential and will be treated as such.
Commitment to Equal Opportunity
As indicated in the General Standards of Conduct for Engineering Students, we are committed to a policy of equal opportunity for all persons and do not discriminate on the basis of race, color, national origin, age, marital status, sex, sexual orientation, gender identity, gender expression, disability, religion, height, weight, or veteran status. Please feel free to contact us with any problem, concern, or suggestion. We ask that all students treat each other with respect.
Students' Mental Health and Well-being
Students may experience stressors that can impact both their academic experience and their personal well-being. These may include academic pressure and challenges associated with relationships, mental health, alcohol or other drugs, identities, finances, etc.
If you are experiencing concerns, seeking help is a courageous thing to do for yourself and those who care about you. If the source of your stressors is academic, please contact me so that we can find solutions together. For personal concerns, U-M offers many resources, some of which are listed at Resources for Student Well-being on the Well-being for U-M Students website. You can also search for additional resources on that website.