• DocumentCode
    1605707
  • Title

    Symbolic Model Checking of Product-Line Requirements Using SAT-Based Methods

  • Author

    Ben-David, Shoham ; Sterin, Baruch ; Atlee, Joanne M. ; Beidu, Sandy

  • Author_Institution
    David Cheriton Sch. of Comput. Sci., Univ. of Waterloo, Waterloo, ON, Canada
  • Volume
    1
  • fYear
    2015
  • Firstpage
    189
  • Lastpage
    199
  • Abstract
    Product line (PL) engineering promotes the development of families of related products, where individual products are differentiated by which optional features they include. Modelling and analyzing requirements models of PLs allows for early detection and correction of requirements errors -- including unintended feature interactions, which are a serious problem in feature-rich systems. A key challenge in analyzing PL requirements is the efficient verification of the product family, given that the number of products is too large to be verified one at a time. Recently, it has been shown how the high-level design of an entire PL, that includes all possible products, can be compactly represented as a single model in the SMV language, and model checked using the NuSMV tool. The implementation in NuSMV uses BDDs, a method that has been outperformed by SAT-based algorithms. In this paper we develop PL model checking using two leading SAT-based symbolic model checking algorithms: IMC and IC3. We describe the algorithms, prove their correctness, and report on our implementation. Evaluating our methods on three PL models from the literature, we demonstrate an improvement of up to 3 orders of magnitude over the existing BDD-based method.
  • Keywords
    binary decision diagrams; computability; program verification; software product lines; systems analysis; BDD method; IC3 algorithm; IMC algorithm; NuSMV tool; PL model checking; SAT-based method; SAT-based symbolic model checking algorithm; SMV language; correctness proving; feature interaction; high-level design; product family verification; product line engineering; product-line requirements; requirement error correction; requirement error detection; Adaptation models; Analytical models; Boolean functions; Computational modeling; Data structures; Interpolation; Model checking; IC3; IMC; Product Lines; Symbolic Model Checking;
  • fLanguage
    English
  • Publisher
    ieee
  • Conference_Titel
    Software Engineering (ICSE), 2015 IEEE/ACM 37th IEEE International Conference on
  • Conference_Location
    Florence
  • Type

    conf

  • DOI
    10.1109/ICSE.2015.40
  • Filename
    7194573