A Unifying View on SMT-Based Software Verification

被引:47
作者
Beyer, Dirk [1 ]
Dangl, Matthias [1 ]
Wendler, Philipp [1 ]
机构
[1] Ludwig Maximilians Univ Munchen, Munich, Germany
关键词
Software verification; Program analysis; Bounded model checking; k-induction; Impact; Lazy abstraction; Predicate abstraction; SMT solving; MODEL CHECKING; INVARIANT GENERATION; INTERPOLATION; ABSTRACTION; REFINEMENT; PROGRAMS;
D O I
10.1007/s10817-017-9432-6
中图分类号
TP18 [人工智能理论];
学科分类号
081104 ; 0812 ; 0835 ; 1405 ;
摘要
After many years of successful development of new approaches for software verification, there is a need to consolidate the knowledge about the different abstract domains and algorithms. The goal of this paper is to provide a compact and accessible presentation of four SMT-based verification approaches in order to study them in theory and in practice. We present and compare the following different "schools of thought" of software verification: bounded model checking, k-induction, predicate abstraction, and lazy abstraction with interpolants. Those approaches are well-known and successful in software verification and have in common that they are based on SMT solving as the back-end technology. We reformulate all four approaches in the unifying theoretical framework of configurable program analysis and implement them in the verification framework CPAchecker. Based on this, we can present an evaluation that thoroughly compares the different approaches, where the core differences are expressed in configuration parameters and all other variables are kept constant (such as parser front end, SMT solver, used theory in SMT formulas). We evaluate the effectiveness and the efficiency of the approaches on a large set of verification tasks and discuss the conclusions.
引用
收藏
页码:299 / 335
页数:37
相关论文
共 71 条
[61]  
McMillan KL, 2003, LECT NOTES COMPUT SC, V2725, P1
[62]  
McMillan KL, 2003, LECT NOTES COMPUT SC, V2619, P2
[63]  
Nielson Flemming, 1999, PRINCIPLES PROGRAM A
[64]  
Cardona PAN, 2015, CUAD ACT, P154
[65]  
Rakamaric Z, 2014, LECT NOTES COMPUT SC, V8559, P106, DOI 10.1007/978-3-319-08867-9_7
[66]   Model Checking Embedded C Software using k-Induction and Invariants [J].
Rocha, Herbert ;
Ismail, Hussama ;
Cordeiro, Lucas ;
Barreto, Raimundo .
2015 BRAZILIAN SYMPOSIUM ON COMPUTING SYSTEMS ENGINEERING (SBESC), 2015, :90-95
[67]  
Schrammel P, 2016, LECT NOTES COMPUT SC, V9636, P905, DOI [10.1007/97-3-662-49674-9_56, 10.1007/978-3-662-49674-9_56]
[68]   Liveness Checking as Safety Checking for Infinite State Spaces [J].
Schuppan, Viktor ;
Biere, Armin .
ELECTRONIC NOTES IN THEORETICAL COMPUTER SCIENCE, 2006, 149 (01) :79-96
[69]  
Sheeran M, 2000, LECT NOTES COMPUT SC, V1954, P108
[70]  
Sinz C, 2012, LECT NOTES COMPUT SC, V7214, P542, DOI 10.1007/978-3-642-28756-5_44