Software Verification with CPAchecker 3.0: Tutorial and User Guide (Extended Version)
Daniel Baier,Dirk Beyer,Po-Chun Chien,Marie-Christine Jakobs,Marek Jankola,Matthias Kettl,Nian-Ze Lee,Thomas Lemberger,Marian Lingsch-Rosenfeld,Henrik Wachowitz,Philipp Wendler
2024-09-04
Abstract:This tutorial provides an introduction to CPAchecker for users. CPAchecker is a flexible and configurable framework for software verification and testing. The framework provides many abstract domains, such as BDDs, explicit values, intervals, memory graphs, and predicates, and many program-analysis and model-checking algorithms, such as abstract interpretation, bounded model checking, Impact, interpolation-based model checking, k -induction, PDR, predicate abstraction, and symbolic execution. This tutorial presents basic use cases for CPAchecker in formal software verification, focusing on its main verification techniques with their strengths and weaknesses. It also shows further use cases of CPAchecker for test-case generation and witness-based result validation. The envisioned readers are assumed to possess a background in automatic formal verification and program analysis, but prior knowledge of CPAchecker is not required. This tutorial and user guide is based on CPAchecker in version 3.0. This user guide's latest version and other documentation are available at <a class="link-external link-https" href="https://cpachecker.sosy-lab.org/doc.php" rel="external noopener nofollow">this https URL</a>.
Software Engineering,Programming Languages