sig   type ('a, 'b) t   val create : ?random:bool -> int -> ('a, 'b) Hashtbl.t   val clear : ('a, 'b) Hashtbl.t -> unit   val reset : ('a, 'b) Hashtbl.t -> unit   val copy : ('a, 'b) Hashtbl.t -> ('a, 'b) Hashtbl.t   val add : ('a, 'b) Hashtbl.t -> '-> '-> unit   val find : ('a, 'b) Hashtbl.t -> '-> 'b   val find_all : ('a, 'b) Hashtbl.t -> '-> 'b list   val mem : ('a, 'b) Hashtbl.t -> '-> bool   val remove : ('a, 'b) Hashtbl.t -> '-> unit   val replace : ('a, 'b) Hashtbl.t -> '-> '-> unit   val iter : ('-> '-> unit) -> ('a, 'b) Hashtbl.t -> unit   val filter_map_inplace :     ('-> '-> 'b option) -> ('a, 'b) Hashtbl.t -> unit   val fold : ('-> '-> '-> 'c) -> ('a, 'b) Hashtbl.t -> '-> 'c   val length : ('a, 'b) Hashtbl.t -> int   val randomize : unit -> unit   val is_randomized : unit -> bool   type statistics = {     num_bindings : int;     num_buckets : int;     max_bucket_length : int;     bucket_histogram : int array;   }   val stats : ('a, 'b) Hashtbl.t -> Hashtbl.statistics   module type HashedType =     sig       type t       val equal : Hashtbl.HashedType.t -> Hashtbl.HashedType.t -> bool       val hash : Hashtbl.HashedType.t -> int     end   module type S =     sig       type key       type 'a t       val create : int -> 'Hashtbl.S.t       val clear : 'Hashtbl.S.t -> unit       val reset : 'Hashtbl.S.t -> unit       val copy : 'Hashtbl.S.t -> 'Hashtbl.S.t       val add : 'Hashtbl.S.t -> Hashtbl.S.key -> '-> unit       val remove : 'Hashtbl.S.t -> Hashtbl.S.key -> unit       val find : 'Hashtbl.S.t -> Hashtbl.S.key -> 'a       val find_all : 'Hashtbl.S.t -> Hashtbl.S.key -> 'a list       val replace : 'Hashtbl.S.t -> Hashtbl.S.key -> '-> unit       val mem : 'Hashtbl.S.t -> Hashtbl.S.key -> bool       val iter : (Hashtbl.S.key -> '-> unit) -> 'Hashtbl.S.t -> unit       val filter_map_inplace :         (Hashtbl.S.key -> '-> 'a option) -> 'Hashtbl.S.t -> unit       val fold :         (Hashtbl.S.key -> '-> '-> 'b) -> 'Hashtbl.S.t -> '-> 'b       val length : 'Hashtbl.S.t -> int       val stats : 'Hashtbl.S.t -> Hashtbl.statistics     end   module Make :     functor (H : HashedType->       sig         type key = H.t         type 'a t         val create : int -> 'a t         val clear : 'a t -> unit         val reset : 'a t -> unit         val copy : 'a t -> 'a t         val add : 'a t -> key -> '-> unit         val remove : 'a t -> key -> unit         val find : 'a t -> key -> 'a         val find_all : 'a t -> key -> 'a list         val replace : 'a t -> key -> '-> unit         val mem : 'a t -> key -> bool         val iter : (key -> '-> unit) -> 'a t -> unit         val filter_map_inplace : (key -> '-> 'a option) -> 'a t -> unit         val fold : (key -> '-> '-> 'b) -> 'a t -> '-> 'b         val length : 'a t -> int         val stats : 'a t -> statistics       end   module type SeededHashedType =     sig       type t       val equal :         Hashtbl.SeededHashedType.t -> Hashtbl.SeededHashedType.t -> bool       val hash : int -> Hashtbl.SeededHashedType.t -> int     end   module type SeededS =     sig       type key       type 'a t       val create : ?random:bool -> int -> 'Hashtbl.SeededS.t       val clear : 'Hashtbl.SeededS.t -> unit       val reset : 'Hashtbl.SeededS.t -> unit       val copy : 'Hashtbl.SeededS.t -> 'Hashtbl.SeededS.t       val add : 'Hashtbl.SeededS.t -> Hashtbl.SeededS.key -> '-> unit       val remove : 'Hashtbl.SeededS.t -> Hashtbl.SeededS.key -> unit       val find : 'Hashtbl.SeededS.t -> Hashtbl.SeededS.key -> 'a       val find_all : 'Hashtbl.SeededS.t -> Hashtbl.SeededS.key -> 'a list       val replace : 'Hashtbl.SeededS.t -> Hashtbl.SeededS.key -> '-> unit       val mem : 'Hashtbl.SeededS.t -> Hashtbl.SeededS.key -> bool       val iter :         (Hashtbl.SeededS.key -> '-> unit) -> 'Hashtbl.SeededS.t -> unit       val filter_map_inplace :         (Hashtbl.SeededS.key -> '-> 'a option) ->         'Hashtbl.SeededS.t -> unit       val fold :         (Hashtbl.SeededS.key -> '-> '-> 'b) ->         'Hashtbl.SeededS.t -> '-> 'b       val length : 'Hashtbl.SeededS.t -> int       val stats : 'Hashtbl.SeededS.t -> Hashtbl.statistics     end   module MakeSeeded :     functor (H : SeededHashedType->       sig         type key = H.t         type 'a t         val create : ?random:bool -> int -> 'a t         val clear : 'a t -> unit         val reset : 'a t -> unit         val copy : 'a t -> 'a t         val add : 'a t -> key -> '-> unit         val remove : 'a t -> key -> unit         val find : 'a t -> key -> 'a         val find_all : 'a t -> key -> 'a list         val replace : 'a t -> key -> '-> unit         val mem : 'a t -> key -> bool         val iter : (key -> '-> unit) -> 'a t -> unit         val filter_map_inplace : (key -> '-> 'a option) -> 'a t -> unit         val fold : (key -> '-> '-> 'b) -> 'a t -> '-> 'b         val length : 'a t -> int         val stats : 'a t -> statistics       end   val hash : '-> int   val seeded_hash : int -> '-> int   val hash_param : int -> int -> '-> int   val seeded_hash_param : int -> int -> int -> '-> int end