mirror of
https://github.com/c-cube/sidekick.git
synced 2025-12-06 03:05:31 -05:00
feat(sat): check proofs if asked to
This commit is contained in:
parent
2d081c554b
commit
a205c429e7
2 changed files with 9 additions and 3 deletions
|
|
@ -149,8 +149,9 @@ let main_cnf () : _ result =
|
|||
~on_new_atom:(fun _ -> incr n_atoms)
|
||||
~size:`Big ()
|
||||
in
|
||||
|
||||
S.Dimacs.parse_file solver !file >>= fun () ->
|
||||
let r = S.solve solver in
|
||||
let r = S.solve ~check:!check solver in
|
||||
if !p_stat then (
|
||||
Fmt.printf "; n-conflicts: %d n-decisions: %d n-propagations: %d@.\
|
||||
; n-restarts: %d n-atoms: %d@."
|
||||
|
|
|
|||
|
|
@ -40,7 +40,7 @@ module Dimacs = struct
|
|||
E.of_exn_trace e
|
||||
end
|
||||
|
||||
let solve (solver:SAT.t) : (unit, string) result =
|
||||
let solve ?(check=false) (solver:SAT.t) : (unit, string) result =
|
||||
let res =
|
||||
Profile.with_ "solve" (fun () -> SAT.solve solver)
|
||||
in
|
||||
|
|
@ -50,7 +50,12 @@ let solve (solver:SAT.t) : (unit, string) result =
|
|||
| SAT.Sat _ ->
|
||||
let t3 = Sys.time () -. t2 in
|
||||
Format.printf "Sat (%.3f/%.3f)@." t2 t3;
|
||||
| SAT.Unsat _ ->
|
||||
| SAT.Unsat (module US) ->
|
||||
|
||||
if check then (
|
||||
let pr = US.get_proof() in
|
||||
SAT.Proof.check (SAT.store solver) pr;
|
||||
);
|
||||
|
||||
let t3 = Sys.time () -. t2 in
|
||||
Format.printf "Unsat (%.3f/%.3f)@." t2 t3;
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue