Synthesizing Modular Invariants for Synchronous Code
Abstract
In this paper, we explore different techniques to synthesize modular invariants for synchronous code encoded as Horn clauses. Modular invariants are a set of formulas that characterizes the validity of predicates. They are very useful for different aspects of analysis, synthesis, testing and program transformation. We describe two techniques to generate modular invariants for code written in the synchronous dataflow language Lustre. The first technique directly encodes the synchronous code in a modular fashion. While in the second technique, we synthesize modular invariants starting from a monolithic invariant. Both techniques, take advantage of analysis techniques based on property-directed reachability. We also describe a technique to minimize the synthesized invariants.
- Publication:
-
arXiv e-prints
- Pub Date:
- December 2014
- DOI:
- 10.48550/arXiv.1412.1152
- arXiv:
- arXiv:1412.1152
- Bibcode:
- 2014arXiv1412.1152G
- Keywords:
-
- Computer Science - Logic in Computer Science
- E-Print:
- In Proceedings HCVS 2014, arXiv:1412.0825