185.291 Formal Methods in Computer Science
This course is in all assigned curricula part of the STEOP.
This course is in at least 1 assigned curriculum part of the STEOP.

2021W, VU, 4.0h, 6.0EC
TUWEL

Properties

  • Semester hours: 4.0
  • Credits: 6.0
  • Type: VU Lecture and Exercise
  • Format: Online

Learning outcomes

After successful completion of the course, students are able to...

  • make use of basic methods of computability theory in order to identify, for instance, undecidable problems
  • apply formal methods from complexity theory to new problems in order to prove their tractability or NP-hardness,
  • represent problems in the area of formal methods as satisfiability problems, to solve these problems with a SAT solver, and to formally argue the correctness of all involved techniques and reductions,
  • formally establish partial and total correctness of software systems, by using  deductive verification approaches based on Hoare logic and predicate transformers. Students will also be able to formulate program semantics and prove program properties algorithmically,
  • understand and apply the basic techniques of model checking: encoding specifications in temporal logic, reasoning about temporal logic formulae, model checking of temporal logic formulae on Kripke structures, using state space reduction techniques, and applying bounded model checking for verification tasks.

Subject of course

Introduction to complexity theory: problem reductions, P versus NP, undecidability; SAT solving and its applications in computer science; introduction to the formal semantics of programming languages; formal verification of programs; model checking and its applications in hard- and software verification.

Teaching methods

The course is organized in four blocks. The course (and thus each block) consists of a lecture and a consolidation part.

The topics of the course are presented during the lectures.

The consolidation part includes two additional classes per block for discussing examples and their solutions. Students receive an exercise sheet for each block. The submissions will be corrected and returned to the students

Three additional classes will be offered to recall some basic principles of mathematical proofs.

Mode of examination

Written

Additional information

Ects breakdown

  2 h introduction (first meeting)
60 h lecture (20 dates à 2h + 1h preparation)
40 h exercise sheets (4 sheets, 10 exercises/sheet, 1h/exercise)
16 h discussion of exercises (8 dates à 2h)
 30 h preparation for written exam
2 h written exam
-----------------------------------------------------------
150 h = 6 Ects

Lecturers

Institute

Course dates

DayTimeDateLocationDescription
Wed12:00 - 13:0006.10.2021 Kick-Off (online - see TUWEL)
Mon13:00 - 15:0011.10.2021 - 24.01.2022 Lecture (online)
Wed12:00 - 14:0013.10.2021 - 26.01.2022 Lecture (online)
Formal Methods in Computer Science - Single appointments
DayDateTimeLocationDescription
Wed06.10.202112:00 - 13:00 Kick-Off (online - see TUWEL)
Mon11.10.202113:00 - 15:00 Lecture (online)
Wed13.10.202112:00 - 14:00 Lecture (online)
Mon18.10.202113:00 - 15:00 Lecture (online)
Wed20.10.202112:00 - 14:00 Lecture (online)
Mon25.10.202113:00 - 15:00 Lecture (online)
Wed27.10.202112:00 - 14:00 Lecture (online)
Wed03.11.202112:00 - 14:00 Lecture (online)
Mon08.11.202113:00 - 15:00 Lecture (online)
Wed10.11.202112:00 - 14:00 Lecture (online)
Mon15.11.202113:00 - 15:00 Lecture (online)
Wed17.11.202112:00 - 14:00 Lecture (online)
Mon22.11.202113:00 - 15:00 Lecture (online)
Wed24.11.202112:00 - 14:00 Lecture (online)
Mon29.11.202113:00 - 15:00 Lecture (online)
Wed01.12.202112:00 - 14:00 Lecture (online)
Mon06.12.202113:00 - 15:00 Lecture (online)
Mon13.12.202113:00 - 15:00 Lecture (online)
Wed15.12.202112:00 - 14:00 Lecture (online)
Mon10.01.202213:00 - 15:00 Lecture (online)

Examination modalities

The evaluation is based on a written exam.

Exams

DayTimeDateRoomMode of examinationApplication timeApplication modeExam
Fri13:00 - 16:0017.05.2024Informatikhörsaal - ARCH-INF written08.04.2024 09:00 - 10.05.2024 23:59TISSExam 3 WS
Wed09:00 - 12:0026.06.2024Informatikhörsaal - ARCH-INF written03.06.2024 09:00 - 24.06.2024 23:59TISSExam 4 WS

Course registration

Begin End Deregistration end
13.09.2021 08:00 18.10.2021 08:00 18.10.2021 08:00

Curricula

Literature

For slides and other material see the TUWEL course.

Previous knowledge

Basic knowledge in mathematical logic and algorithms are required (to the extent taught in “Theoretische Informatik und Logik” and “Algorithmen und Datenstrukturen”).

Language

if required in English