The students who have taken IS593 (Language-based Security) are not eligible to apply.
- Instructor: Kihong Heo (허기홍, kihong.heo@prosys.kaist.ac.kr)
- TAs (mailing list: cs524.ta@prosys.kaist.ac.kr)
- Tae Eun Kim (김태은)
- Geon Park (박건)
- Time: Mon/Wed 09:00 - 10:30
- Location: N1 102
- Office hours:
- Instructor: Mon 10:30 - 11:30
- TAs: Wed 10:30 - 11:30
"How to estimate the behavior of a program before it runs?"
This course introduces a technique called program analysis that answers the question. Instead of running programs with potentially infinite inputs, program analysis statically estimates the runtime behaviors of programs within a finite time. The course will cover fundamental theories, designs, and implementations of program analysis including formal semantics of programming languages and the theory of abstract interpretation.
- Homework 50%
- Final exam 40%
- Participation 10%
This course does not allow for P/NR grading.
- Lecture slides will be provided
- Xavier Rival and Kwangkeun Yi, Introduction to Static Analysis: an Abstract Interpretation Perspective, MIT Press, 2020
This course includes programming assignments through which students will learn how to design and implement program analyzers. Students will use a few tools which are described here.
All submissions will be managed using Github.
For each assignment, a unique invitation URL for GitHub Classroom will be posted in the discussion board.
Once you accept the invitation, a private repository for your assignment will be created.
You can push as many commits as you want before the deadline. We will grade the final commit of your main
branch.
The late homework policy is as follows:
- 80% credit for one day late
- 50% credit for two days late
- NO credit given after two days late
Students who violate academic integrity will get F. See the KAIST CS honor code.
Have fun with student artifacts from previous semesters here (distinguished essays, drawings, etc).
- PL Wiki
- Static Analysis in the Real World
- Lessons from Building Static Analysis Tools at Google, CACM 2018
- Scaling Static Analysis at Facebook, CACM 2019
- Detect Bugs Early with the Static Analyzer, Apple WWDC 2021
- Automated Reasoning @ Amazon