package mc2
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
A mcsat-based SMT solver in pure OCaml
Install
dune-project
Dependency
Authors
Maintainers
Sources
v0.1.tar.gz
md5=92de696251ec76fbf3eba6ee917fd80f
sha512=e88ba0cfc23186570a52172a0bd7c56053273941eaf3cda0b80fb6752e05d1b75986b01a4e4d46d9711124318e57cba1cd92d302e81d34f9f1ae8b49f39114f0
doc/src/mc2.dimacs/Plugin_sat.ml.html
Source file Plugin_sat.ml
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
(** {1 Trivial plugin for SAT} *) open Mc2_core let name = "sat" let k_atom = Service.Key.make "sat.atom" type term_view += Atom of int let tc_term = let pp out = function | Atom i -> Format.fprintf out "P%d" i | _ -> assert false in Term.TC.make ~pp () let build p_id Plugin.S_nil : Plugin.t = let module T = Term.Term_allocator(struct let tc = Term.TC.lazy_from_val tc_term let p_id = p_id let initial_size = 64 let equal a b = match a, b with | Atom i, Atom j -> i=j | _ -> false let hash = function Atom i -> CCHash.int i | _ -> assert false end) in let module P = struct let id = p_id let name = name let mk_atom i : atom = let sign = i>0 in let t = T.make (Atom (abs i)) Type.bool in if sign then Term.Bool.pa t else Term.Bool.na t let provided_services = [ Service.Any (k_atom, mk_atom); ] let check_if_sat _ = Sat let iter_terms = T.iter_terms let gc_all = T.gc_all end in (module P) let plugin = Plugin.Factory.make ~requires:Plugin.K_nil ~name ~build ()
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>