Thu 24 Jun 2021 21:20 - 21:25 at PLDI-A - Talks 3A: Analysis and Synthesis
Determining whether a given program terminates is the quintessential undecidable problem. Algorithms for termination analysis may be classified into two groups: (1) algorithms with strong behavioral guarantees that work in limited circumstances (e.g., complete synthesis of linear ranking functions for polyhedral loops), and (2) algorithms that are widely applicable, but have weak behavioral guarantees (e.g., {\sc Terminator}). This paper investigates the space in between: \textit{how can we design practical termination analyzers with useful behavioral guarantees?}
This paper presents a termination analysis that is both \textit{compositional} (the result of analyzing a composite program is a function of the analysis results of its components) and \textit{monotone} (``more information into the analysis yields more information out''). The paper has two key contributions. The first is an extension of Tarjan's method for solving path problems in graphs to solve \textit{infinite} path problems. This provides a foundation upon which to build compositional termination analyses. The second is a collection of monotone conditional termination analyses based on this framework. We demonstrate that our tool ComPACT (Compositional and Predictable Analysis for Conditional Termination) is competitive with state-of-the-art termination tools while providing stronger behavioral guarantees.