This is an introductory course on formal software specification and verification, covering various formalisms, methods, and tools for specifying the properties of a software program and for verifying that the program meets its specification. Its goal is to acquaint the students with fundamentals of formal software verification and to prepare them for conducting research in the area. We will focus on deductive (theorem proving) methods. A separate, complementary course entitled “Automatic Verification” covers algorithmic (model checking) methods.
Yih-Kuen Tsay (蔡益坤), Room 1108, Management II, 3366-1189, Xtsay@im.ntu.edu.twX (between the enclosing pair of X's)
Thursday 1:20-2:50PM and 5:00-6:00PM, Room 204, College of Management, Building I
Note: when the class is small enough, we will meet in Room 1108, Management Building II.
Wednesday 1:30-2:00PM (Room 1108, Management II) or by appointment
Computer Programming and Discrete Mathematics
Class Notes and Selected Readings
We shall seek to strike a balance between depth and breadth, covering both the foundations and some of the more successful formalisms, techniques, and tools. Below is a tentative list of topics and their schedule:
Homework Assignments 15%, Final 35%, Term Paper/Report 40%, Participation 10%.