package dolmen
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  A parser library for automated deduction
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      dolmen-0.8.1.tbz
    
    
        
    
  
  
  
    
  
  
    
  
        sha256=80fc33ae81817a79c6e6b2f6c01c4cfcc0af02bfe4d2d1b87cf70b84cdde3928
    
    
  sha512=3a44a99bce871161bc70cf909c813e9e6c91c590873cbc163c69b2ec90ab5be65bf0bf45430bc8d00d85d75cf0af004b06b8f5f1c9d4d47c8a30ab9f28762c04
    
    
  doc/src/dolmen.std/normalize.ml.html
Source file normalize.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 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(* This file is free software, part of dolmen. See file "LICENSE" for more information. *) module Tptp = struct let symbol m ~attr ~loc id = let t = match id with (* Base builtins *) | { Id.name = Simple "$_"; ns = Term } -> Term.(builtin ~loc Wildcard ()) | { Id.name = Simple "$tType" ; ns = Term } -> Term.(builtin ~loc Ttype ()) | { Id.name = Simple "$o"; ns = Term } -> Term.(builtin ~loc Prop ()) | { Id.name = Simple "$true"; ns = Term } -> Term.(builtin ~loc True ()) | { Id.name = Simple "$false"; ns = Term } -> Term.(builtin ~loc False ()) (* Arithmetic builtins *) | { Id.name = Simple "$int"; ns = Term } -> Term.(builtin ~loc Int ()) | { Id.name = Simple "$less"; ns = Term } -> Term.(builtin ~loc Lt ()) | { Id.name = Simple "$lesseq"; ns = Term } -> Term.(builtin ~loc Leq ()) | { Id.name = Simple "$greater"; ns = Term } -> Term.(builtin ~loc Gt ()) | { Id.name = Simple "$greatereq"; ns = Term } -> Term.(builtin ~loc Geq ()) | { Id.name = Simple "$uminus"; ns = Term } -> Term.(builtin ~loc Minus ()) | { Id.name = Simple "$sum"; ns = Term } -> Term.(builtin ~loc Add ()) | { Id.name = Simple "$difference"; ns = Term } -> Term.(builtin ~loc Sub ()) | { Id.name = Simple "$product"; ns = Term } -> Term.(builtin ~loc Mult ()) | _ -> Term.(const ~loc id) in let attrs = List.map (Term.map m) attr in Term.add_attrs attrs t let mapper = { Term.id_mapper with symbol } end module Smtlib = struct let symbol m ~attr ~loc id = let t = match id with | { Id.name = Simple "Bool"; ns = Sort } -> Term.(builtin ~loc Prop ()) | { Id.name = Simple "true"; ns = Term } -> Term.(builtin ~loc True ()) | { Id.name = Simple "false"; ns = Term } -> Term.(builtin ~loc False ()) | { Id.name = Simple "not"; ns = Term } -> Term.(builtin ~loc Not ()) | { Id.name = Simple "and"; ns = Term } -> Term.(builtin ~loc And ()) | { Id.name = Simple "or"; ns = Term } -> Term.(builtin ~loc Or ()) | { Id.name = Simple "xor"; ns = Term } -> Term.(builtin ~loc Xor ()) | { Id.name = Simple "=>"; ns = Term } -> Term.(builtin ~loc Imply ()) | { Id.name = Simple "="; ns = Term } -> Term.(builtin ~loc Eq ()) | { Id.name = Simple "distinct"; ns = Term } -> Term.(builtin ~loc Distinct ()) | { Id.name = Simple "ite"; ns = Term } -> Term.(builtin ~loc Ite ()) | _ -> Term.(const ~loc id) in let attrs = List.map (Term.map m) attr in Term.add_attrs attrs t let binder_let_eq m t = match t with | { Term.term = Term.Colon (u, v) ; _ } -> Term.eq ~loc:t.Term.loc (Term.map m u) (Term.map m v) | _ -> assert false let binder m ~attr ~loc b l body = match b with | Term.Let_seq -> let attrs = List.map (Term.map m) attr in let l' = List.map (binder_let_eq m) l in Term.add_attrs attrs (Term.letin ~loc l' (Term.map m body)) | Term.Let_par -> let attrs = List.map (Term.map m) attr in let l' = List.map (binder_let_eq m) l in Term.add_attrs attrs (Term.letand ~loc l' (Term.map m body)) | _ -> Term.(id_mapper.binder m ~attr ~loc b l body) let mapper = { Term.id_mapper with symbol; binder } end
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >