Analyzing Program Termination and Complexity Automatically with AProVE
Jürgen Giesl,Cornelius Aschermann,Marc Brockschmidt,Fabian Emmes,Florian Frohn,Carsten Fuhs,Jera Hensel,Carsten Otto,Martin Plücker,Peter Schneider-Kamp,Thomas Ströder,Stephanie Swiderski,René Thiemann
DOI: https://doi.org/10.1007/s10817-016-9388-y
2016-10-21
Journal of Automated Reasoning
Abstract:In this system description, we present the tool AProVE for automatic termination and complexity proofs of Java, C, Haskell, Prolog, and rewrite systems. In addition to classical term rewrite systems (TRSs), AProVE also supports rewrite systems containing built-in integers (int-TRSs). To analyze programs in high-level languages, AProVE automatically converts them to (int-)TRSs. Then, a wide range of techniques is employed to prove termination and to infer complexity bounds for the resulting rewrite systems. The generated proofs can be exported to check their correctness using automatic certifiers. To use AProVE in software construction, we present a corresponding plug-in for the popular Eclipse software development environment.
computer science, artificial intelligence