Table of Contents

Computational Logic and Software Verification

Type to search the document. Use arrow keys to navigate results.

    Table of ContentsClose

    General Infromation

    Courese Number: 343370
    Instructor: Jyun-Ao Lin
    Location: 六教 224(e)
    Time: 09:10 – 12:00, Wednesday

    Overviews

    Computational logic has been used in a wide range of application in computer science, ranging from the deductive approach to Artificial Intelligence advocated by AI’s founder John McCarthy, to proving the absence of bugs in large industrial software such as the 14th metro line in Paris, or checking difficult theorems the as the one of Feit-Thompson in the classification of finite simple groups.

    The goal of this course is to explain how logic can be used in order for modeling problems of computational or mathematical nature, and how computers can be used to achieve this.

    Recommended Prerequisites

    Some basic discrete mathematics, computer programming, algorithms, theory of computation/formal language.

    Communication

    When you need help from the course staff, please use office hours or hang around after lecture. For issues requiring privacy, please feel free to email the course instructor.

    Office Hours

    13:30–17:30 Friday

    Topics and Class Schedule

    Topics

    Propositional Logic

    Predicate Logic

    Model Checking

    Program Verification

    Class Schedule

    The current schedule is tentative and subject to change.

    Date # Lecture Support
    02/19 1 Introduction  
    02/26 2    
    03/05 3    
    03/12 4    
    03/19 5    
    03/26 6    
    04/02 7    
    04/09 8    
    04/16 9 Mid-term  
    04/23 10    
    04/30 11    
    05/07 12    
    05/14 13    
    05/21 14    
    05/28 15    
    06/04 16    
    06/11 17 Final Project Presentation  
    06/18 18 Final Project Presentation  

    Useful References

    Evalution

    Asseignments (40 %)

    Written Homework:

    The goal of the written homework is to help you refine the fundamental skills, and better understand the theoretical underpinnings, that you will need in order to do well on the labs and exams. Grading for these assignments is based on the correctness of your answer, and the presentation of your reasoning. You should strive for clarity and conciseness, while making sure to show each step of your reasoning. Categorical answers with no explanation will not even receive partial credit, but lucid explanations of your attempt to find the answer will.

    Written homework will be handed in in PDF format via teams, and should preferably be typeset in LaTeX.

    Programming Homework:

    The programming homework is designed to give you hands-on experience writing bug-free code with the help of formal verification tools. In general, we will ask you to implement some interesting functionality, such as a SAT solver or fault-tolerant communication protocol. The most important criterion with respect to grading programs is correctness.

    Programming Homework will be send in a Unix compressed archive name.tgz. Your archive must include a README file describing how to compile and run your program. It must also include a short report (2 pages max.) describing the salient parts of your code.

    Academic Integrity

    Students are expected to complete each assignment on their own, and should be able to explain all of the work that they hand in. Copying code or proof material from other students, from online sources, or from prior instances of this course is not allowed. However, you are encouraged to discuss assignments with each other at a sufficiently high level to avoid the risk of duplicating implementation or proof. Examples of this would be discussing algorithms and properties referred to in the assignment, helping other students with questions about a programming language or tool required to complete the assignment, discussing a general proof technique, or referring to an online source with useful information. Similarly, you may consult online sources, tutorials, and public libraries. If you find specifically helpful material it is critical that you (a) do not copy the code or proof, but study it as a guide and then do your own work, and (b) cite the source with your classmates' names, suitable URLs and chat prompts (if you use any generative AIs) in your solution. If you have questions about whether something might be permissible, contact the course staff before you proceed.

    Mid-terms (30 %)

    TBA

    Final Project (30 %)

    TBA

    Attendance (0 %)

    All students are expected to attend the lectures. However I appreciate that different people learn differently. Thus the attendance won't be recorded.

    Some tools you may be interested in

    OCaml

    Acknowledgement and Credits

    The course is designed based on the Introduction to Computational Logic by Bow-Yaw Wang. I thank him for providing his teaching materials including source code of slides.

    Created: 2025-02-06 Thu 20:47

    Validate