Parisian Master of Research in Computer Science
Master Parisien de Recherche en Informatique (MPRI)

Basics of Verification (60h, 6 ECTS)

In charge: Paul Gastin (LSV, ENS Cachan).

Lecturers

Paul Gastin (lectures), Stefan Schwoon (lectures), Sylvain Schmitz (exercises), Daniel Stan (exercises).

Research internships

Language

The default language is French.
But the lectures may be given in English if attended by non French-speaking students.

Motivations and main objectives

Nowadays, it is of the highest importance to use formal methods in order to increase the reliability of critical systems.
In this introductory course on verification of discrete systems, we concentrate in particular on _model checking_ techniques.
We will describe various models used to define systems: transition systems enriched with various data structures (variables, channels, ...) and which can be composed with several synchronization mechanisms.
We will also cover specification languages that are used to express properties to be checked on our systems: temporal logics (linear or branching), first-order or monadic second-order logic, ...
We will study expressivity, decidability and complexity properties of our models and specification languages.
We will also cover abstraction/refinement techniques and (bi)simulation relations used to relate various abstraction levels.
Algorithmic aspects of model checking will be investigated and we will stress efficient techniques such as binary decision diagrams (BDDs) or bounded model checking.

Detailed description and Lecture notes

The full lecture notes of the first half of the semester are available here.

Date Type Topics covered
2013/09/18 Lecture Introduction
Models: transition systems, variables, synchronized products, Rendez-vous, shared variables, atomicity, asynchronous communication with channels
2013/09/25 Exercises Mutual exclusion algorithms, Handshake with data exchange, Needham-Schroeder protocol, Channel systems
2013/10/02 Lecture Specification: introduction, linear vs branching specifications, FO and TL: definitions and examples, linear model checking, branching specifications, MSO, CTL*
2013/10/09 Exercises Temporal Logics: LTL, CTL*, CTL, CTL+
2013/10/16 Lecture CTL, PTIME model checking algorithm for CTL and for fair-CTL
Büchi automata
2013/10/23 Exercises CTL model checking and Büchi automata
2013/10/30 Lecture Büchi transducers: definitions, examples and main properties
Construction of a Büchi transducer from an LTL formula
Satisfiability and Model checking for LTL: decidability and complexity
PSPACE model checking algorithm for CTL*
2013/11/06 Exercises LTL model checking and complexity
2013/11/13 Lecture Temporal logics: Expressivity, Ehrenfeucht-Fraïssé games, Separation
2013/11/20 Exercises EF Games, Separation
2013/12/11 Lecture Binary Decision Diagrams
2013/12/18 Exercises BBDs
2014/01/08 Lecture Petri Nets
2014/01/15 Exercises Petri nets, Coverability
2014/01/22 Lecture Petri Nets
2014/01/28 Exercises Unfoldings, Vector Addition Systems
2014/02/05 Lecture Partial-Order Reduction
2014/02/12 Exercises Partial-Order Reduction
2014/02/19 Lecture Abstraction and Refinement

See also previous year.

Exams

There will be 2 written exams (E1 and E2) and 2 home assignments (H1 and H2).
The final mark will be (H1+2E1+H2+2E2)/6.

The examination questions will be in French and/or in English depending on the requests.
Students may write their answers in French or in English.

Date Type Topics and comments
2013/10/30 H1: Dynamic Logics To hand in on November 13th.
Don't be late.
2013/11/27 E1: midterm exam Exam on the first half of the course.
2014/01/28 H2: Petri Nets Coverability To hand in on February 12th.
Don't be late.
2014/03/?? E2 Exam on the second half of the course – March 12

Prerequisites

Finite Automata.

Related courses

  • 1-2: Automates avancés et applications
  • 1-18: Automates d'arbres et applications
  • 2-8: Fondements pour la vérification des systèmes temps-réel
  • 2-9: Vérification de systèmes dynamiques et paramétrés
  • 2-16: Modélisation par automates finis
  • 2-20-1: Jeux pour la théorie des automates, la vérification et l'internet.

Bibliography

  • Principles of Model Checking. Christel Baier and Joost-Pieter Katoen. MIT Press, 2008.
  • Systems and Software Verification. Model-Checking Techniques and Tools. B. Bérard, M. Bidoit, A. Finkel, F. Laroussinie, A. Petit, L. Petrucci, Ph. Schnoebelen. Springer, 2001.
    Also available in french: Vérification de logiciels : Techniques et outils du model checking. Coordonné par Ph. Schnoebelen. Vuibert, 1999.
  • Model Checking. E.M. Clarke, O. Grumberg, D. Peled. MIT Press, 1999.
  • Temporal Verification of Reactive Systems - Safety. Zohar Manna and Amir Pnueli. Springer-Verlag, 1995.
  • The Temporal Logic of Reactive and Concurrent Systems - Specification. Zohar Manna and Amir Pnueli. Springer-Verlag, 1992.

Teachers

Paul GastinPRENS CachanLSV
Sylvain SchmitzMCENS CachanLSV
Stefan SchwoonMCENS CachanLSV
Daniel StanPhDENS CachanLSV

Previous Years

 
Universités partenaires Université Paris-Diderot
Université Paris-Saclay
ENS Cachan École polytechnique Télécom ParisTech
ENS
Établissements associés Université Pierre-et-Marie-Curie CNRS INRIA CEA