sig
  type ('k, 'v, 'comparator) t
  type ('k, 'v, 'comparator) tree
  type 'k key
  type ('a, 'comparator, 'z) options
  val empty : ('k, 'comparator, ('k, 'a, 'comparator) t) options
  val singleton :
    ('k, 'comparator, 'k key -> '-> ('k, 'v, 'comparator) t) options
  val of_alist :
    ('k, 'comparator,
     ('k key * 'v) list ->
     [ `Duplicate_key of 'k key | `Ok of ('k, 'v, 'comparator) t ])
    options
  val of_alist_exn :
    ('k, 'comparator, ('k key * 'v) list -> ('k, 'v, 'comparator) t) options
  val of_alist_multi :
    ('k, 'comparator, ('k key * 'v) list -> ('k, 'v list, 'comparator) t)
    options
  val of_alist_fold :
    ('k, 'comparator,
     ('k key * 'v1) list ->
     init:'v2 -> f:('v2 -> 'v1 -> 'v2) -> ('k, 'v2, 'comparator) t)
    options
  val of_tree :
    ('k, 'comparator,
     ('k key, 'v, 'comparator) tree -> ('k, 'v, 'comparator) t)
    options
  val is_empty : ('a, 'b, 'c) t -> bool
  val length : ('a, 'b, 'c) t -> int
  val add :
    ('k, 'comparator,
     ('k, 'v, 'comparator) t ->
     key:'k key -> data:'-> ('k, 'v, 'comparator) t)
    options
  val add_multi :
    ('k, 'comparator,
     ('k, 'v list, 'comparator) t ->
     key:'k key -> data:'-> ('k, 'v list, 'comparator) t)
    options
  val change :
    ('k, 'comparator,
     ('k, 'v, 'comparator) t ->
     'k key -> ('v option -> 'v option) -> ('k, 'v, 'comparator) t)
    options
  val find :
    ('k, 'comparator, ('k, 'v, 'comparator) t -> 'k key -> 'v option) options
  val find_exn :
    ('k, 'comparator, ('k, 'v, 'comparator) t -> 'k key -> 'v) options
  val remove :
    ('k, 'comparator,
     ('k, 'v, 'comparator) t -> 'k key -> ('k, 'v, 'comparator) t)
    options
  val mem :
    ('k, 'comparator, ('k, 'a, 'comparator) t -> 'k key -> bool) options
  val iter : ('k, 'v, 'a) t -> f:(key:'k key -> data:'-> unit) -> unit
  val map :
    ('k, 'v1, 'comparator) t -> f:('v1 -> 'v2) -> ('k, 'v2, 'comparator) t
  val mapi :
    ('k, 'v1, 'comparator) t ->
    f:(key:'k key -> data:'v1 -> 'v2) -> ('k, 'v2, 'comparator) t
  val fold :
    ('k, 'v, 'b) t -> init:'-> f:(key:'k key -> data:'-> '-> 'a) -> 'a
  val fold_right :
    ('k, 'v, 'b) t -> init:'-> f:(key:'k key -> data:'-> '-> 'a) -> 'a
  val filter :
    ('k, 'comparator,
     ('k, 'v, 'comparator) t ->
     f:(key:'k key -> data:'-> bool) -> ('k, 'v, 'comparator) t)
    options
  val filter_map :
    ('k, 'comparator,
     ('k, 'v1, 'comparator) t ->
     f:('v1 -> 'v2 option) -> ('k, 'v2, 'comparator) t)
    options
  val filter_mapi :
    ('k, 'comparator,
     ('k, 'v1, 'comparator) t ->
     f:(key:'k key -> data:'v1 -> 'v2 option) -> ('k, 'v2, 'comparator) t)
    options
  val compare_direct :
    ('k, 'comparator,
     ('-> '-> int) ->
     ('k, 'v, 'comparator) t -> ('k, 'v, 'comparator) t -> int)
    options
  val equal :
    ('k, 'comparator,
     ('-> '-> bool) ->
     ('k, 'v, 'comparator) t -> ('k, 'v, 'comparator) t -> bool)
    options
  val keys : ('k, 'a, 'b) t -> 'k key list
  val data : ('a, 'v, 'b) t -> 'v list
  val to_alist : ('k, 'v, 'a) t -> ('k key * 'v) list
  val merge :
    ('k, 'comparator,
     ('k, 'v1, 'comparator) t ->
     ('k, 'v2, 'comparator) t ->
     f:(key:'k key ->
        [ `Both of 'v1 * 'v2 | `Left of 'v1 | `Right of 'v2 ] -> 'v3 option) ->
     ('k, 'v3, 'comparator) t)
    options
  val min_elt : ('k, 'v, 'a) t -> ('k key * 'v) option
  val min_elt_exn : ('k, 'v, 'a) t -> 'k key * 'v
  val max_elt : ('k, 'v, 'a) t -> ('k key * 'v) option
  val max_elt_exn : ('k, 'v, 'a) t -> 'k key * 'v
  val for_all : ('k, 'v, 'a) t -> f:('-> bool) -> bool
  val exists : ('k, 'v, 'a) t -> f:('-> bool) -> bool
  val fold_range_inclusive :
    ('k, 'comparator,
     ('k, 'v, 'comparator) t ->
     min:'k key ->
     max:'k key -> init:'-> f:(key:'k key -> data:'-> '-> 'a) -> 'a)
    options
  val range_to_alist :
    ('k, 'comparator,
     ('k, 'v, 'comparator) t ->
     min:'k key -> max:'k key -> ('k key * 'v) list)
    options
  val prev_key :
    ('k, 'comparator,
     ('k, 'v, 'comparator) t -> 'k key -> ('k key * 'v) option)
    options
  val next_key :
    ('k, 'comparator,
     ('k, 'v, 'comparator) t -> 'k key -> ('k key * 'v) option)
    options
  val rank :
    ('k, 'comparator, ('k, 'v, 'comparator) t -> 'k key -> int option)
    options
  val to_tree : ('k, 'v, 'comparator) t -> ('k key, 'v, 'comparator) tree
end