Polynomial function intervals for floating-point software verification

Abstract

The focus of our work is the verification of tight functional properties of numerical programs, such as showing that a floating-point implementation of Riemann integration computes a close approximation of the exact integral. Programmers and engineers writing such programs will benefit from verification tools that support an expressive specification language and that are highly automated. Our work provides a new method for verification of numerical software, supporting a substantially more expressive language for specifications than other publicly available automated tools. The additional expressivity in the specification language is provided by two constructs. First, the specification can feature inclusions between interval arithmetic expressions. Second, the integral operator from classical analysis can be used in the specifications, where the integration bounds can be arbitrary expressions over real variables. To support our claim of expressivity, we outline the verification of four example programs, including the integration example mentioned earlier. A key component of our method is an algorithm for proving numerical theorems. This algorithm is based on automatic polynomial approximation of non-linear real and real-interval functions defined by expressions. The PolyPaver tool is our implementation of the algorithm and its source code is publicly available. In this paper we report on experiments using PolyPaver that indicate that the additional expressivity does not come at a performance cost when comparing with other publicly available state-of-the-art provers. We also include a scalability study that explores the limits of PolyPaver in proving tight functional specifications of progressively larger randomly generated programs.

Publication DOI: https://doi.org/10.1007/s10472-014-9409-7
Divisions: ?? 50811700Jl ??
Additional Information: The original publication is available at www.springerlink.com Funding: Altran Praxis Ltd; EPSRC [EP/C01037X/1]
Uncontrolled Keywords: floating-point software verification,interval arithmetic,non-linear numerical constraint solving,polynomial intervals,theorem proving,validated computation,Artificial Intelligence,Applied Mathematics
Publication ISSN: 1573-7470
Last Modified: 16 Jan 2025 08:08
Date Deposited: 08 Sep 2014 15:05
Full Text Link: http://link.spr ... 0472-014-9409-7
Related URLs: http://www.scop ... tnerID=8YFLogxK (Scopus URL)
PURE Output Type: Article
Published Date: 2014-04-24
Authors: Duracz, Jan
Konečný, Michal (ORCID Profile 0000-0003-2374-9017)

Download

[img]

Version: Accepted Version


Export / Share Citation


Statistics

Additional statistics for this record