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 update_stdlib :
    '->
    ('b option -> 'b option) ->
    ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t
  val find : '-> ('a, 'b) BatMap.PMap.t -> 'b
  val find_default : '-> '-> ('a, 'b) BatMap.PMap.t -> 'b
  val find_first : ('-> bool) -> ('a, 'b) BatMap.PMap.t -> 'a * 'b
  val find_first_opt :
    ('-> bool) -> ('a, 'b) BatMap.PMap.t -> ('a * 'b) option
  val find_last : ('-> bool) -> ('a, 'b) BatMap.PMap.t -> 'a * 'b
  val find_last_opt :
    ('-> bool) -> ('a, 'b) BatMap.PMap.t -> ('a * 'b) option
  val remove : '-> ('a, 'b) BatMap.PMap.t -> ('a, 'b) BatMap.PMap.t
  val remove_exn : '-> ('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 choose_opt : ('key, 'a) BatMap.PMap.t -> ('key * 'a) option
  val any : ('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 min_binding_opt : ('key, 'a) BatMap.PMap.t -> ('key * 'a) option
  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 max_binding_opt : ('key, 'a) BatMap.PMap.t -> ('key * 'a) option
  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 union_stdlib :
    ('key -> '-> '-> 'a option) ->
    ('key, 'a) BatMap.PMap.t ->
    ('key, 'a) BatMap.PMap.t -> ('key, 'a) BatMap.PMap.t
  val to_seq : ('key, 'a) BatMap.PMap.t -> ('key * 'a) BatSeq.t
  val to_rev_seq : ('key, 'a) BatMap.PMap.t -> ('key * 'a) BatSeq.t
  val to_seq_from : 'key -> ('key, 'a) BatMap.PMap.t -> ('key * 'a) BatSeq.t
  val add_seq :
    ('key * 'a) BatSeq.t ->
    ('key, 'a) BatMap.PMap.t -> ('key, 'a) BatMap.PMap.t
  val of_seq :
    ?cmp:('key -> 'key -> int) ->
    ('key * 'a) BatSeq.t -> ('key, 'a) 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
      val choose : ('a, 'b) BatMap.PMap.t -> ('a * 'b) option
      val any : ('a, 'b) BatMap.PMap.t -> ('a * '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