A pearl on SAT and SMT solving in Prolog (Q428887)

From MaRDI portal
Revision as of 03:57, 30 January 2024 by Import240129110155 (talk | contribs) (Added link to MaRDI item.)
scientific article
Language Label Description Also known as
English
A pearl on SAT and SMT solving in Prolog
scientific article

    Statements

    A pearl on SAT and SMT solving in Prolog (English)
    0 references
    0 references
    0 references
    25 June 2012
    0 references
    A succinct and elegant solver of twenty two Prolog clauses for the Boolean satisfiability problem (SAT solver) is presented. The brevity of the program is achieved using Prolog to transform a propositional formula into a conjunctive normal form (CNF). The match between Prolog, SAT, Davis-Putnam-Logeman-Loveland (DPLL) algorithm with watched literals -- one of the most power features in speeding up SAT solvers -- promotes a lot the author's success. The solver provides an easy entry into the SAT and SAT modulo theories (SMT). The SAT solver exploits the control provided by delay declarations to implement watched literals and unit propagation. The SAT solver can be integrated into an SMT framework which uses the constraint solvers that are available in many Prolog systems. The presented SAT solver is not going to be competitive on large, difficult problems set as challenges in the international SAT and SMT competitions. Nevertheless, the solver does provide a declarative description of SAT solving with watched literals in a succinct and self-contained manner, and one which can be extended in a number of ways. For instance, its incorporation into an SMT scheme using the constraint packages often distributed with Prolog systems gives a straightforward realization of the theory of linear real arithmetic.
    0 references
    SAT solving
    0 references
    SMT solving
    0 references
    Prolog
    0 references
    constraint logic programming
    0 references
    delay declarations
    0 references
    watched literal
    0 references
    unit propagation
    0 references

    Identifiers