Course ObjectiveLearning to use formal techniques for specification and validation of
Course ContentThis course is concerned with the specification and validation of
protocols, using formal methods. The course is based on a specification
language based on process algebra combined with abstract data types,
called mCRL. This language and its toolset can be used for the
specification of parallel, communicating processes with data. Model
checking is a method for expressing properties of concurrent finite-
state systems, which can be checked automatically. Interesting
properties of a specification are: "something bad will never happen"
(safety), and "something good will eventually happen" (liveness). In the
lab we will teach the use of a tool for automated verification of the
required properties of a specification.
Teaching Methods4 hours per week HC
2 hours per week WC/PR (mixed)
During the practicum the mCRL2 toolset will be used for the validation
of protocols discussed during lectures. This toolset is freely available
for Windows, Linux, Mac (see
Method of AssessmentWritten exam, together with a practical homework assignment. The overall
mark of the course is (H+2W)/3, where H is the mark for the homework
assignment, and W is the mark for the written exam.
LiteratureWan Fokkink, Modelling Distributed Systems, Springer 2007. An online
version of this book (2nd edition) will be available.
Target AudiencemAI, mCS, mPDCS, master of Logic
Recommended background knowledgeBasic knowledge in mathematics and propositional logic, e.g. as dealt
with in the course "Logica en Modelleren"
|Language of Tuition||English|
|Faculty||Faculty of Science|
|Course Coordinator||dr. A. Ponse|
|Examiner||prof. dr. W.J. Fokkink|
You need to register for this course yourself
Last-minute registration is available for this course.
|Teaching Methods||Seminar, Lecture, Practical|
This course is also available as: