Get Free Shipping on orders over $89
Decision Procedures : An Algorithmic Point of View - Daniel Kroening

Decision Procedures

An Algorithmic Point of View

By: Daniel Kroening, Ofer Strichman

Hardcover | 27 January 2017 | Edition Number 2

At a Glance

Hardcover


RRP $129.00

$102.75

20%OFF

or 4 interest-free payments of $25.69 with

 or 

Ships in 10 to 15 business days

A decision procedure is an algorithm that, given a decision problem, terminates with a correct yes/no answer. Here, the authors focus on theories that are expressive enough to model real problems, but are still decidable. Specifically, the book concentrates on decision procedures for first-order theories that are commonly used in automated verification and reasoning, theorem-proving, compiler optimization and operations research. The techniques described in the book draw from fields such as graph theory and logic, and are routinely used in industry.

The authors introduce the basic terminology of SAT, Satisfiability Modulo Theories (SMT) and the DPLL(T) framework. Then, in separate chapters, they study decision procedures for propositional logic; equalities and uninterpreted functions; linear arithmetic; bit vectors; arrays; pointer logic; and quantified formulas. They also study the problem of deciding combined theories based on the Nelson-Oppen procedure.

Thefirst edition of this book was adopted as a textbook in courses worldwide. It was published in 2008 and the field now called SMT was then in its infancy, without the standard terminology and canonic algorithms it has now; this second edition reflects these changes. It brings forward the DPLL(T) framework. It also expands the SAT chapter with modern SAT heuristics, and includes a new section about incremental satisfiability, and the related Constraints Satisfaction Problem (CSP). The chapter about quantifiers was expanded with a new section about general quantification using E-matching and a section about Effectively Propositional Reasoning (EPR). The book also includes a new chapter on the application of SMT in industrial software engineering and in computational biology, coauthored by Nikolaj Bjorner and Leonardo de Moura, and Hillel Kugler, respectively.

Each chapter includes a detailed bibliography and exercises. Lecturers' slides and a C++ library for rapid prototyping of decision procedures are available from the authors' website.

Industry Reviews
"This is an excellent book, which I am delighted to have the chance to review. ... The text and the supporting material have been invaluable, stepping the reader through decision procedures and their combinations. ... I highly recommend the book to those interested in understanding and contributing to the world of SAT and SMT solving ... ." (Rosemary Monahan, Formal Aspects of Computing, Vol. 30 (06), November, 2018)

Other Editions and Formats

Paperback

Published: 13th July 2018

More in Algorithms & Data Structures

Python 3 Using DeepSeek - Oswald Campesato

RRP $110.00

$96.75

12%
OFF
Python 3 Using DeepSeek - Oswald Campesato

RRP $242.00

$211.75

12%
OFF
Addiction by Design : Machine Gambling in Las Vegas - Natasha Dow Schll
Learning Algorithms : A Programmer's Guide to Writing Better Code - George Heineman
Python for Algorithmic Trading : From Idea to Cloud Deployment - Yves Hilpisch
How to Prove It : A Structured Approach - Daniel J. Velleman

RRP $73.95

$70.75

The Metaverse : Hype or Hoax? - Kapil Sharma

RRP $103.00

$91.75

11%
OFF
Mathematical Foundations of Deep Learning : Theory and Algorithms - Xiaojing Ye
Theory of Computation for Software Developers - Maxim  Mozgovoy

RRP $189.00

$167.75

11%
OFF