Back to Search Start Over

Selectively-Amortized Resource Bounding (Extended Version)

Authors :
Lu, Tianhan
Chang, Bor-Yuh Evan
Trivedi, Ashutosh
Publication Year :
2021

Abstract

We consider the problem of automatically proving resource bounds. That is, we study how to prove that an integer-valued resource variable is bounded by a given program expression. Automatic resource-bound analysis has recently received significant attention because of a number of important applications (e.g., detecting performance bugs, preventing algorithmic-complexity attacks, identifying side-channel vulnerabilities), where the focus has often been on developing precise amortized reasoning techniques to infer the most exact resource usage. While such innovations remain critical, we observe that fully precise amortization is not always necessary to prove a bound of interest. And in fact, by amortizing selectively, the needed supporting invariants can be simpler, making the invariant inference task more feasible and predictable. We present a framework for selectively-amortized analysis that mixes worst-case and amortized reasoning via a property decomposition and a program transformation. We show that proving bounds in any such decomposition yields a sound resource bound in the original program, and we give an algorithm for selecting a reasonable decomposition.<br />Comment: This is an extended version of SAS'21 paper (with appendices)

Details

Database :
arXiv
Publication Type :
Report
Accession number :
edsarx.2108.08263
Document Type :
Working Paper