Skip to content

Latest commit

 

History

History
42 lines (35 loc) · 2.88 KB

README.md

File metadata and controls

42 lines (35 loc) · 2.88 KB

GitHub stars GitHub branches GitHub commits GitHub latest commit

Minisat-based Circuit-SAT-solver

Description

In theoretical computer science, the circuit satisfiability problem (also known as Circuit-SAT) is the decision problem of determining whether a given Boolean circuit has an assignment of its inputs that makes the output true. In other words, it asks whether the inputs to a given Boolean circuit can be consistently set to 1 or 0 such that the circuit outputs 1. If that is the case, the circuit is called satisfiable. Otherwise, the circuit is called unsatisfiable. The Circuit-SAT problem can be solved using SAT-solvers.

Minisat is a very well-known SAT-solver. It is small, complete and efficient. This project is a Minisat-based Circuit-SAT-solver. It applies the Zeitin transformation and has support for a number of circuit-based heuristics that can be easily configured.

Building

(circuit-sat-minisat)$ mkdir build
(circuit-sat-minisat)$ cd build
(circuit-sat-minisat/build)$ cmake ..
(circuit-sat-minisat/build)$ cmake --build .

Using

(circuit-sat-minisat/build)$ ./csat_solver <.bench instance path>

There are some command line options. One can read about them in solver/core/Main.cc.

Configuring heuristics

One can configure heuristics used in the solver in solver/core/Config.h.

Available heuristics:

  • back propagation branching heurictic -- the selection of variables from outputs to inputs
  • activity-based jFrontier branching heurictic -- among the unassigned operands of the assigned gates, the one whose activity is maximal is selected
  • max-probability polarity initialization heuristic -- polarities are initialized so that probabilities of their values are maximal
  • max-propagation polarity initialization heuristic -- polarities are initialized so that unit-propagation during the solving is maximal
  • starting from circuit-based heuristic -- first, the circuit-based branching heuristic is used, and then the basic minisat heuristic is used

Benchmarks

One can find some circuits in benchmark folder. There are 5 classes of circuits, each contains description, 10 SAT-instances and 10 UNSAT-instances.

Contact

If you have any questions feel free to write me: danilapechenev@gmail.com.