functor (H : SeededHashedType->   sig     type key = H.t     and '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:key -> data:'-> 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:key -> data:'-> unit     val mem : 'a t -> key -> bool     val iter : f:(key:key -> data:'-> unit) -> 'a t -> unit     val filter_map_inplace :       f:(key:key -> data:'-> 'a option) -> 'a t -> unit     val fold : f:(key:key -> data:'-> '-> 'b) -> 'a t -> init:'-> 'b     val length : 'a t -> int     val stats : 'a t -> statistics   end