2022-2024
Lead Software Engineer / Software Architect
Workforce Management, INFORM GmbH
Having convinced the company of the need to evolve the fundamental technology, which revolves around a proprietary Datalog DSL, I led the endeavour in a skunkworks-style R&D team created for this purpose.
The work involved classic language design & implementation topics, such as the incremental replacement of misguided language concepts without breaking the existing huge code base, and tool development to automate the error-prone workflows of developers and consultants using the language.
2020 – 2022
Software Engineer
Workforce Management, INFORM GmbH
I was part of the core team of developers responsible for expressing customer-independent, fundamental concepts of the business domain in a JVM-embedded, proprietary Datalog DSL.
The resulting “model” contained the logic of WorkforcePlus, and I was recruited help managing its increasing complexity.
My analysis uncovered concrete deficiencies and misapprehensions in the home-made logic programming paradigm as the root cause.
Thus, my main responsibilities were (re-)engineering of the most problematic business domain concepts at that time, and the introduction of modelling language constructs needed to enable more principled modelling.
2014 – 2020
Research Associate
Informatik 11 – Embedded Software, RWTH Aachen University
Taught formal methods and worked on Arcade.PLC, a platform for verification of software for industrial controllers, featuring model checking procedures and static analyses.
The work on this project involved abstracting the concrete program semantics to avoid exhaustive exploration of the program’s state space, and formalising & exploiting peculiarities of both the properties of interest and the domain.
2014
Teaching Assistant
Informatik 2 – Theory of Hybrid Systems, RWTH Aachen University
Assisted students in “Data Structures and Algorithms”.
2013
Research Assistant
Informatik 2 – Software Modeling and Verification, RWTH Aachen University
Worked on the compiler for the SLIM language in the HASDEL research project with the European Space Agency.
2012
Research Assistant
Informatik 11 – Embedded Software, RWTH Aachen University
Developed static analyses and visualisations of signal-flow in Matlab/Simulink in a research project with Daimler AG.
2011
Teaching Assistant
Lehr- und Forschungsgebiet Informatik 2 – Programming Languages and Verification, RWTH Aachen University
Assisted students in “Programming Concepts”.
2011
Teaching Assistant
Informatik 7 – Logic and Theory of Discrete Systems, RWTH Aachen University
Assisted students in “Formal Systems, Automata, Processes”.
2010
Teaching Assistant
Informatik 12 – Hochleistungsrechnen, RWTH Aachen University
Assisted students in “Programming Concepts”.
2008 – 2009
Compulsory Social Service
Evangelische Kirchengemeinde Düsseldorf-Eller, Düsseldorf
2005 – 2007
Certified Youth Leader
CVJM Schwelm e.V.
Joint lead of YMCA-based youth work.
2022 – 2023
Extending Datalog by Rank Operations
Bachelor’s Thesis (M. Hestermann)
Original title is “Erweiterung von Datalog um Berechnung von Rängen”
2018 – 2019
Viability of BDDs in Property Directed Reachability
Master’s Thesis (T. Henn)
2018 – 2019
Abstraction Refinement in Incremental Cycle-bounded Model Checking
Master’s Thesis (L. Oss)
2017
A Unifying Formalism for PDR-based Software Verification
Master’s Thesis (T. Armborst)
2016 – 2017
Cycle-bounded Model Checking of Reactive Programs
Master’s Thesis (D. Hamm)
2015
IC3-based Model Checking for PLC Programs
Master’s Thesis (M. Völker)
2015
Efficient Encoding of PLC Programs for nuXmv
Bachelor’s Thesis (M. Grochowski)
2015 – 2019
Formal and semi-formal Methods for Embedded Software (Seminar)
Informatik 11 – Embedded Software, RWTH Aachen University
Taught scientific writing and giving a talk on the basis of recent publications in the formal methods community.
2015 – 2019
Formal Methods for Logic Control Software (Lecture & Exercises)
Informatik 11 – Embedded Software, RWTH Aachen University
Proposed the lecture and was reponsible for its design and all related materials.
The lecture covers state-of-the-art techniques in static analysis and model checking of logic control software.
2014 – 2021
PhD in Computer Science
Informatik 11 – Embedded Software, RWTH Aachen University
During this time I worked on formal verification of control software from the automation domain and graduated summa cum laude.
In my thesis “Symbolic Methods for Formal Verification of Industrial Control Software” I leverage SMT solving and abstract interpretation to develop fully-automated procedures for proving a program’s compliance with various specifications that are relevant or unique to this domain.
2012 – 2014
MSc in Computer Science
Informatik 2 – Software Modeling and Verification, RWTH Aachen University
I picked electrical engineering as minor subject and graduated with distinction.
My thesis “Accelerating Predicate Abstraction for Probabilistic Automata” proposes a fully symbolic approach to probabilistic reachability checking for Markov decision processes.
The results are implemented in the Storm model checker.
2009 – 2012
BSc in Computer Science
Informatik 11 – Embedded Software, RWTH Aachen University
My thesis “Modular and Boolean Abstraction of PLC-Programs” implements counterexample-guided abstraction refinement of procedures and control flow for PLC software model checking in the Arcade.PLC tool.
1999 – 2008
Abitur
Märkisches Gymnasium Schwelm
Being enthusiastic about game programming, and the school not teaching anything related to computers, I brought a voluntary course into being where I taught programming to like-minded.
2018
Verification Technology, Systems & Applications
UniGR Summer School
Applied for this edition to learn about both deductive verification and what to look out for when implementing BMC for LLVM IR.
2017
Logical Methods for Safety and Security of Software Systems
Marktoberdorf Summer School
Attended the summer school for all things formal.
I applied for this edition since it had a particularly strong lineup of lecturers in the domain of software verification.
DEDS 2019
Leveraging Horn Clause Solving for Compositional Verification of PLC Software
Dimitri Bohlender, Stefan Kowalewski
RE 2019
Explainability as a Non-Functional Requirement
Maximilian Alexander Köhl, Dimitri Bohlender, Kevin Baum, Markus Langer, Daniel Oster, Timo Speith
IFM 2018
Design and Verification of Restart-robust Industrial Control Software
Dimitri Bohlender, Stefan Kowalewski
WODES 2018
Compositional Verification of PLC Software using Horn Clauses and Mode Abstraction
Dimitri Bohlender, Stefan Kowalewski
SAC 2018
Cycle-bounded Model Checking of PLC Software via Dynamic Large-Block Encoding
Dimitri Bohlender, Daniel Hamm, Stefan Kowalewski
ETFA 2017
A Priori Test Coverage Estimation for Automated Production Systems: Using Generated Behavior Models for Coverage Calculation
Sebastian Ulewicz, Birgit Vogel-Heuser, Hendrik Simon, Dimitri Bohlender, Mathias Obster, Stefan Kowalewski
WODES 2016
Concolic Test Generation for PLC Programs using Coverage Metrics
Dimitri Bohlender, Hendrik Simon, Nico Friedrich, Stefan Kowalewski, Stefan Hauck-Stattelmann
MBMV 2016
Symbolic Verification of PLC Safety-Applications based on PLCopen Automata
Dimitri Bohlender, Hendrik Simon, Stefan Kowalewski
ISoLA 2014
A Review of Statistical Model Checking Pitfalls on Real-Time Stochastic Models
Dimitri Bohlender, Harold Bruintjes, Sebastian Junges, Jens Katelaan, Viet Yen Nguyen, Thomas Noll
DCDS 2013
Boolean and Modular Abstractions for Programmable Logic Controllers
Sebastian Biallas, Dimitri Bohlender, Stefan Kowalewski