Lectures: 0216 Siebel Center for Computer Science, MW: 9:30 AM – 10:45 AM
Member (NetID) | Role | Office Hours |
---|---|---|
Fan Lai (fanlai) | Instructor | 3128 Siebel Center. W 11:00 AM – 12:00 PM |
Chengsong Zhang (cz81) | TA | Zoom. M 11:00 AM - 12:00 PM |
Piazza: ALL communication regarding this course must be via Piazza. This includes questions, discussions, announcements, as well as private messages.
Presentation slides and paper summaries should be emailed to cs598-aisys-staff@illinois.edu.
Learning Objectives: This course will introduce the key concepts and the state-of-the-art in practical, scalable, and fault-tolerant software systems for emerging Generative AI (GenAI). At the end of the course you will be able to:
- Critique and evaluate the design details of state-of-the-art GenAI systems
- Develop and utilize tools to profile and understand the performance of GenAI systems
- Propose new research ideas in topics related to support practical GenAI
Structure: The course will be a mix of lectures, student presentations, seminar-style discussions, and a semester-long project on GenAI topics. We will cover GenAI topics from top conferences that take a systems view to the relevant challenges, including:
- Basics of GenAI models from a systems perspective;
- Systems for GenAI lifecycle (pre-training, training, fine-tuning/alignment, inference serving, and grounding);
- GenAI for systems and etc.
Note that this course is NOT focused on AI methods. Instead, we will focus on how one can build software systems so that existing AI methods can be used in practice and new AI methods can emerge.
Prerequisites: Students are expected to have good programming skills and must have taken at least one undergraduate-level systems-related course (from operating systems, databases, distributed systems, or networking). Having an undergraduate ML/AI course is helpful but not required.
This is an evolving list and subject to changes due to the breakneck pace of GenAI innovations.
Groups: All activities of this course, except your own participation :), will be performed in groups of 2-3 students. Form a group of 2-3 members and declare your group's membership and paper preferences by Sept 5. After this date, we will form groups from the remaining students.
Weight | |
---|---|
Participation | 10% |
Paper Presentation & Discussion | 15% |
Paper Summary | 15% |
Project Report | 40% |
Project Presentations | 20% |
Academic integrity: The University's Honor Code applies to all activities related to this course. All material you submit in this course (reading responses, project reports, and presentation materials) must be your own. If you use someone else’s material, you must cite them properly.
AI Tool Policy: AI tools may be used for grammar checking and refining initial brainstorms, but the final reviews and codes must be authored by the student. Students are responsible for the entire content and must adhere to the Academic Integrity Policy.
Before Each Lecture: Each lecture will include one or two required reading that everyone must read. There will be optional related reading(s) that only the presenter(s) should be familiar with. They are optional for the rest of the class. You are required to submit one insightful question for each presented papers before each class (up to 2 absences).
During Lectures: Active participation is crucial for both your own understanding and to improve the overall quality of the course. You are expected to attend all lectures (up to 2 absences allowed for legitimate reasons), and more importantly, participate in class discussions. Not everyone must have add something every day, but it is expected that everyone has something to share over the semester.
After Lectures: Participation also involves contributing to discussions on Piazza. The group responsible for the summary should initiate the (remaining) discussion, and the rest of the members are encouraged to participate.
The course will be conducted as a seminar. Only one group will present in each class. Each group will be assigned at least one lecture over the course of the semester. Presentations should last at most 40 minutes without interruption. However, presenters should expect questions and interruptions throughout.
In the presentation, you should:
- Provide a brief background to motivate the problem (e.g., simplifying this by referencing previous talks)
- Present the high level idea, approach, and/or insight (using examples, whenever appropriate) in the required reading.
- Discuss technical details so that one can understand key details without carefully reading (quickly skim the evaluations).
- Explain the differences between related works as well as the additional reading.
- Identify strengths and weaknesses of the required reading and propose directions of future research.
The slides for a presentation must be emailed to the instructor team (in *.pptx format) at least 24 hours prior to the corresponding class.
To foster a deeper understanding of the papers and encourage critical thinking, each lecture will be followed by a panel discussion. This discussion will involve three distinct roles played by different student groups, simulating an interactive and dynamic scholarly exchange.
- The Authors
- Group Assignment: The group that presents the paper and the group that writes the summary will play the role of the paper's authors.
- Responsibility: As authors, you are expected to defend your paper against critiques, answer questions, and discuss how you might improve or extend your research in the future, akin to writing a rebuttal during the peer-review process.
- The Reviewers
- Group Assignment: Each group will be assigned to one slot to play the role of reviewers.
- Responsibility: Reviewers critically assess the paper, posing challenging questions and highlighting potential weaknesses or areas for further investigation. Your goal is to engage in a constructive critique of the paper, simulating a peer review scenario.
- Rest of the Class
- Responsibility: During the panel discussions, feel free to actively ask questions and engage in the dialogue.
Each group will also be assigned to write summaries for at least TWO lectures. The summary assigned to a group will not be the reading they gave the lecture on.
A paper summary must address the following four questions in sufficient details (2-3 pages):
- What is the problem addressed in the lecture, and why is this problem important?
- What is the state of related works in this topic?
- What is the proposed solution, and what key insight guides their solution?
- What is one (or more) drawback or limitation of the proposal?
- What are potential directions for future research?
Late reviews will not be counted. The paper summary of a paper must be emailed to the instructor team within 24 hours after its presentation.
You should use this format for writing your summary. Use Google doc to enable in-line comments and suggestions.
Allocate enough time for your reading, discuss as a group, write the summary carefully, and finally, include key observations from the class discussion.
You will have to complete substantive work an instructor-approved problem and have original contribution. Surveys are not permitted as projects; instead, each project must contain a survey of background and related work.
You must meet the following milestones (unless otherwise specified in future announcements) to ensure a high-quality project at the end of the semester:
- Turn in a 2-page draft proposal, plus as many pages as needed for references, by September 26. Remember to include the names and UIUC email addresses of the group members.
- Each group must present mid-semester progress during class hours on October 21 and October 23.
- Each group must turn in an 8-page final report and your code via email on or before 6:00PM CDT on December 19. The report must be submitted as a PDF file, with formatting similar to that of the papers you've read in the class. The self-contained (i.e., include ALL dependencies) code must be submitted as a zip file. Each zip file containing the code must include a README file with a step-by-step guide on how to compile and run the provided code.
- You can find how to access GPU resources here.
This course is heavily inspired by other excellent system seminar courses, particularly UMich CSE 585. Acknowledgments to SymbioticLab.