Universe Types for KeY
Typ: | BA |
---|---|
Datum: | 2025-03-07 |
Betreuer: |
Wolfram Pfeifer Mattias Ulbrich |
Aushang: |
Background
Universe Types
Ownership type systems are a technique to enforce a hierarchical topology of the objects in programming. In recent years, this technique got a revival driven by the popularity of Rust.
More sophisticated ownership type systems, such as Universe types, can furthermore be used to ensure encapsulation by restricting certain references to only be used for read access.
KeY
KeY is a is a formal verification tool for Java, using symbolic execution and deductive reasoning in a dynamic logic with sequent calculus rules. KeY can be used for verifying that a Java programs adheres to a formal specifications written in the Java Modeling Language (JML).
Your Task
The goal is to develop a technique and a workflow to exploit ownership types in the KeY system. The idea is to integrate an existing type checker built with the checker framework.
Theoretical part: | Practical part: |
---|---|
- Adapt calculus rules of KeY | - Make the existing ownership checker usable |
- Implement the adapted rules | |
- Collect and prepare concrete examples |
Your Profile
You should have a background in formal methods (e.g., from relevant KIT lectures).