(* module Ptset : sig include Set.S with type elt = int val from_list : elt list -> t end *) type state = int val mk_state : unit -> state type predicate = [ `Left of (Tree.Binary.t -> bool) | `Right of (Tree.Binary.t -> bool) | `True ] val eval_pred : Tree.Binary.t -> predicate -> bool type formula_expr = False | True | Or of formula * formula | And of formula * formula | Atom of ([ `Left | `Right | `LLeft | `RRight ] * bool * state) and formula = { fid : int; fkey : int; pos : formula_expr; neg : formula; st : (Ptset.t*Ptset.t)*(Ptset.t*Ptset.t); size: int;} val true_ : formula val false_ : formula val atom_ : [`Left | `Right | `LLeft | `RRight ] -> bool -> state -> formula val and_ : formula -> formula -> formula val or_ : formula -> formula -> formula val not_ : formula -> formula (*val equal_form : formula -> formula -> bool *) val pr_frm : Format.formatter -> formula -> unit module HTagSet : Hashtbl.S with type key = Ptset.t*Tag.t type t = { id : int; mutable states : Ptset.t; init : Ptset.t; mutable final : Ptset.t; universal : Ptset.t; phi : (state,(TagSet.t*(bool*formula*predicate)) list) Hashtbl.t; delta : (state*Tag.t, (bool*formula*predicate)) Hashtbl.t; (* delta : (state,(bool*formula*predicate) TagMap.t) Hashtbl.t; *) sigma : (bool*formula*(predicate list*predicate list)*bool) HTagSet.t; } val dump : Format.formatter -> t -> unit module Transitions : sig type t = state*TagSet.t*bool*formula*predicate (* Doing this avoid the parenthesis *) val ( ?< ) : state -> state val ( >< ) : state -> TagSet.t*bool -> state*(TagSet.t*bool*predicate) val ( ><@ ) : state -> TagSet.t*bool*predicate -> state*(TagSet.t*bool*predicate) val ( >=> ) : state*(TagSet.t*bool*predicate) -> formula -> t val ( +| ) : formula -> formula -> formula val ( *& ) : formula -> formula -> formula val ( ** ) : [`Left | `Right | `LLeft | `RRight ] -> state -> formula end type transition = Transitions.t val equal_trans : transition -> transition -> bool module TS : sig type t val empty : t val cons : Tree.Binary.t -> t -> t val append : Tree.Binary.t -> t -> t val concat : t -> t -> t val to_list_rev : t -> Tree.Binary.t list val length : t -> int val iter : (Tree.Binary.t -> unit) -> t -> unit val rev_iter : (Tree.Binary.t -> unit) -> t -> unit val find : (Tree.Binary.t -> bool) -> t -> Tree.Binary.t end (*module BottomUpJumpNew : sig *) val run : t -> Tree.Binary.t -> TS.t val run_count : t -> Tree.Binary.t -> int val run_time : t -> Tree.Binary.t -> TS.t (*end *)