CSCI-598 Program Verification & Synthesis, Spring 2020
Course Information
- Lecture Time/Location: Tue Thu 11:00am-12:15am, Alderson Hall 152
Instructor
Jedidiah McClurg, Assistant Professor of CS
- Contact: mcclurg (at) mines (dot) edu
- Office: Brown Hall 280C
- Office Hours: Tue 1:00pm-1:50pm, Thu 2:00pm-3:50pm
Teaching Assistant (TA)
(No teaching assistant)
Course Overview
This course is a hands-on introduction to formal methods. Students will learn how to (1) reason about correctness of programs using first-order logic, temporal logic, and Hoare logic, (2) build tools such as model-checkers to formally verify (exhaustively test) programs written in various languages, and (3) leverage verification functionality to automatically generate (synthesize) correct programs from high-level descriptions of program behavior.
Prerequisites
There are no official prerequisites, but it is recommended that you have some familiarity with the material covered in CSCI-400 Programming Languages. It is also helpful if you have some basic Linux command-line experience.
Course Goals
- Learn several approaches for specifying and reasoning about correctness of programs.
- Learn how to build verification tools to check the correctness of programs.
- Gain exposure to recent research in the area of program synthesis.
- Apply some verification/synthesis techniques in a domain of interest to you.
Textbook and Other Reading Materials
NOTE: the following resources are recommended, but not required. The instructor will assign readings from these sources to supplement our discussions in class, but our in-class discussions will constitute the “official” version of the course material.
The above links will take you to free versions of the materials.
Schedule
This schedule is tentative, and is subject to change. Deadlines are at midnight (Mountain Time) on the corresponding date.
week | date | topic | lecture notes | supplemental reading | homework | project |
---|---|---|---|---|---|---|
1 | Jan 7 | introduction to formal methods | lecture01 | hw1 assigned | ||
Jan 9 | natural deduction | lecture02 | LICS 1.1-1.2 | hw1 due | ||
2 | Jan 14 | propositional logic | lecture03 | LICS 1.3 | hw2 assigned | |
Jan 16 | semantics of propositional logic | lecture04 | LICS 1.4 | |||
3 | Jan 21 | normal forms | lecture05 | LICS 1.5 | ||
Jan 23 | SAT solving | lecture06, DPLL | LICS 1.6, CDCL | hw2 due | ||
4 | Jan 28 | predicate logic | lecture07 | LICS 2.1-2.2 | hw3 assigned | |
Jan 30 | proof theory of predicate logic | lecture08 | LICS 2.3 | |||
5 | Feb 4 | no class (Career Day) | ||||
Feb 6 | semantics of predicate logic, SMT solving | lecture09 | LICS 2.4, SMT | hw3 due | ||
6 | Feb 11 | linear temporal logic (LTL) | lecture10 | LICS 3.2 | ||
Feb 13 | model checking | lecture11 | LICS 3.3 | |||
7 | Feb 18 | no class (holiday) | ||||
Feb 20 | computation tree logic (CTL) | lecture12 | LICS 3.4 | |||
8 | Feb 25 | CTL model checking | lecture13 | LICS 3.6.1 | ||
Feb 27 | guest lecture: Jordan Schmerge | project proposal due | ||||
9 | Mar 3 | LTL model checking | lecture14 | LICS 3.6.3 | hw4 assigned | |
Mar 5 | program syntax/semantics | lecture15 | LICS 4.1-4.2.1 | |||
10 | Mar 10 | program verification | lecture16 | LICS 4.2.2-4.2.4 | ||
Mar 12 | Hoare logic | lecture17 | LICS 4.3 | hw4 due | ||
11 | Mar 17 | verification conditions | lecture18 | Weakest Preconditions | ||
Mar 19 | finding loop invariants | |||||
12 | Mar 24 | no class (holiday) | ||||
Mar 26 | no class (holiday) | |||||
13 | Mar 31 | Team 5: paper presentation | Combinatorial Sketching for Finite Programs | |||
Apr 2 | Team 4: paper presentation | Sketching Concurrent Data Structures | ||||
14 | Apr 7 | Team 6: paper presentation | Oracle-Guided Component-Based Program Synthesis | |||
Apr 9 | Team 1: paper presentation | Automating String Processing in Spreadsheets Using Input-Output Examples | ||||
15 | Apr 14 | Team 2: paper presentation | Abstraction-Guided Synthesis of Synchronization | hw5 assigned | ||
Apr 16 | Team 3: paper presentation | TRANSIT: Specifying Protocols with Concolic Snippets | ||||
16 | Apr 21 | Team 7: paper presentation | Syntax-Guided Synthesis | presentation slides due | ||
Apr 23 | project presentations | |||||
17 | Apr 28 | project presentations | hw5 due | |||
Apr 30 | no class (“dead day”) | |||||
18 | May 5 | no class (final exam week) | ||||
May 7 | no class (final exam week) | final report and project code due |
Homework
There will be approximately 8 homeworks, which will be completed individually. These are designed to help encourage you to keep up-to-date on the course material. You will have approximately 2 weeks to work on each homework.
Student Paper Presentations
Students will work in groups of 2-3 to thoroughly read one of the program synthesis research papers at the end of the course schedule. Each group will prepare a detailed (50 min) presentation on the paper, and will lead the class discussion on the corresponding day. Teams/papers will be chosen shortly after project proposals are due.
Final Project
Each student will propose a programming project which utilizes a verification/synthesis technique(s) in a domain of interest. Project proposals are due approximately halfway through the course (week 8). Each student will give a brief presentation during the last week of class, to describe the project results. A brief final report will be due at the end of finals week.
Project Proposal
The purpose of this document is to propose a non-trivial problem related to the topics discussed in the class, and describe the basic steps you will take to develop a software solution. The project proposal should be in PDF format, and should be typeset nicely using LaTeX, Word, LibreOffice, or similar. The report should be 3-4 pages, and should contain at a minimum the following sections:
- Introduction: describe the problem you are trying to solve, and discuss the problem’s relevance.
- Examples: work through some self-contained examples by hand.
- Proposed Approach: propose a technique/algorithm to solve the problem, and discuss the expected challenges.
- Proposed Evaluation: describe how you will evaluate the correctness/performance of your solution.
Your proposal should provide convincing evidence that (A) the problem is non-trivial, and (B) you have a reasonable plan to tackle the problem. For our purposes, non-trivial will mean (roughly) that an algorithm needs to be written to solve the problem. For example, implementing a SAT solver by making a single call to Z3 or MiniSAT would be a trivial solution. If any aspect of the proposal is unconvincing, the instructor may require changes that will need to be documented and incorporated into the final project.
Project Report / Project Code
The purpose of the Project Report is to flesh out the details missing from the Project Proposal – in particular, you should detail the steps you took to develop your solution, and show how you tested it. The project proposal should be in PDF format, and should be typeset nicely using LaTeX, Word, LibreOffice, or similar. The report should be 6-8 pages, and should contain at a minimum the following sections:
- Introduction: describe the problem you solved, and discuss the problem’s relevance.
- Examples: work through some self-contained examples, either by hand, or step-by-step using your tool.
- Approach: describe the technique/algorithm you built to solve the problem, and discuss the challenges you encountered.
- Evaluation: describe how you evaluated the correctness/performance of your solution.
The Project Report (an the accompanying Project Code) are due on the last day of the semester (see Schedule). The Code should work on a standard Ubuntu Linux machine. If needed, you can package your code as a VirtualBox VM, so that it can be run on Linux.
Project Presentation
We will have short final-project presentations during the final two class periods. Each presentation time slot will be 8 minutes. Aim for 5-6 minutes of presentation, and that will leave 2-3 minutes for questions. Please practice your talk to ensure that it falls in the 5-6 minute range, so that we can keep on schedule. Your presentations slides are due the week before the first presentation begins (see Schedule). Please upload your slides in PDF format to your project repository.
In your talk, please be sure to cover each of the 4 elements on the project (Introduction, Examples, Approach, Evaluation). One detailed slide for each of these should be sufficient.
Online Community and Communication
In Homework 1, you will be asked to introduce yourself to the instructor. This includes sending a passport-style photo of yourself to the instructor (or adding one on your Canvas profile). The photo must be clear, with your face un-obstructed. If you are not comfortable providing a photo, then you will need to contact the instructor to set up a brief in-person meeting to introduce yourself. Failure to meet this requirement on Homework 1 will result in a 0 (zero) for the Participation component of the grade.
We will use Piazza in the class. This is a great way to ask questions and communicate with the instructor and your classmates. Participation on Piazza will factor into the Participation component of the grade.
The class Piazza link is: https://piazza.com/class/k51i3nb2iw64cp
The instructor will use Piazza to communicate with the class. If you have questions about the course, you should first do a quick search on the Piazza page, to make sure your question has not already been answered there. If not, please go ahead and post your question on Piazza so that the instructor or another student can answer it publicly. This will help to streamline the communication.
NOTE: if you have a question you do not wish to publicize (e.g., about grades, etc.), please create a “private post” on Piazza. Email should only be used in rare instances where use of Piazza would not be feasible.
There is a Github organization for the class: https://github.com/mines-pvs
All of your individual/team repositories will show up there.
Class Notes
Class notes will be posted 1-2 days after the lecture. Posted notes are not guaranteed to provide all information discussed in lecture (class attendance is highly recommended).
Grading
The following percentages show how final grades will be calculated. The instructor will not perform any rounding on the scores (e.g., a score of 92.999 will not be rounded up to 93). The instructor may or may not curve the overall grades, depending on how well the class performs overall, however, The instructor expects each student to work hard, and not rely on the curve!
item | percentage |
---|---|
homeworks | 45% |
presentations | 20% |
final project | 25% |
participation | 10% |
Letter grades will be calculated based on the following intervals:
range | grade |
---|---|
[93,100] | A |
[90,93) | A- |
[87,90) | B+ |
[83,87) | B |
[80,83) | B- |
[77,80) | C+ |
[73,77) | C |
[70,73) | C- |
[67,70) | D+ |
[63,67) | D |
[60,63) | D- |
[0,60) | F |
Late Policy
Any work submitted after midnight (Mountain Time) on the stated deadline will be subject to a late penalty. If the work is submitted x hours late, the following percentage will be deducted from your score:
1.13 / (1 + e^(-2 × 0.51 × ((x / 24) - 2))) - 0.13.
Notice that the penalty increases as times passes: 24 hours late is -17%, 48 hours late is -44%, 72 hours late is -70%, etc.
Attendance
We will not take attendance, but your overall class attendance will factor into the Participation component of the grade.
Collaboration
We will use GitHub for collaboration. We will use private individual and team-specific repositories to submit assignments. Your repositories will show up here: https://github.com/mines-pvs
Respectfulness and Academic Honesty
Every student is expected to show respect to the instructors and the rest of the class. This course is preparation for your future career, so make sure you are behaving with the same level of professionalism that would be expected at a future full-time position. The general rule of thumb is: informal is okay, but disrespectful is not.
- The instructor prefers to be addressed by his nickname “Jed”, but “Prof. McClurg” or “Dr. McClurg” is also fine.
- It is vital that you do your best to be participate in the class, and communicate with the instructor(s) about any course-related difficulties you are facing.
Plagiarism/cheating is NOT acceptable, and will be met with the maximum available penalty. Sophisticated plagiarism-detection software will be used on every submitted assignment, and all confirmed instances of cheating will be immediately reported to the Computer Science department. Please ensure that you do not engage in or facilitate academic dishonesty in this class!
IMPORTANT CAVEATS
-
A purely grade-driven approach to taking (graduate) courses is at best unnecessary, and at worst highly counterproductive. The volume of grade-related email/questions generated by students is typically far too high. As a (graduate) student, your task is not to to squeeze every possible point out of the course, your job is to learn the material, and be able to use it in the real world (for your research, or for your future job, etc.). It’s likely that 99% of employers are NOT going to care if you have an A versus an A- or B+, but they ARE going to care if you can reason about computer science concepts, write code, and understand how to build systems.
-
YOU will determine how much knowledge/experience you gain from this course. The instructor has lots of expertise in the domains covered in the course, and will work hard to present you with the resources, tools, and techniques to develop a similar skillset. However, education is not a pre-packaged box that the instructor can hand out – YOU will need to put in the effort to actively engage with the material, participate in class, and work hard on the assignments/projects.
-
We will take a very formal approach to the topics, i.e., we will carefully develop the mathematical/logical underpinnings of the concepts examined throughout the course. Although this may seem dry or boring at first, it is very important for you to develop a taste for being rigorous about computer science. This type of approach will suit you well in your future career, regardless of your research area or future career plans.
-
We will learn how to read and absorb highly technical written materials. Throughout the course, the instructor will work to collect some of the most easily-digestible materials for your reference, but a big part of research is figuring out things that you don’t quite understand at first glance. You will need to exercise perseverance in reading research papers, and iterate until the pieces start falling into place.
Course Feedback
Just as you expect the instructor to grade your coursework in a fair and timely fashion, the instructor expects you to take the Mines course feedback seriously. Feedback is typically collected during the two weeks before finals week.
As an encouragement to participate in the course feedback, the instructor will monitor the overall response rate via Canvas – if the overall response rate goes above 50%, all students in the class will receive bonus points worth 50% of a homework assignment.
Your feedback is important! The instructor will read all of your comments, and use them to help improve the course/teaching in the future. Rather than simply leaving a numeric rating, please describe your rating in words – for example, a high score without any indication of what you enjoyed/gained from the class is great but not particularly informative, and a low score without any indication of what went wrong in the class will not help the instructor improve.
Please put yourself in the instructor’s shoes, and be constructive in your comments.
Accommodation
The Colorado School of Mines is committed to ensuring the full participation of all students in its programs, including students with disabilities. If you anticipate or experience any barriers to learning in this course, please feel welcome to discuss your concerns with the instructor. Students with disabilities may also wish to contact Disability Support Services (DSS) to discuss options to removing barriers in this course, including how to register and request official accommodations. Please visit their website at https://disabilities.mines.edu for contact and additional information. If you have already been approved for accommodations through DSS, please meet with the instructor at your earliest convenience to discuss your needs in this course.
Typos and Bug Fixes
Please use the Issues or Pull Request features of GitHub to bring any typos or bugs to the instructor’s attention.