TY - GEN
T1 - Solving linear arithmetic with SAT-based model checking
AU - Vizel, Yakir
AU - Nadel, Alexander
AU - Malik, Sharad
N1 - Publisher Copyright:
© 2017 FMCAD Inc.
PY - 2017/11/8
Y1 - 2017/11/8
N2 - We present LIAMC, a novel decision procedure for (quantifier-free) linear arithmetic over both integers modulo 2N (LIAn) and integers (LIA). There is no need to explain our motivation to design a new efficient decision procedure for the widely used LIA logic. A LIAn decision procedure can be extremely useful in the context of software (SW) verification. SW verification usually requires to reason about arithmetic constraints over finite integers. To that end, modern SW verification tools commonly use fixed-width bit-vector (BV) solvers. However, BV solvers' efficiency drops dramatically as the width increases. To solve the performance problem, LIA solvers are applied, but they are imprecise as they cannot handle integer overflow. An efficient LIAN solver would be the ideal solution in this context. Our decision procedure LIAMC is based on a transformation of linear arithmetic into safety verification. We treat integers as unbounded streams of bits over time. More precisely, for each input integer, the least significant bit (LSB) corresponds to time 0 in the corresponding stream, and the k-th bit corresponds to the bit received at time k. LIAMC then uses SAT-based model checking (SATMC) to solve the resulting problem. In order to achieve efficiency, LIAMC uses two forms of generalization. First, if it finds a formula to be unsatisfiable for width N, it tries to generalize this result for all the widths. Second, if LIAMC finds a formula to be satisfiable for width N, it tries to 'extend' and thus generalize the assignment to a wider target width. To evaluate LIAMC we used the QF-LIA subset of SMT-COMP'16, and ran two sets of experiments. First, we reinterpreted the QF-LIA over fixed-width bit-vectors of varying widths and compared LIAMC in LIAn mode to both Boolector and Z3. LIAMC solved the most satisfiable instances out of the three even for the shortest width 32. Second, we compared LIAMC to CVC4 and Z3 on the original QF-LIA benchmarks. LIAMC was able to solve many instances that had not been solved by the other solvers.
AB - We present LIAMC, a novel decision procedure for (quantifier-free) linear arithmetic over both integers modulo 2N (LIAn) and integers (LIA). There is no need to explain our motivation to design a new efficient decision procedure for the widely used LIA logic. A LIAn decision procedure can be extremely useful in the context of software (SW) verification. SW verification usually requires to reason about arithmetic constraints over finite integers. To that end, modern SW verification tools commonly use fixed-width bit-vector (BV) solvers. However, BV solvers' efficiency drops dramatically as the width increases. To solve the performance problem, LIA solvers are applied, but they are imprecise as they cannot handle integer overflow. An efficient LIAN solver would be the ideal solution in this context. Our decision procedure LIAMC is based on a transformation of linear arithmetic into safety verification. We treat integers as unbounded streams of bits over time. More precisely, for each input integer, the least significant bit (LSB) corresponds to time 0 in the corresponding stream, and the k-th bit corresponds to the bit received at time k. LIAMC then uses SAT-based model checking (SATMC) to solve the resulting problem. In order to achieve efficiency, LIAMC uses two forms of generalization. First, if it finds a formula to be unsatisfiable for width N, it tries to generalize this result for all the widths. Second, if LIAMC finds a formula to be satisfiable for width N, it tries to 'extend' and thus generalize the assignment to a wider target width. To evaluate LIAMC we used the QF-LIA subset of SMT-COMP'16, and ran two sets of experiments. First, we reinterpreted the QF-LIA over fixed-width bit-vectors of varying widths and compared LIAMC in LIAn mode to both Boolector and Z3. LIAMC solved the most satisfiable instances out of the three even for the shortest width 32. Second, we compared LIAMC to CVC4 and Z3 on the original QF-LIA benchmarks. LIAMC was able to solve many instances that had not been solved by the other solvers.
UR - http://www.scopus.com/inward/record.url?scp=85044633199&partnerID=8YFLogxK
UR - http://www.scopus.com/inward/citedby.url?scp=85044633199&partnerID=8YFLogxK
U2 - 10.23919/FMCAD.2017.8102240
DO - 10.23919/FMCAD.2017.8102240
M3 - Conference contribution
AN - SCOPUS:85044633199
T3 - Proceedings of the 17th Conference on Formal Methods in Computer-Aided Design, FMCAD 2017
SP - 47
EP - 54
BT - Proceedings of the 17th Conference on Formal Methods in Computer-Aided Design, FMCAD 2017
A2 - Weissenbacher, Georg
A2 - Stewart, Daryl
PB - Institute of Electrical and Electronics Engineers Inc.
T2 - 17th Conference on Formal Methods in Computer-Aided Design, FMCAD 2017
Y2 - 2 October 2017 through 6 October 2017
ER -