package smtml
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
On This Page
  
  
  An SMT solver frontend for OCaml
Install
    
    dune-project
 Dependency
Authors
- 
  
    
    JJoão Pereira <joaomhmpereira@tecnico.ulisboa.pt>
- 
  
    
    FFilipe Marques <filipe.s.marques@tecnico.ulisboa.pt>
- 
  
    
    HHichem Rami Ait El Hara <hra@ocamlpro.com>
- 
  
    
    LLéo Andrès <contact@ndrs.fr>
- 
  
    
    AArthur Carcano <arthur.carcano@ocamlpro.com>
- 
  
    
    PPierre Chambart <pierre.chambart@ocamlpro.com>
- 
  
    
    JJosé Fragoso Santos <jose.fragoso@tecnico.ulisboa.pt>
Maintainers
Sources
  
    
      v0.12.0.tar.gz
    
    
        
    
  
  
  
    
  
  
    
  
        md5=f8549c12d40e6a1dafcced7e319887a4
    
    
  sha512=f147faa9e2519585cfe9b11654b750061259da4db0b2136d9047b4cb480abb562f6ac627545fd06461f4414acba57558713868de370f58131f3face308f7c7f0
    
    
  doc/index.html
Smtml - SMT Solving in OCaml
Full API Documentation | Test Coverage | GitHub Repository
Smtml is an OCaml SMT solver abstraction layer providing:
- Multi-backend support (currently Z3, Colibri2, Alt-Ergo, Bitwuzla, and cvc5)
- Type-safe expression construction
- Flexible solver interaction modes
- Model extraction capabilities
Getting Started
Install via OPAM:
opam install smtmlBasic usage in OCaml toplevel:
# #require "smtml";;
# #install_printer Smtml.Expr.pp;;
# let pp_model = Smtml.Model.pp ~no_values:false;;
val pp_model : Smtml.Model.t Fmt.t = <fun>
# #install_printer pp_model;;
# #install_printer Smtml.Statistics.pp;;
# module Z3 = Smtml.Solver.Batch (Smtml.Z3_mappings);;
module Z3 :
  sig
    type t = Smtml.Solver.Batch(Smtml.Z3_mappings).t
    type solver = Smtml.Solver.Batch(Smtml.Z3_mappings).solver
    val solver_time : float ref
    val solver_count : int ref
    val pp_statistics : t Fmt.t
    val create : ?params:Smtml.Params.t -> ?logic:Smtml.Logic.t -> unit -> t
    val interrupt : t -> unit
    val clone : t -> t
    val push : t -> unit
    val pop : t -> int -> unit
    val reset : t -> unit
    val add : t -> Smtml.Expr.t list -> unit
    val add_set : t -> Smtml.Expr.Set.t -> unit
    val get_assertions : t -> Smtml.Expr.t list
    val get_statistics : t -> Smtml.Statistics.t
    val check : t -> Smtml.Expr.t list -> [ `Sat | `Unknown | `Unsat ]
    val check_set : t -> Smtml.Expr.Set.t -> [ `Sat | `Unknown | `Unsat ]
    val get_value : t -> Smtml.Expr.t -> Smtml.Expr.t
    val model : ?symbols:Smtml.Symbol.t list -> t -> Smtml.Model.t option
    val get_sat_model :
      ?symbols:Smtml.Symbol.t list ->
      t ->
      Smtml.Expr.Set.t -> [ `Model of Smtml.Model.t | `Unknown | `Unsat ]
  end
# let solver = Z3.create ();;
val solver : Z3.t = <abstr>Creating Solvers
Smtml provides different solver modes through functors:
- Smtml.Solver.Batchfor one-shot solving
- Smtml.Solver.Incrementalfor incremental solving
Create a Z3-based batch solver with custom parameters:
# let params = Smtml.Params.(default () $ (Timeout, 5000));;
val params : Smtml.Params.t = <abstr>
# let solver = Z3.create ~params ~logic:Smtml.Logic.QF_BV ();;
val solver : Z3.t = <abstr>Solver Operations
Key operations (see Smtml.Solver_intf):
- Smtml.Solver_intf.S.push/- Smtml.Solver_intf.S.popfor context management
- Smtml.Solver_intf.S.addfor adding constraints
- Smtml.Solver_intf.S.checkfor satisfiability checks
- Smtml.Solver_intf.S.get_valuefor model extraction
Building Expressions
Construct type-safe SMT expressions using:
- Smtml.Symbolfor creating variables
- Smtml.Exprcombinators
- Smtml.Tyfor type annotations
Example: Bitvector arithmetic
# open Smtml;;
# let cond =
  let x = Expr.symbol (Symbol.make (Ty_bitv 8) "x") in
  let y = Expr.symbol (Symbol.make (Ty_bitv 8) "y") in
  let sum = Expr.binop (Ty_bitv 8) Add x y in
  let num = Expr.value (Bitv (Bitvector.of_int8 42)) in
  Expr.relop Ty_bool Eq sum num;;
val cond : Expr.t = (bool.eq (i8.add x y) 42)Checking Satisfiability
Add constraints and check satisfiability:
# Z3.add solver [ cond ];;
- : unit = ()
# match Z3.check solver [] with
  | `Sat -> "Satisfiable"
  | `Unsat -> "Unsatisfiable"
  | `Unknown -> "Unknown";;
- : string = "Satisfiable"Working with Models
Extract values from satisfiable constraints:
# let model = Z3.model solver |> Option.get;;
val model : Model.t = (model
    (x i8 9)
    (y i8 33))
# let x_val =
  let x = Symbol.make (Ty_bitv 8) "x" in
  Model.evaluate model x;;
val x_val : Value.t option = Some (Smtml.Value.Bitv <abstr>)Advanced Features
Solver Parameters
Customize solver behavior using parameters:
let params = Smtml.Params.(
  default ()
  $ (Timeout, 1000)
  $ (Model, true)
  $ (Unsat_core, false)
);;Solver Statistics
Track solver performance:
# Z3.get_statistics solver
- : Statistics.t =
((max memory 16.9)
 (memory 16.9)
 (num allocs 7625)
 (rlimit count 362)
 (sat backjumps 2)
 (sat conflicts 2)
 (sat decisions 15)
 (sat mk clause 2ary 57)
 (sat mk clause nary 98)
 (sat mk var 53)
 (sat propagations 2ary 28)
 (sat propagations nary 30))More Examples
Explore comprehensive usage scenarios:
- Optimizer - Using optimizers
Contributing
Smtml is open source! Report issues and contribute at: GitHub Repository
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  On This Page