sig
  type elt
  type set
  type +'a t
  val empty : 'SetMap.Map.t
  val is_empty : 'SetMap.Map.t -> bool
  val size : 'SetMap.Map.t -> int
  val root : 'SetMap.Map.t -> (SetMap.Map.elt * 'a) option
  val max_key : 'SetMap.Map.t -> SetMap.Map.elt option
  val add : SetMap.Map.elt -> '-> 'SetMap.Map.t -> 'SetMap.Map.t
  val remove : SetMap.Map.elt -> 'SetMap.Map.t -> 'SetMap.Map.t
  val add_while_testing_freshness :
    ('parameters, 'error,
     SetMap.Map.elt ->
     '-> 'SetMap.Map.t -> 'error * bool * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val remove_while_testing_existence :
    ('parameters, 'error,
     SetMap.Map.elt -> 'SetMap.Map.t -> 'error * bool * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val pop : SetMap.Map.elt -> 'SetMap.Map.t -> 'a option * 'SetMap.Map.t
  val merge : 'SetMap.Map.t -> 'SetMap.Map.t -> 'SetMap.Map.t
  val min_elt : 'SetMap.Map.t -> (SetMap.Map.elt * 'a) option
  val find_option : SetMap.Map.elt -> 'SetMap.Map.t -> 'a option
  val find_default : '-> SetMap.Map.elt -> 'SetMap.Map.t -> 'a
  val find_option_with_logs :
    ('parameters, 'error,
     SetMap.Map.elt -> 'SetMap.Map.t -> 'error * 'a option)
    SetMap.with_log_wrap
  val find_default_with_logs :
    ('parameters, 'error,
     '-> SetMap.Map.elt -> 'SetMap.Map.t -> 'error * 'a)
    SetMap.with_log_wrap
  val mem : SetMap.Map.elt -> 'SetMap.Map.t -> bool
  val diff :
    'SetMap.Map.t -> 'SetMap.Map.t -> 'SetMap.Map.t * 'SetMap.Map.t
  val union : 'SetMap.Map.t -> 'SetMap.Map.t -> 'SetMap.Map.t
  val update : 'SetMap.Map.t -> 'SetMap.Map.t -> 'SetMap.Map.t
  val diff_pred :
    ('-> '-> bool) ->
    'SetMap.Map.t -> 'SetMap.Map.t -> 'SetMap.Map.t * 'SetMap.Map.t
  val add_with_logs :
    ('parameters, 'error,
     SetMap.Map.elt -> '-> 'SetMap.Map.t -> 'error * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val remove_with_logs :
    ('parameters, 'error,
     SetMap.Map.elt -> 'SetMap.Map.t -> 'error * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val join_with_logs :
    ('parameters, 'error,
     'SetMap.Map.t ->
     SetMap.Map.elt -> '-> 'SetMap.Map.t -> 'error * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val split_with_logs :
    ('parameters, 'error,
     SetMap.Map.elt ->
     'SetMap.Map.t ->
     'error * ('SetMap.Map.t * 'a option * 'SetMap.Map.t))
    SetMap.with_log_wrap
  val update_with_logs :
    ('parameters, 'error,
     'SetMap.Map.t -> 'SetMap.Map.t -> 'error * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val map2_with_logs :
    ('parameters, 'error,
     ('parameters -> 'error -> '-> 'error * 'c) ->
     ('parameters -> 'error -> '-> 'error * 'c) ->
     ('parameters -> 'error -> '-> '-> 'error * 'c) ->
     'SetMap.Map.t -> 'SetMap.Map.t -> 'error * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val map2z_with_logs :
    ('parameters, 'error,
     ('parameters -> 'error -> '-> '-> 'error * 'a) ->
     'SetMap.Map.t -> 'SetMap.Map.t -> 'error * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val fold2z_with_logs :
    ('parameters, 'error,
     ('parameters ->
      'error -> SetMap.Map.elt -> '-> '-> '-> 'error * 'c) ->
     'SetMap.Map.t -> 'SetMap.Map.t -> '-> 'error * 'c)
    SetMap.with_log_wrap
  val fold2_with_logs :
    ('parameters, 'error,
     ('parameters -> 'error -> SetMap.Map.elt -> '-> '-> 'error * 'c) ->
     ('parameters -> 'error -> SetMap.Map.elt -> '-> '-> 'error * 'c) ->
     ('parameters ->
      'error -> SetMap.Map.elt -> '-> '-> '-> 'error * 'c) ->
     'SetMap.Map.t -> 'SetMap.Map.t -> '-> 'error * 'c)
    SetMap.with_log_wrap
  val fold2_sparse_with_logs :
    ('parameters, 'error,
     ('parameters ->
      'error -> SetMap.Map.elt -> '-> '-> '-> 'error * 'c) ->
     'SetMap.Map.t -> 'SetMap.Map.t -> '-> 'error * 'c)
    SetMap.with_log_wrap
  val iter2_sparse_with_logs :
    ('parameters, 'error,
     ('parameters -> 'error -> SetMap.Map.elt -> '-> '-> 'error) ->
     'SetMap.Map.t -> 'SetMap.Map.t -> 'error)
    SetMap.with_log_wrap
  val diff_with_logs :
    ('parameters, 'error,
     'SetMap.Map.t ->
     'SetMap.Map.t -> 'error * 'SetMap.Map.t * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val diff_pred_with_logs :
    ('parameters, 'error,
     ('-> '-> bool) ->
     'SetMap.Map.t ->
     'SetMap.Map.t -> 'error * 'SetMap.Map.t * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val merge_with_logs :
    ('parameters, 'error,
     'SetMap.Map.t -> 'SetMap.Map.t -> 'error * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val union_with_logs :
    ('parameters, 'error,
     'SetMap.Map.t -> 'SetMap.Map.t -> 'error * 'SetMap.Map.t)
    SetMap.with_log_wrap
  val fold_restriction_with_logs :
    ('parameters, 'error,
     (SetMap.Map.elt -> '-> 'error * '-> 'error * 'b) ->
     SetMap.Map.set -> 'SetMap.Map.t -> '-> 'error * 'b)
    SetMap.with_log_wrap
  val fold_restriction_with_missing_associations_with_logs :
    ('parameters, 'error,
     (SetMap.Map.elt -> '-> 'error * '-> 'error * 'b) ->
     (SetMap.Map.elt -> 'error * '-> 'error * 'b) ->
     SetMap.Map.set -> 'SetMap.Map.t -> '-> 'error * 'b)
    SetMap.with_log_wrap
  val iter : (SetMap.Map.elt -> '-> unit) -> 'SetMap.Map.t -> unit
  val fold :
    (SetMap.Map.elt -> '-> '-> 'b) -> 'SetMap.Map.t -> '-> 'b
  val fold_with_interruption :
    (SetMap.Map.elt -> '-> '-> ('b, 'c) Stop.stop) ->
    'SetMap.Map.t -> '-> ('b, 'c) Stop.stop
  val monadic_fold2 :
    'parameters ->
    'method_handler ->
    ('parameters ->
     'method_handler ->
     SetMap.Map.elt -> '-> '-> '-> 'method_handler * 'c) ->
    ('parameters ->
     'method_handler -> SetMap.Map.elt -> '-> '-> 'method_handler * 'c) ->
    ('parameters ->
     'method_handler -> SetMap.Map.elt -> '-> '-> 'method_handler * 'c) ->
    'SetMap.Map.t -> 'SetMap.Map.t -> '-> 'method_handler * 'c
  val monadic_fold2_sparse :
    'parameters ->
    'method_handler ->
    ('parameters ->
     'method_handler ->
     SetMap.Map.elt -> '-> '-> '-> 'method_handler * 'c) ->
    'SetMap.Map.t -> 'SetMap.Map.t -> '-> 'method_handler * 'c
  val monadic_iter2_sparse :
    'parameters ->
    'method_handler ->
    ('parameters ->
     'method_handler -> SetMap.Map.elt -> '-> '-> 'method_handler) ->
    'SetMap.Map.t -> 'SetMap.Map.t -> 'method_handler
  val monadic_fold_restriction :
    'parameters ->
    'method_handler ->
    ('parameters ->
     'method_handler -> SetMap.Map.elt -> '-> '-> 'method_handler * 'b) ->
    SetMap.Map.set -> 'SetMap.Map.t -> '-> 'method_handler * 'b
  val mapi :
    (SetMap.Map.elt -> '-> 'b) -> 'SetMap.Map.t -> 'SetMap.Map.t
  val map : ('-> 'b) -> 'SetMap.Map.t -> 'SetMap.Map.t
  val map2 :
    ('-> '-> 'a) -> 'SetMap.Map.t -> 'SetMap.Map.t -> 'SetMap.Map.t
  val for_all : (SetMap.Map.elt -> '-> bool) -> 'SetMap.Map.t -> bool
  val filter_one :
    (SetMap.Map.elt -> '-> bool) ->
    'SetMap.Map.t -> (SetMap.Map.elt * 'a) option
  val compare :
    ('-> '-> int) -> 'SetMap.Map.t -> 'SetMap.Map.t -> int
  val equal :
    ('-> '-> bool) -> 'SetMap.Map.t -> 'SetMap.Map.t -> bool
  val bindings : 'SetMap.Map.t -> (SetMap.Map.elt * 'a) list
  val print :
    (Format.formatter -> '-> unit) ->
    Format.formatter -> 'SetMap.Map.t -> unit
  val of_json :
    ?lab_key:string ->
    ?lab_value:string ->
    ?error_msg:string ->
    (Yojson.Basic.json -> SetMap.Map.elt) ->
    (Yojson.Basic.json -> 'value) -> Yojson.Basic.json -> 'value SetMap.Map.t
  val to_json :
    ?lab_key:string ->
    ?lab_value:string ->
    (SetMap.Map.elt -> Yojson.Basic.json) ->
    ('value -> Yojson.Basic.json) -> 'value SetMap.Map.t -> Yojson.Basic.json
end