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 Brain | 1 | 279 | 22.41 |
Vijay D'Silva | 2 | 239 | 14.07 |
Alberto Griggio | 3 | 624 | 36.37 |
Leopold Haller | 4 | 127 | 6.93 |
Daniel Kroening | 5 | 43 | 2.92 |