-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathsimple.ml
39 lines (27 loc) · 1.15 KB
/
simple.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
(* We hide the context by instanciating a functor: *)
module Z = Z3overlay.Make (struct let ctx = Z3.mk_context [] end)
(* The result of the functor is safe for opening (contains only types and modules. *)
open Z
let () =
Printf.printf "\nSimple test!\n%!" ;
(* We create a solver for future usage. *)
let solver = Solver.make () in
(* We create new SMT variables and specify their types. *)
let x = Symbol.declare Real "x" in
let y = Symbol.declare Real "y" in
(* We can define SMT formulas using an OCaml-like syntax.
[!] transforms a symbol into a term.
*)
let t = T.( !y <= int 3 && !x + !y <= rat Q.(5 // 2)) in
(* We assert the formula in the SMT solver. *)
Solver.add ~solver t ;
(* We can now solve it and extract the result: *)
let result = Solver.check ~solver [] in
let model = match result with
| Unsat _ | Unkown _ -> failwith "Oh noees"
| Sat (lazy model) -> model
in
(* Finally we easily get back the values in the model as inferred by Z3 without any casting! *)
let vy = Model.get_value ~model y in
let vx = Model.get_value ~model x in
Printf.printf "y = %s \nx = %s\n" (Q.to_string vy) (Q.to_string vx)