Title
Deciding floating-point logic with abstract conflict driven clause learning
Abstract
We present a bit-precise decision procedure for the theory of floating-point arithmetic. The core of our approach is a non-trivial, lattice-theoretic generalisation of the conflict-driven clause learning algorithm in modern sat solvers to lattice-based abstractions. We use floating-point intervals to reason about the ranges of variables, which allows us to directly handle arithmetic and is more efficient than encoding a formula as a bit-vector as in current floating-point solvers. Interval reasoning alone is incomplete, and we obtain completeness by developing a conflict analysis algorithm that reasons natively about intervals. We have implemented this method in the mathsat5 smt solver and evaluated it on assertion checking problems that bound the values of program variables. Our new technique is faster than a bit-vector encoding approach on 80 % of the benchmarks, and is faster by one order of magnitude or more on 60 % of the benchmarks. The generalisation of cdcl we propose is widely applicable and can be used to derive abstraction-based smt solvers for other theories.
Year
DOI
Venue
2014
10.1007/s10703-013-0203-7
Formal Methods in System Design
Keywords
Field
DocType
Decision procedures,Floating-point logic,Abstract interpretation,SMT
Conflict-Driven Clause Learning,Abstract interpretation,Floating point,Computer science,Assertion,Theoretical computer science,Conflict analysis,Completeness (statistics),Encoding (memory),Satisfiability modulo theories
Journal
Volume
Issue
ISSN
45
2
0925-9856
Citations 
PageRank 
References 
22
0.86
55
Authors
5
Name
Order
Citations
PageRank
Martin Brain127922.41
Vijay D'Silva223914.07
Alberto Griggio362436.37
Leopold Haller41276.93
Daniel Kroening5432.92