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