sig   type ('a, 'b) t   val empty : ('a, 'b) BatMap.PMap.t   val is_empty : ('a, 'b) BatMap.PMap.t -> bool   val create : ('-> '-> int) -> ('a, 'b) BatMap.PMap.t   val singleton :     ?cmp:('-> '-> int) -> '-> '-> ('a, 'b) BatMap.PMap.t   val cardinal : ('a, 'b) BatMap.PMap.t -> int   val add : '-> '-> ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t   val update :     '-> '-> '-> ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t   val find : '-> ('a, 'b) BatMap.PMap.t -> 'b   val remove : '-> ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t   val mem : '-> ('a, 'b) BatMap.PMap.t -> bool   val iter : ('-> '-> unit) -> ('a, 'b) BatMap.PMap.t -> unit   val map : ('-> 'c) -> ('a, 'b) BatMap.PMap.t -> ('a, 'c) BatMap.PMap.t   val mapi :     ('-> '-> 'c) -> ('a, 'b) BatMap.PMap.t -> ('a, 'c) BatMap.PMap.t   val fold : ('-> '-> 'c) -> ('a, 'b) BatMap.PMap.t -> '-> 'c   val foldi : ('-> '-> '-> 'c) -> ('a, 'b) BatMap.PMap.t -> '-> 'c   val at_rank_exn : int -> ('a, 'b) BatMap.PMap.t -> 'a * 'b   val filterv :     ('-> bool) -> ('key, 'a) BatMap.PMap.t -> ('key, 'a) BatMap.PMap.t   val filter :     ('key -> '-> bool) ->     ('key, 'a) BatMap.PMap.t -> ('key, 'a) BatMap.PMap.t   val filter_map :     ('key -> '-> 'b option) ->     ('key, 'a) BatMap.PMap.t -> ('key, 'b) BatMap.PMap.t   val choose : ('key, 'a) BatMap.PMap.t -> 'key * 'a   val split :     'key ->     ('key, 'a) BatMap.PMap.t ->     ('key, 'a) BatMap.PMap.t * 'a option * ('key, 'a) BatMap.PMap.t   val min_binding : ('key, 'a) BatMap.PMap.t -> 'key * 'a   val pop_min_binding :     ('key, 'a) BatMap.PMap.t -> ('key * 'a) * ('key, 'a) BatMap.PMap.t   val max_binding : ('key, 'a) BatMap.PMap.t -> 'key * 'a   val pop_max_binding :     ('key, 'a) BatMap.PMap.t -> ('key * 'a) * ('key, 'a) BatMap.PMap.t   val enum : ('a, 'b) BatMap.PMap.t -> ('a * 'b) BatEnum.t   val backwards : ('a, 'b) BatMap.PMap.t -> ('a * 'b) BatEnum.t   val keys : ('a, 'b) BatMap.PMap.t -> 'BatEnum.t   val values : ('a, 'b) BatMap.PMap.t -> 'BatEnum.t   val of_enum :     ?cmp:('-> '-> int) -> ('a * 'b) BatEnum.t -> ('a, 'b) BatMap.PMap.t   val for_all : ('-> '-> bool) -> ('a, 'b) BatMap.PMap.t -> bool   val exists : ('-> '-> bool) -> ('a, 'b) BatMap.PMap.t -> bool   val partition :     ('-> '-> bool) ->     ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t * ('a, 'b) BatMap.PMap.t   val add_carry :     '-> '-> ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t * 'b option   val modify :     '-> ('-> 'b) -> ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t   val modify_def :     '->     '-> ('-> 'b) -> ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t   val modify_opt :     '->     ('b option -> 'b option) ->     ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t   val extract : '-> ('a, 'b) BatMap.PMap.t -> 'b * ('a, 'b) BatMap.PMap.t   val pop : ('a, 'b) BatMap.PMap.t -> ('a * 'b) * ('a, 'b) BatMap.PMap.t   val union :     ('a, 'b) BatMap.PMap.t ->     ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t   val diff :     ('a, 'b) BatMap.PMap.t ->     ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t   val intersect :     ('-> '-> 'd) ->     ('a, 'b) BatMap.PMap.t ->     ('a, 'c) BatMap.PMap.t -> ('a, 'd) BatMap.PMap.t   val merge :     ('key -> 'a option -> 'b option -> 'c option) ->     ('key, 'a) BatMap.PMap.t ->     ('key, 'b) BatMap.PMap.t -> ('key, 'c) BatMap.PMap.t   val merge_unsafe :     ('key -> 'a option -> 'b option -> 'c option) ->     ('key, 'a) BatMap.PMap.t ->     ('key, 'b) BatMap.PMap.t -> ('key, 'c) BatMap.PMap.t   val compare :     ('-> '-> int) ->     ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t -> int   val equal :     ('-> '-> bool) ->     ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t -> bool   module Exceptionless :     sig val find : '-> ('a, 'b) BatMap.PMap.t -> 'b option end   module Infix :     sig       val ( --> ) : ('a, 'b) BatMap.PMap.t -> '-> 'b       val ( <-- ) :         ('a, 'b) BatMap.PMap.t -> 'a * '-> ('a, 'b) BatMap.PMap.t     end   val ( --> ) : ('a, 'b) BatMap.PMap.t -> '-> 'b   val ( <-- ) : ('a, 'b) BatMap.PMap.t -> 'a * '-> ('a, 'b) BatMap.PMap.t   val bindings : ('key, 'a) BatMap.PMap.t -> ('key * 'a) list   val print :     ?first:string ->     ?last:string ->     ?sep:string ->     ?kvsep:string ->     ('BatInnerIO.output -> '-> unit) ->     ('BatInnerIO.output -> '-> unit) ->     'BatInnerIO.output -> ('b, 'c) BatMap.PMap.t -> unit   val get_cmp : ('a, 'b) BatMap.PMap.t -> '-> '-> int end