Skip to content

Sleep Set POR in Trace Abstraction Refinement

maul.esel edited this page Oct 28, 2020 · 11 revisions

Project Goal

Integrate Trace Abstraction Refinement (TAR) with a form of Partial Order Reduction (POR), namely Sleep Sets. Thereby we aim to improve the verification time for concurrent programs. We formulate the integration, prove soundness and completeness, and implement it in Ultimate Automizer's automata-based analysis of concurrent programs.

Resources

Work Packages

  • Related Work & Background
  • Implementation & Evaluation of Godefroid's sleep set algorithm (with delay sets)
  • Definition, Proof, Implementation & Evaluation of a modified sleep set construction (no delay sets)
  • Basic integration of POR and TAR: devise, prove, implement
  • Implement lazy construction of program automaton
  • Store interpolants & use for improved reduction (conditional POR)
  • Optimized integration: devise, implement, prove
  • Finalize thesis

Current Tasks

  • read background and related work, get a better understanding of underlying theory
    • read & understand section 6 of Azadeh's paper
  • begin writing corresponding chapters (definitions)
    • POR background
  • implementation: Godefroid's sleep set algorithm as construction of a new automaton; use NestedWordAutomaton; see CFG2NestedWordAutomaton for an example of adding states and edges

Ultimate

Sleep Set Reduction

Project Library-Automata, package de.uni_freiburg.informatik.ultimate.automata.partialorder

  • IIndependenceRelation (given as parameter)
  • INwaOutgoingLetterAndTransitionProvider<LETTER, STATE> represents an automaton
  • NestedWordAutomataUtils.isFiniteAutomaton to test if automaton does not contain call or return edges
  • consider form of implementation: lazy automata construction, eager automata construction, emptiness check?
Clone this wiki locally