Multi-dimensional rankings, program termination, and complexity bounds of flowchart programs

  • Authors:
  • Christophe Alias;Alain Darte;Paul Feautrier;Laure Gonnord

  • Affiliations:
  • LIP, Lyon, France and UMR, CNRS, ENS Lyon, UCB Lyon, Inria;LIP, Lyon, France and UMR, CNRS, ENS Lyon, UCB Lyon, Inria;LIP, Lyon, France and UMR, CNRS, ENS Lyon, UCB Lyon, Inria;LIFL, UMR CNRS, USTL, INRIA Lille, Villeneuve d'Ascq, France

  • Venue:
  • SAS'10 Proceedings of the 17th international conference on Static analysis
  • Year:
  • 2010

Quantified Score

Hi-index 0.00

Visualization

Abstract

Proving the termination of a flowchart program can be done by exhibiting a ranking function, i.e., a function from the program states to a well-founded set, which strictly decreases at each program step. A standard method to automatically generate such a function is to compute invariants for each program point and to search for a ranking in a restricted class of functions that can be handled with linear programming techniques. Previous algorithms based on affine rankings either are applicable only to simple loops (i.e., single-node flowcharts) and rely on enumeration, or are not complete in the sense that they are not guaranteed to find a ranking in the class of functions they consider, if one exists. Our first contribution is to propose an efficient algorithm to compute ranking functions: It can handle flowcharts of arbitrary structure, the class of candidate rankings it explores is larger, and our method, although greedy, is provably complete. Our second contribution is to show how to use the ranking functions we generate to get upper bounds for the computational complexity (number of transitions) of the source program. This estimate is a polynomial, which means that we can handle programs with more than linear complexity. We applied the method on a collection of test cases from the literature. We also show the links and differences with previous techniques based on the insertion of counters.