Counting Integer Points in Parametric Polytopes Using Barvinok's Rational Functions

  • Authors:
  • Sven Verdoolaege;Rachid Seghir;Kristof Beyls;Vincent Loechner;Maurice Bruynooghe

  • Affiliations:
  • Department of Computer Science, Katholieke Universiteit Leuven, 3000, Leuven, Belgium;ICPS-LSIIT UMR 7005, Universite Louis Pasteur, F-67070, Strasbourg, France;Department of Electronics and Information Systems, Ghent University, Ghent, Belgium;ICPS-LSIIT UMR 7005, Universite Louis Pasteur, F-67070, Strasbourg, France;Department of Computer Science, Katholieke Universiteit Leuven, 3000, Leuven, Belgium

  • Venue:
  • Algorithmica
  • Year:
  • 2007

Quantified Score

Hi-index 0.01

Visualization

Abstract

Many compiler optimization techniques depend on the ability to calculate the number of elements that satisfy certain conditions. If these conditions can be represented by linear constraints, then such problems are equivalent to counting the number of integer points in (possibly) parametric polytopes. It is well known that the enumerator of such a set can be represented by an explicit function consisting of a set of quasi-polynomials, each associated with a chamber in the parameter space. Previously, interpolation was used to obtain these quasi-polynomials, but this technique has several disadvantages. Its worst-case computation time for a single quasi-polynomial is exponential in the input size, even for fixed dimensions. The worst-case size of such a quasi-polynomial (measured in bits needed to represent the quasi-polynomial) is also exponential in the input size. Under certain conditions this technique even fails to produce a solution. Our main contribution is a novel method for calculating the required quasi-polynomials analytically. It extends an existing method, based on Barvinok's decomposition, for counting the number of integer points in a non-parametric polytope. Our technique always produces a solution and computes polynomially-sized enumerators in polynomial time (for fixed dimensions).