Book description
This multivolume work on the analysis of algorithms has long been recognized as the definitive description of classical computer science. The four volumes published to date already comprise a unique and invaluable resource in programming theory and practice. Countless readers have spoken about the profound personal influence of Knuth’s writings. Scientists have marveled at the beauty and elegance of his analysis, while practicing programmers have successfully applied his “cookbook” solutions to their day-to-day problems. All have admired Knuth for the breadth, clarity, accuracy, and good humor found in his books.
To continue the fourth and later volumes of the set, and to update parts of the existing volumes, Knuth has created a series of small books called fascicles, which are published at regular intervals. Each fascicle encompasses a section or more of wholly new or revised material. Ultimately, the content of these fascicles will be rolled up into the comprehensive, final versions of each volume, and the enormous undertaking that began in 1962 will be complete.
Volume 4 Fascicle 6
This fascicle, brimming with lively examples, forms the middle third of what will eventually become hardcover Volume 4B. It introduces and surveys “Satisfiability,’’ one of the most fundamental problems in all of computer science: Given a Boolean function, can its variables be set to at least one pattern of 0s and 1s that will make the function true?
Satisfiability is far from an abstract exercise in understanding formal systems. Revolutionary methods for solving such problems emerged at the beginning of the twenty-first century, and they’ve led to game-changing applications in industry. These so-called “SAT solvers’’ can now routinely find solutions to practical problems that involve millions of variables and were thought until very recently to be hopelessly difficult.
Fascicle 6 presents full details of seven different SAT solvers, ranging from simple algorithms suitable for small problems to state-of-the-art algorithms of industrial strength. Many other significant topics also arise in the course of the discussion, such as bounded model checking, the theory of traces, Las Vegas algorithms, phase changes in random processes, the efficient encoding of problems into conjunctive normal form, and the exploitation of global and local symmetries. More than 500 exercises are provided, arranged carefully for self-instruction, together with detailed answers.
Table of contents
- Title Page
- Copyright Page
- Preface
- Contents
-
Chapter 7. Combinatorial Searching
-
7.2.2.2. Satisfiability
- A simple example
- Backtracking for SAT
- Random satisfiability
- Resolution
- SAT solving via resolution
- Monte Carlo methods
- The Local Lemma
- *Message passing
- *Preprocessing of clauses
- Encoding constraints into clauses
- Unit propagation and forcing
- Symmetry breaking
- Satisfiability-preserving maps
- One hundred test cases
- Tuning up the parameters
- Exploiting parallelism
- A brief history
- Exercises
-
7.2.2.2. Satisfiability
- Answers to Exercises
- Index to Algorithms and Theorems
- Index and Glossary
Product information
- Title: The Art of Computer Programming: Satisfiability, Volume 4, Fascicle 6
- Author(s):
- Release date: December 2015
- Publisher(s): Addison-Wesley Professional
- ISBN: 9780134394572
You might also like
book
Make: Volume 81
Put your bot-building skills to the test by going head-to-head with your best pals in radio-controlled, …
book
Minimalist Mobile Robotics
Rather than using traditional artificial intelligence techniques, which are ineffective when applied to the complexities of …
video
Illustrating Technical Books: From getting ideas to completing a figure
An expert in Computer Vision and Image Processing demonstrates how to create entertaining graphics for complex …
book
Build Your Own Autonomous NERF Blaster
Design and build your own robotic, Arduino-powered sentry blaster! Break out the big daddy blaster--and teach …