Skip to content

Latest commit

 

History

History
135 lines (95 loc) · 3.69 KB

README.md

File metadata and controls

135 lines (95 loc) · 3.69 KB

Super Simple SAT (S3) Solver

A super simple SAT solver implementation.

Credits

Heavily inspired by

Thanks to their authors for the inspiration!

Also thanks to Holger H. Hoos for providing many useful .cnf problems for benchmarks and tests here.

Usage

As Executable

cargo run --release <.cnf-file>

This will print either SAT and the satisfying assignment it has found or UNSAT depending on the input .cnf file. You can find several random 3-SAT .cnf files in this repository's cnf directory for testing and benchmarking.

Example: SAT

> cargo run --release ./cnf/sat/uf150-645/sat/uf150-001.cnf
start solving ...
SAT
model = 1 2 -3 4 -5 6 -7 8 -9 -10 11 -12 -13 14 -15 -16 17 -18 -19 20 -21 -22 -23 24 -25 26 27 -28 29 -30 31 32 33 34 -35 36 37 -38 39 40 41 -42 -43 -44 45 -46 47 48 -49 -50 -51 52 -53 -54 -55 -56 57 58 59 60 61 -62 63 -64 -65 66 67 68 69 70 71 -72 -73 -74 -75 76 -77 -78 79 80 -81 82 83 84 85 -86 -87 88 -89 90 -91 92 93 94 95 -96 -97 98 99 -100 -101 102 103 -104 105 106 -107 -108 109 110 111 -112 -113 -114 -115 -116 -117 118 119 120 121 122 123 -124 -125 126 127 128 129 130 131 132 133 -134 135 136 137 138 139 -140 141 142 143 144 145 -146 147 148 149 -150

Example: UNSAT

> cargo run --release ./cnf/uf150-645/unsat/uuf150-001.cnf
start solving ...
UNSAT

As Library

Example: .cnf Input

let cnf_input = br"
    p cnf 10 4
    1 3 5 0
    -2 -8 6 0
    -4 -8 -1 0
    -10 -7 -2 0
";
let mut solver = Solver::from_cnf(&mut &cnf_input[..]).unwrap();
let result = solver.solve([]).unwrap();
assert!(result.is_sat());

Example: Programmatically Specified Problem

let mut solver = Solver::default();
let v = solver.new_literal_chunk(10)
  .into_iter()
  .collect::<Vec<_>>();
solver.consume_clause([ v[1],  v[3],  v[5]]);
solver.consume_clause([!v[1], !v[7],  v[5]]);
solver.consume_clause([!v[3], !v[7], !v[0]]);
solver.consume_clause([!v[9], !v[6], !v[1]]);
let result = solver.solve([]).unwrap();
assert!(result.is_sat());

Development

Testing

Run tests for the whole workspace using

cargo test --release --workspace

Or run tests for just the solver using

cargo test --release --package s3sat-solver

Note that without --release some tests take a considerably longer time to execute.

Benchmarks

Run benchmarks for the whole workspace using

cargo bench

Run benchmarks for just the SAT solver's solve procedure using

cargo bench Solver::solve

License

Licensed under either of

at your option.

Dual licence: badge badge

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.