We are hiring new doctoral researchers, student research assistants, and tutors. Apply now!
2 papers accepted at ASE 2024: BenchCloud and CoVeriTeam GUI

Research Assistant and Tutor Positions

The Software and Computational Systems Lab is constantly looking for research assistants. If you have good grades and are interested in research in the area of software verification, please consider the below positions. We offer flexible working hours, a shared workspace in our offices, and the chance to contribute to novel research in multiple areas of software verification.

Picture of Thomas Lemberger

To apply and to get more information, contact Thomas Lemberger via mail or Zulip.

Doctoral Researcher

If you have a Master degree in computer science or a related field and want to pursue a PhD, employment as a doctoral researcher allows you to do research and academic teaching full-time. We offer a strong academic environment and a comprehensive qualification program to our doctoral researchers. All positions are a full-time employment at TV-L E13. Our office space is in Munich, Oettingenstr. 67, with the opportunity for hybrid work according to prior agreement.

🔬 Doctoral Researcher in Open Position

We are currently looking for a doctoral researcher for an open position at our chair. Feel free to reach out to us to get more information and to apply.

See our research and publications for potential research directions.

🔬 Doctoral Researcher on Cooperative Software Verification

We are currently looking for a doctoral researcher in our DFG project on Cooperative Software Verification. Feel free to reach out to us to get more information and to apply.

The aim of software verification is the assurance of high-quality software, in particular absence of unintended and erroneous behavior. Today, a range of different tools provide software-analysis techniques, covering the whole area from static and dynamic analysis to model checking. All of these techniques have their individual strengths and weaknesses. The goal of this research project is the enhancement of precision and performance in software verification by cooperation between different verification tools and techniques. Cooperative software verification requires (1) options for exchange of information between verification tools and sound usage of such information and (2) techniques for the decomposition of verification tasks to solve them in parallel and by different tools. Based on the results of the first project phase, the project will in particular investigate techniques for enhancing efficiency and effectiveness of cooperative verification as well as improving its usability. The focus of the project remains on the combined development of a methodology and theory of cooperation. All approaches developed in this project will be thoroughly evaluated using experiments on large benchmark sets, and the project will also contribute new benchmark sets to the community.

🔬 Doctoral Researcher on Continuous Verification of CYber-Physical Systems (ConVeY)

ConVeY is a joint DFG research training group between TU Munich and LMU Munich. The next application phase will open in February 2025, for start of employment in July 2025. Feel free to reach out to us to get more information!

Student Research Assistant

Our job positions target students with a place of residence (Wohnort) in Germany. If this does not apply please still contact us - we will organize a student exchange or internship.

🔬 BenchCloud: A Cloud Platform for Benchmarking
We are currently looking for several student research assistants for our cloud solution for distributed execution of verification benchmarks. The BenchCloud is the fundamental component for running international scientific competitions (SV-COMP, Test-Comp), and large-scale experiments for publications at our chair. In this context, the BenchCloud dynamically manages the reliable distribution of benchmarks to our chair-owned cluster. In addition, computing resources are also made available via a web frontend for experiments in the context of student work at our chair. If you have found fun in Java programming in the SEP and would like to expand your knowledge by working on a real project, this is the right place for you. The BenchCloud has been actively developed for several years and is in productive use on a daily basis (e.g., over 50,000 benchmarks on quiet days alone).

Required Skills:
  • Java programming
  • Basic Linux knowledge

Useful knowledge/areas of interest:
  • Software Verification
  • Web technologies
  • Parallel programming

The employment is as a student assistant (HiWi), whereby the number of hours per week can be flexibly adjusted (but should not be less than 5 hours per week). The working hours can be arranged flexibly. A long-term cooperation over several semesters is generally desired from our side. If you are interested or if any questions are left, please contact us directly via Zulip or mail.

Languages: German and English

Supervisors: Marek Jankola and Daniel Baier
🔬 CPAchecker: The Configurable Software-Verification Platform
We are currently looking for student research assistants at the chair. We are mainly concerned with software safety. The internationally awarded framework CPAchecker supports a variety of analyses and approaches for the verification of C programs. CPAchecker offers several thousand different configuration options and allows to easily integrate new ideas. Basically, it verifies a given C program with respect to a specification, such as "the reach_error function is never called", and tells the user if there are paths through the program that violate that specification. CPAchecker annually participates very successfully in SV-COMP, the largest international competition for software verifiers. If you have found fun in Java programming and want to expand your knowledge in the world of formal verification by working on a real project, this is the right place for you. CPAchecker has been under active development for several years and is used, among other things, to verify parts of the Linux kernel.

Required Skills:
  • Java programming
  • Basic Linux knowledge
  • First experiences with formal methods in software verification

Useful knowledge/areas of interest:
  • Software Verification
  • Interest in research and experimenting

The employment is as a student assistant (HiWi), whereby the number of hours per week can be flexibly adjusted (but should not be less than 5 hours per week). The working hours can be arranged flexibly. A long-term cooperation over several semesters is generally desired from our side. If you are interested or if any questions are left, please contact me directly via Zulip or mail.

Languages: German and English

Supervisor: Thomas Lemberger
🔬 Development of Tools and Microservices for Code Analysis

We aim to apply our achievements in software-verification research to various real-world applications. In this role, you will be part of a small team that designs and develops tools to make code analysis more accessible and better scalable for everday software development. A focus is on increasing the usability and the speed. You will have the opportunity to work on projects like IDE plugins, micro-service infrastructures, and integrations in CI pipelines.

This job is for you, if:

  • you proud yourself with high-quality code
  • you are enthusiastic about developer tooling
  • you are interested in the field of compilers and software analysis (parsers, code transformations, static analysis)
  • you can manage yourself well

Required Skills:

  • Programming experience in Java, Kotlin, or C++
  • Basic knowledge in code analysis and/or software verification (example: lectures on formal specification and verification).

Employment: The employment is as a student assistant (HiWi) with 7 to 12 hours per week. The day and time of work can be arranged flexibly in certain bounds. A long-term cooperation over several semesters is generally desired from our side.

Languages: German and English

Supervisor: Thomas Lemberger
Please contact us via Zulip or mail. We're always available for questions.
🔬 Bridging Hardware and Software Analysis

Background: Computational systems consisting of both hardware and software components are used everywhere in modern society. The correctness assurance of theses systems is thus an indispensable research area. In this project, we aim at utilizing the joint knowledge of both hardware and software verification communities by

  • optimizing the applicability of software analyzers to hardware designs,
  • constructing a framework that facilitates the utilization of off-the-shelf hardware analyzers for software, and
  • combining strengths of hardware and software verification algorithms to solve practical problems.

Job description: We are looking for students that can assist us in the following tasks.

Requirements:

  • Programming experience in C/C++ and Python
  • Basic Linux skills
  • Knowledge in formal verification and testing

Employment: The employment is as a student assistant (HiWi) with 7 to 12 hours per week. The day and time of work can be arranged flexibly in certain bounds. A long-term cooperation over several semesters is generally desired from our side.

Languages: English

Supervisors: Po-Chun Chien and Nian-Ze Lee

🔬 Formalization of cyber-physical systems logics in Isabelle/HOL

When computers control real-world systems (e.g. brake assistant systems in modern cars) their correctness has impact on human health and life. Said casually the failure of heavy machines could cause harm beyond the mere malfunction of, e.g., a printer or smartphone. To achieve high reliability, logical methods for cyber-physical systems strive for a formal proof of their correct behavior. However, the logical methods do only ensure correctness if they are in turn proven correct themselves.

We are searching for a student research assistant to work on the formalization of existing correctness proofs of logical methods for the analysis of cyber-physical systems in the proof assistant Isabelle/HOL. You will have the opportunity to participate in active research in the area of formal methods and logics in computer science.

This job is for you, if:

  • mathematical problems don't scare you but arouse your curiosity
  • you are enthusiastic about digging into challenging problems
  • you are interested in logics and theorem-proving
  • you can manage yourself well

Required Skills:

  • Experience (e.g. from a lecture) in interactive theorem proving (e.g. with Isabelle/HOL, Coq, or Lean)
  • Knowledgeable in logics (e.g. Hoare-logic)
  • Ability to understand and play with mathematical proofs

Employment: The employment is as a student assistant (HiWi) with 7 to 12 hours per week. The day and time of work can be arranged flexibly in certain bounds. A long-term cooperation over several semesters is generally desired from our side.

Languages: German and English

Supervisor: Marvin Brieger
Please contact us via Zulip or mail. We're always available for questions.
🔬 Exploring Synergies between Machine Learning and Formal Methods

Background: Machine learning (ML) has become a popular tool for solving complex problems in various domains. In particular there are some synergies between ML and formal methods. Not only can ML methods be used to improve the performance of formal methods, but formal methods can also be used to improve the reliability and explainability of ML models. We are searching for a student who would be interested in exploring synergies between ML and formal methods in at least one of the following directions:

  • Using ML to improve the performance of formal methods
  • Using formal methods to improve the reliability of ML models

Job description: We are looking for students that can assist us in one or more of the following tasks:

  • Use generative AI to provide information to formal method tools, like Code2Inv
  • Finding invariants from program executions using ML
  • Use generative AI and formal methods to automatically generate function contracts in ACSL
  • Use formal methods to verify the reliability of ML models
  • Discover rules underlying how an ML model makes decisions using formal methods
  • ... and much more!

Requirements:

  • Programming experience in Python
  • Basic Linux skills
  • Knowledge in formal verification and testing
  • Knowledge in machine learning

Employment: The employment is as a student assistant (HiWi) with 7 to 20 hours per week. The day and time of work can be arranged flexibly in certain bounds. A long-term cooperation over several semesters is generally desired from our side.

Languages: German and English

Supervisor: Marian Lingsch-Rosenfeld

🔬 Exploring Interactions between Model Checkers, Deductive Verifiers and Interactive Theorem Provers

Background: Formal Methods are a set of techniques to verify the correctness of software and hardware systems. Some popular methods are model checking, deductive verification, and interactive theorem proving. Each of these methods has its own strengths and weaknesses. The goal is to explore how these methods can be combined to leverage their strengths and mitigate their weaknesses.

Job description: We are looking for students that can assist us in one or more of the following tasks:

  • Translate the results of a model checker into a proof for a deductive verifier
  • Improve the information output of a model checker to be more useful for a deductive verifier
  • Translate the results of a model checker into a proof for an interactive theorem prover
  • Use the proof of an interactive theorem prover to obtain hints for a model checker
  • ... and much more!

Requirements:

  • Programming experience in Python or Java
  • Basic Linux skills
  • Basic knowledge in format methods

Employment: The employment is as a student assistant (HiWi) with 7 to 20 hours per week. The day and time of work can be arranged flexibly in certain bounds. A long-term cooperation over several semesters is generally desired from our side.

Languages:German and English

Supervisor: Marian Lingsch-Rosenfeld

Tutorship

Wir suchen für das Wintersemester 2024/2025 Tutorinnen und Tutoren für die unten gelisteten Veranstaltungen. Bei Interesse melde dich unverbindlich bei Thomas Lemberger via Mail or Zulip. Wir freuen uns auf deine Bewerbung!


📝 Einführung in die Informatik (mit Python)
Als Tutorin oder Tutor für die Einführungsveranstaltung in die Informatik (InfoEinf) für Nebenfächler hältst du wöchentlich eine zweistündige Übung für die Studentinnen und Studenten ab. Außerdem unterstützt du uns beim Korrigieren der Abgaben und bei der Organisation der Klausuren. In einem ebenfalls zweistündigen und wöchentlich stattfindeten Tutorinnentreffen lernst du die anderen Tutorinnen und Tutoren kennen und wir tauschen uns über die Korrekturen und aufkommende Fragen aus. Wenn Du gut in Python bist und dein Wissen gerne mit anderen Studenten teilst, würden wir uns freuen, Dich in unserem Team willkommen zu heißen.

Anmerkung: Die Veranstaltung "Einführung in die Informatik" wird ab dem WS 2022/23 von Java zu Python als primäre Programmiersprache wechseln.

Wir können Dir einen der folgenden Verträge anbieten:
  • Bei einer Gruppe: 9h / Woche
  • Bei zwei Gruppen: 13h / Woche (Bei zwei Gruppen sind es in Summe etwas weniger Stunden, da das Tutorentreffen ja nur einmal anfällt.)

Vertragsbeginn: 01.10.2024 oder 17.10.2024, jeweils bis 14.04.2025

Sprache: Deutsch

Supervisor: Philipp Wendler
📝 Softwaretechnik
Als Tutorin oder Tutor für die Veranstaltung Softwaretechnik hältst du wöchentlich eine zweistündige Übung für die Studentinnen und Studenten ab. Außerdem unterstützt du uns beim Korrigieren der Abgaben und bei der Organisation der Klausuren. Vereinzelt trifft sich das Tutorinnen-Team mit den Dozenten, um offene Fragen zu klären und um euch die Möglichkeit zum Austausch innerhalb des Teams zu geben. Wenn du selbst gut in Softwaretechnik abgeschnitten hast und dein Wissen gerne mit anderen Studentinnen und Studenten teilen möchtest, würden wir uns freuen, dich in unserem Team willkommen zu heißen.

Die Vertragsdauer beträgt 5 Monate (17.10.2024-15.03.2025) mit folgenden möglichen Arbeitszeiten:
  • 9h / Woche für Aufgabenkorrektur, ohne dass du eine Übung hältst.
  • 13h / Woche für Aufgabenkorrektur und eine wöchentliche, zweistündige Übung für Studentinnen und Studenten.
  • 19h / Woche für Aufgabenkorrektur und zwei wöchentliche, zweistündge Übungen für Studentinnen und Studenten.

Sprache: Deutsch

Supervisor: Henrik Wachowitz
📝 Compiler Construction
As a tutor for the course "Compiler Construction," you will prepare a weekly two-hour exercise session for the students. Additionally, you will assist us with grading assignments, organizing exams, and preparing teaching materials. You will also implement the framework for the practical part of the course (Java and/or Python). If you have performed well in "Formal Languages and Complexity" and "Formal Specification and Verification", are capable of programming in Java and/or Python, and are eager to share your knowledge with other students, we would be happy to welcome you to our team.

The contract duration is 7 months (August to March 15, 2025) with 13 hours per week for assignment grading (including exams), the preparation of the weekly two-hour exercise session for students, the preparation of the practical part of the course, and the preparation of teaching materials until October.

Language: English

Supervisors: Matthias Kettl and Daniel Baier