Formal Methods for Verification and Synthesis of Software Systems
Lecturers
Course Description
The role of specification and verification during software system development. The advantages and disadvantages of applying formal methods.
Theory and practice during the development of software systems. Formal approaches to modelling software systems. Theoretical background: process algebras, Petri nets and temporal logic.
The difference between model checking, testing and run-time verification. Formal communication models. Practical application of specification, verification and testing languages.
Model checking tools as well as software testing tools. Testing automatization. Procedures of automata based programming for rigid and robust software development.
The application of inductive synthesis for process mining: proces discovery, process conformance testing and process repair. Aplication to business proces mining and specification mining.
Study Programmes
Learning Outcomes
- analyse the problem domain
- create usable (formal) model that describe the problem
- identify method(s) to find the solution
- analyse the model: Is model describing problem in a usable way?
- derive problem solution
- compare results with other similar approaches
- revise solution if results are not satisfactory
Forms of Teaching
Lectures
Before each lecture lecture notes and presentations are on course web page
Seminars and workshopsthe application of formal methods on rigid software development ("design-for-verification" and "correct-by-construction" systems)
Independent assignmentshomework assignments, preparation for work in laboratory
Laboratorycomplex laboratory assignments which includes: model checking tool application on selected examples, rigid software development
Grading Method
Continuous Assessment | Exam | |||||
---|---|---|---|---|---|---|
Type | Threshold | Percent of Grade | Threshold | Percent of Grade | ||
Laboratory Exercises | 0 % | 20 % | 0 % | 20 % | ||
Homeworks | 0 % | 15 % | 0 % | 15 % | ||
Seminar/Project | 0 % | 10 % | 0 % | 10 % | ||
Mid Term Exam: Written | 0 % | 30 % | 0 % | |||
Final Exam: Written | 0 % | 35 % | ||||
Exam: Written | 0 % | 65 % |
Week by Week Schedule
- Role of formal specification and analysis techniques in the software development cycle for concurrent reactive systems. Rigid and robust software development.
- Formal program and software system modeling: process algebras, Petri nets and finite discrete automaton
- Formal model driven software development: specification, testing and verification languages. Model and communicating processes semantic.
- Temporal logic, program and software system models. Behavior equivalence.
- Verification: Spin model checker and Promela language
- Verification: model checking and Petri nets
- Software model checking
- Midterm exam
- Program and software system synthesis: from verified specification to target code skeleton
- Inductive synthesis and process mining: process discovery and specification mining
- Process mining: conformance testing and process repair
- Automatized software testing with model checkers. Runtime verification
- New trends for rigid and robust software development. Conections beetwen artificial inteligence and software design.
- Project
- Final exam
Literature
Edmund M. Clarke, Orna Grumberg, Doron A. Peled (2000.), Model Checking, MIT Press
Mordechai Ben-Ari (2012.), Mathematical Logic for Computer Science, Springer Publishing Company
G. Holzman (2011.), The Spin Model Checker, Addison-Wesley Professional
Paul Ammann, Jeff Offutt (2016.), Introduction to Software Testing, Cambridge University Press
Peterson, J.L. (1981.), Petri Net Theory and the Modeling of Systems, Prentice Hall PTR
Manfred Broy et all (2005.), Model-Based Testing of Reactive Systems, Springer
Mark Utting Bruno Legeard: (2006.), Practical Model-based Testing: a Tools Approach, Morgan Kaufmann
C.A.R. Hoare (2015.), Communicating Sequential Procceses, Prentice-Hall
(.), razni članci iz časopisa i konferencijski zbornici koji će tek biti objavljeni,
Wil van der Aalst (2016.), Process Mining: Data Science in Action, Springer
For students
General
ID 222962
5 ECTS
L3 English Level
L2 e-Learning
30 Lectures
0 Seminar
0 Exercises
15 Laboratory exercises
0 Project laboratory
0 Physical education excercises
Grading System
90 Excellent
75 Very Good
60 Good
50 Sufficient