sig
  module type Foldable =
    sig type t type data val init : t val f : t -> data -> t end
  module type S =
    sig
      type in_value
      type out_value
      type 'key t = private ('key, out_value) Core.Std.Map.Poly.t
      type 'a _in_value = in_value
      type 'a _out_value = out_value
      type ('a, 'b) _t = 'a t
      val empty : 'a t
      val singleton : '-> in_value -> 'a t
      val is_empty : 'a t -> bool
      val length : 'a t -> int
      val add : key:'-> data:in_value -> 'a t -> 'a t
      val find : 'a t -> '-> out_value
      val remove : 'a t -> '-> 'a t
      val set : key:'-> data:out_value -> 'a t -> 'a t
      val mem : 'a t -> '-> bool
      val iter : 'a t -> f:(key:'-> data:out_value -> unit) -> unit
      val fold :
        'a t -> init:'-> f:(key:'-> data:out_value -> '-> 'b) -> 'b
      val filter : 'a t -> f:(key:'-> data:out_value -> bool) -> 'a t
      val keys : 'a t -> 'a list
      val data : 'a t -> out_value list
      val to_alist : 'a t -> ('a * out_value) list
      val of_list : ('a * in_value) list -> 'a t
      val for_all : 'a t -> f:(out_value -> bool) -> bool
      val exists : 'a t -> f:(out_value -> bool) -> bool
      val to_map : 'a t -> ('a, out_value) Core.Std.Map.Poly.t
      val of_map : ('a, out_value) Core.Std.Map.Poly.t -> 'a t
    end
  module Make :
    functor (Fold : Foldable->
      sig
        type in_value = Fold.data
        type out_value = Fold.t
        type 'key t = 'key Fold_map.Make(Fold).t
        type 'a _in_value = in_value
        type 'a _out_value = out_value
        type ('a, 'b) _t = 'a t
        val empty : 'a t
        val singleton : '-> in_value -> 'a t
        val is_empty : 'a t -> bool
        val length : 'a t -> int
        val add : key:'-> data:in_value -> 'a t -> 'a t
        val find : 'a t -> '-> out_value
        val remove : 'a t -> '-> 'a t
        val set : key:'-> data:out_value -> 'a t -> 'a t
        val mem : 'a t -> '-> bool
        val iter : 'a t -> f:(key:'-> data:out_value -> unit) -> unit
        val fold :
          'a t -> init:'-> f:(key:'-> data:out_value -> '-> 'b) -> 'b
        val filter : 'a t -> f:(key:'-> data:out_value -> bool) -> 'a t
        val keys : 'a t -> 'a list
        val data : 'a t -> out_value list
        val to_alist : 'a t -> ('a * out_value) list
        val of_list : ('a * in_value) list -> 'a t
        val for_all : 'a t -> f:(out_value -> bool) -> bool
        val exists : 'a t -> f:(out_value -> bool) -> bool
        val to_map : 'a t -> ('a, out_value) Core.Std.Map.Poly.t
        val of_map : ('a, out_value) Core.Std.Map.Poly.t -> 'a t
      end
  module type S_sexpable =
    sig
      type in_value
      type out_value
      type 'key t = private ('key, out_value) Core.Std.Map.Poly.t
      type 'a _in_value = in_value
      type 'a _out_value = out_value
      type ('a, 'b) _t = 'a t
      val empty : 'a t
      val singleton : '-> in_value -> 'a t
      val is_empty : 'a t -> bool
      val length : 'a t -> int
      val add : key:'-> data:in_value -> 'a t -> 'a t
      val find : 'a t -> '-> out_value
      val remove : 'a t -> '-> 'a t
      val set : key:'-> data:out_value -> 'a t -> 'a t
      val mem : 'a t -> '-> bool
      val iter : 'a t -> f:(key:'-> data:out_value -> unit) -> unit
      val fold :
        'a t -> init:'-> f:(key:'-> data:out_value -> '-> 'b) -> 'b
      val filter : 'a t -> f:(key:'-> data:out_value -> bool) -> 'a t
      val keys : 'a t -> 'a list
      val data : 'a t -> out_value list
      val to_alist : 'a t -> ('a * out_value) list
      val of_list : ('a * in_value) list -> 'a t
      val for_all : 'a t -> f:(out_value -> bool) -> bool
      val exists : 'a t -> f:(out_value -> bool) -> bool
      val to_map : 'a t -> ('a, out_value) Core.Std.Map.Poly.t
      val of_map : ('a, out_value) Core.Std.Map.Poly.t -> 'a t
      val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
      val sexp_of_t : ('-> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
    end
  module type Foldable_sexpable =
    sig
      type t
      type data
      val init : t
      val f : t -> data -> t
      val t_of_sexp : Sexplib.Sexp.t -> t
      val sexp_of_t : t -> Sexplib.Sexp.t
    end
  module Make_sexpable :
    functor (Fold : Foldable_sexpable->
      sig
        type in_value = Fold.data
        type out_value = Fold.t
        type 'key t = 'key Fold_map.Make_sexpable(Fold).t
        type 'a _in_value = in_value
        type 'a _out_value = out_value
        type ('a, 'b) _t = 'a t
        val empty : 'a t
        val singleton : '-> in_value -> 'a t
        val is_empty : 'a t -> bool
        val length : 'a t -> int
        val add : key:'-> data:in_value -> 'a t -> 'a t
        val find : 'a t -> '-> out_value
        val remove : 'a t -> '-> 'a t
        val set : key:'-> data:out_value -> 'a t -> 'a t
        val mem : 'a t -> '-> bool
        val iter : 'a t -> f:(key:'-> data:out_value -> unit) -> unit
        val fold :
          'a t -> init:'-> f:(key:'-> data:out_value -> '-> 'b) -> 'b
        val filter : 'a t -> f:(key:'-> data:out_value -> bool) -> 'a t
        val keys : 'a t -> 'a list
        val data : 'a t -> out_value list
        val to_alist : 'a t -> ('a * out_value) list
        val of_list : ('a * in_value) list -> 'a t
        val for_all : 'a t -> f:(out_value -> bool) -> bool
        val exists : 'a t -> f:(out_value -> bool) -> bool
        val to_map : 'a t -> ('a, out_value) Core.Std.Map.Poly.t
        val of_map : ('a, out_value) Core.Std.Map.Poly.t -> 'a t
        val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
        val sexp_of_t : ('-> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
      end
  module type Foldable2 =
    sig type 'a t val init : 'a t val f : 'a t -> '-> 'a t end
  module type S2 =
    sig
      type 'a out_value
      type ('key, 'data) t = private
          ('key, 'data out_value) Core.Std.Map.Poly.t
      type 'a _in_value = 'a
      type 'a _out_value = 'a out_value
      type ('a, 'b) _t = ('a, 'b) t
      val empty : ('a, 'b) t
      val singleton : '-> '-> ('a, 'b) t
      val is_empty : ('a, 'b) t -> bool
      val length : ('a, 'b) t -> int
      val add : key:'-> data:'-> ('a, 'b) t -> ('a, 'b) t
      val find : ('a, 'b) t -> '-> 'b out_value
      val remove : ('a, 'b) t -> '-> ('a, 'b) t
      val set : key:'-> data:'b out_value -> ('a, 'b) t -> ('a, 'b) t
      val mem : ('a, 'b) t -> '-> bool
      val iter :
        ('a, 'b) t -> f:(key:'-> data:'b out_value -> unit) -> unit
      val fold :
        ('a, 'b) t ->
        init:'-> f:(key:'-> data:'b out_value -> '-> 'c) -> 'c
      val filter :
        ('a, 'b) t -> f:(key:'-> data:'b out_value -> bool) -> ('a, 'b) t
      val keys : ('a, 'b) t -> 'a list
      val data : ('a, 'b) t -> 'b out_value list
      val to_alist : ('a, 'b) t -> ('a * 'b out_value) list
      val of_list : ('a * 'b) list -> ('a, 'b) t
      val for_all : ('a, 'b) t -> f:('b out_value -> bool) -> bool
      val exists : ('a, 'b) t -> f:('b out_value -> bool) -> bool
      val to_map : ('a, 'b) t -> ('a, 'b out_value) Core.Std.Map.Poly.t
      val of_map : ('a, 'b out_value) Core.Std.Map.Poly.t -> ('a, 'b) t
    end
  module Make2 :
    functor (Fold : Foldable2->
      sig
        type 'a out_value = 'Fold.t
        type ('key, 'data) t = ('key, 'data) Fold_map.Make2(Fold).t
        type 'a _in_value = 'a
        type 'a _out_value = 'a out_value
        type ('a, 'b) _t = ('a, 'b) t
        val empty : ('a, 'b) t
        val singleton : '-> '-> ('a, 'b) t
        val is_empty : ('a, 'b) t -> bool
        val length : ('a, 'b) t -> int
        val add : key:'-> data:'-> ('a, 'b) t -> ('a, 'b) t
        val find : ('a, 'b) t -> '-> 'b out_value
        val remove : ('a, 'b) t -> '-> ('a, 'b) t
        val set : key:'-> data:'b out_value -> ('a, 'b) t -> ('a, 'b) t
        val mem : ('a, 'b) t -> '-> bool
        val iter :
          ('a, 'b) t -> f:(key:'-> data:'b out_value -> unit) -> unit
        val fold :
          ('a, 'b) t ->
          init:'-> f:(key:'-> data:'b out_value -> '-> 'c) -> 'c
        val filter :
          ('a, 'b) t -> f:(key:'-> data:'b out_value -> bool) -> ('a, 'b) t
        val keys : ('a, 'b) t -> 'a list
        val data : ('a, 'b) t -> 'b out_value list
        val to_alist : ('a, 'b) t -> ('a * 'b out_value) list
        val of_list : ('a * 'b) list -> ('a, 'b) t
        val for_all : ('a, 'b) t -> f:('b out_value -> bool) -> bool
        val exists : ('a, 'b) t -> f:('b out_value -> bool) -> bool
        val to_map : ('a, 'b) t -> ('a, 'b out_value) Core.Std.Map.Poly.t
        val of_map : ('a, 'b out_value) Core.Std.Map.Poly.t -> ('a, 'b) t
      end
  module type Foldable2_sexpable =
    sig
      type 'a t
      val init : 'a t
      val f : 'a t -> '-> 'a t
      val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
      val sexp_of_t : ('-> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
    end
  module type S2_sexpable =
    sig
      type 'a out_value
      type ('key, 'data) t = private
          ('key, 'data out_value) Core.Std.Map.Poly.t
      type 'a _in_value = 'a
      type 'a _out_value = 'a out_value
      type ('a, 'b) _t = ('a, 'b) t
      val empty : ('a, 'b) t
      val singleton : '-> '-> ('a, 'b) t
      val is_empty : ('a, 'b) t -> bool
      val length : ('a, 'b) t -> int
      val add : key:'-> data:'-> ('a, 'b) t -> ('a, 'b) t
      val find : ('a, 'b) t -> '-> 'b out_value
      val remove : ('a, 'b) t -> '-> ('a, 'b) t
      val set : key:'-> data:'b out_value -> ('a, 'b) t -> ('a, 'b) t
      val mem : ('a, 'b) t -> '-> bool
      val iter :
        ('a, 'b) t -> f:(key:'-> data:'b out_value -> unit) -> unit
      val fold :
        ('a, 'b) t ->
        init:'-> f:(key:'-> data:'b out_value -> '-> 'c) -> 'c
      val filter :
        ('a, 'b) t -> f:(key:'-> data:'b out_value -> bool) -> ('a, 'b) t
      val keys : ('a, 'b) t -> 'a list
      val data : ('a, 'b) t -> 'b out_value list
      val to_alist : ('a, 'b) t -> ('a * 'b out_value) list
      val of_list : ('a * 'b) list -> ('a, 'b) t
      val for_all : ('a, 'b) t -> f:('b out_value -> bool) -> bool
      val exists : ('a, 'b) t -> f:('b out_value -> bool) -> bool
      val to_map : ('a, 'b) t -> ('a, 'b out_value) Core.Std.Map.Poly.t
      val of_map : ('a, 'b out_value) Core.Std.Map.Poly.t -> ('a, 'b) t
      val t_of_sexp :
        (Sexplib.Sexp.t -> 'a) ->
        (Sexplib.Sexp.t -> 'b) -> Sexplib.Sexp.t -> ('a, 'b) t
      val sexp_of_t :
        ('-> Sexplib.Sexp.t) ->
        ('-> Sexplib.Sexp.t) -> ('a, 'b) t -> Sexplib.Sexp.t
    end
  module Make2_sexpable :
    functor (Fold : Foldable2_sexpable->
      sig
        type 'a out_value = 'Fold.t
        type ('key, 'data) t = ('key, 'data) Fold_map.Make2_sexpable(Fold).t
        type 'a _in_value = 'a
        type 'a _out_value = 'a out_value
        type ('a, 'b) _t = ('a, 'b) t
        val empty : ('a, 'b) t
        val singleton : '-> '-> ('a, 'b) t
        val is_empty : ('a, 'b) t -> bool
        val length : ('a, 'b) t -> int
        val add : key:'-> data:'-> ('a, 'b) t -> ('a, 'b) t
        val find : ('a, 'b) t -> '-> 'b out_value
        val remove : ('a, 'b) t -> '-> ('a, 'b) t
        val set : key:'-> data:'b out_value -> ('a, 'b) t -> ('a, 'b) t
        val mem : ('a, 'b) t -> '-> bool
        val iter :
          ('a, 'b) t -> f:(key:'-> data:'b out_value -> unit) -> unit
        val fold :
          ('a, 'b) t ->
          init:'-> f:(key:'-> data:'b out_value -> '-> 'c) -> 'c
        val filter :
          ('a, 'b) t -> f:(key:'-> data:'b out_value -> bool) -> ('a, 'b) t
        val keys : ('a, 'b) t -> 'a list
        val data : ('a, 'b) t -> 'b out_value list
        val to_alist : ('a, 'b) t -> ('a * 'b out_value) list
        val of_list : ('a * 'b) list -> ('a, 'b) t
        val for_all : ('a, 'b) t -> f:('b out_value -> bool) -> bool
        val exists : ('a, 'b) t -> f:('b out_value -> bool) -> bool
        val to_map : ('a, 'b) t -> ('a, 'b out_value) Core.Std.Map.Poly.t
        val of_map : ('a, 'b out_value) Core.Std.Map.Poly.t -> ('a, 'b) t
        val t_of_sexp :
          (Sexplib.Sexp.t -> 'a) ->
          (Sexplib.Sexp.t -> 'b) -> Sexplib.Sexp.t -> ('a, 'b) t
        val sexp_of_t :
          ('-> Sexplib.Sexp.t) ->
          ('-> Sexplib.Sexp.t) -> ('a, 'b) t -> Sexplib.Sexp.t
      end
  module Cons :
    sig
      type 'a out_value = 'a list
      type ('key, 'data) t = ('key, 'data) Fold_map.Cons.t
      type 'a _in_value = 'a
      type 'a _out_value = 'a out_value
      type ('a, 'b) _t = ('a, 'b) t
      val empty : ('a, 'b) t
      val singleton : '-> '-> ('a, 'b) t
      val is_empty : ('a, 'b) t -> bool
      val length : ('a, 'b) t -> int
      val add : key:'-> data:'-> ('a, 'b) t -> ('a, 'b) t
      val find : ('a, 'b) t -> '-> 'b out_value
      val remove : ('a, 'b) t -> '-> ('a, 'b) t
      val set : key:'-> data:'b out_value -> ('a, 'b) t -> ('a, 'b) t
      val mem : ('a, 'b) t -> '-> bool
      val iter :
        ('a, 'b) t -> f:(key:'-> data:'b out_value -> unit) -> unit
      val fold :
        ('a, 'b) t ->
        init:'-> f:(key:'-> data:'b out_value -> '-> 'c) -> 'c
      val filter :
        ('a, 'b) t -> f:(key:'-> data:'b out_value -> bool) -> ('a, 'b) t
      val keys : ('a, 'b) t -> 'a list
      val data : ('a, 'b) t -> 'b out_value list
      val to_alist : ('a, 'b) t -> ('a * 'b out_value) list
      val of_list : ('a * 'b) list -> ('a, 'b) t
      val for_all : ('a, 'b) t -> f:('b out_value -> bool) -> bool
      val exists : ('a, 'b) t -> f:('b out_value -> bool) -> bool
      val to_map : ('a, 'b) t -> ('a, 'b out_value) Core.Std.Map.Poly.t
      val of_map : ('a, 'b out_value) Core.Std.Map.Poly.t -> ('a, 'b) t
      val t_of_sexp :
        (Sexplib.Sexp.t -> 'a) ->
        (Sexplib.Sexp.t -> 'b) -> Sexplib.Sexp.t -> ('a, 'b) t
      val sexp_of_t :
        ('-> Sexplib.Sexp.t) ->
        ('-> Sexplib.Sexp.t) -> ('a, 'b) t -> Sexplib.Sexp.t
    end
  module Add :
    sig
      type in_value = int
      type out_value = int
      type 'key t = 'key Fold_map.Add.t
      type 'a _in_value = in_value
      type 'a _out_value = out_value
      type ('a, 'b) _t = 'a t
      val empty : 'a t
      val singleton : '-> in_value -> 'a t
      val is_empty : 'a t -> bool
      val length : 'a t -> int
      val add : key:'-> data:in_value -> 'a t -> 'a t
      val find : 'a t -> '-> out_value
      val remove : 'a t -> '-> 'a t
      val set : key:'-> data:out_value -> 'a t -> 'a t
      val mem : 'a t -> '-> bool
      val iter : 'a t -> f:(key:'-> data:out_value -> unit) -> unit
      val fold :
        'a t -> init:'-> f:(key:'-> data:out_value -> '-> 'b) -> 'b
      val filter : 'a t -> f:(key:'-> data:out_value -> bool) -> 'a t
      val keys : 'a t -> 'a list
      val data : 'a t -> out_value list
      val to_alist : 'a t -> ('a * out_value) list
      val of_list : ('a * in_value) list -> 'a t
      val for_all : 'a t -> f:(out_value -> bool) -> bool
      val exists : 'a t -> f:(out_value -> bool) -> bool
      val to_map : 'a t -> ('a, out_value) Core.Std.Map.Poly.t
      val of_map : ('a, out_value) Core.Std.Map.Poly.t -> 'a t
      val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
      val sexp_of_t : ('-> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
    end
  module Multiply :
    sig
      type in_value = int
      type out_value = int
      type 'key t = 'key Fold_map.Multiply.t
      type 'a _in_value = in_value
      type 'a _out_value = out_value
      type ('a, 'b) _t = 'a t
      val empty : 'a t
      val singleton : '-> in_value -> 'a t
      val is_empty : 'a t -> bool
      val length : 'a t -> int
      val add : key:'-> data:in_value -> 'a t -> 'a t
      val find : 'a t -> '-> out_value
      val remove : 'a t -> '-> 'a t
      val set : key:'-> data:out_value -> 'a t -> 'a t
      val mem : 'a t -> '-> bool
      val iter : 'a t -> f:(key:'-> data:out_value -> unit) -> unit
      val fold :
        'a t -> init:'-> f:(key:'-> data:out_value -> '-> 'b) -> 'b
      val filter : 'a t -> f:(key:'-> data:out_value -> bool) -> 'a t
      val keys : 'a t -> 'a list
      val data : 'a t -> out_value list
      val to_alist : 'a t -> ('a * out_value) list
      val of_list : ('a * in_value) list -> 'a t
      val for_all : 'a t -> f:(out_value -> bool) -> bool
      val exists : 'a t -> f:(out_value -> bool) -> bool
      val to_map : 'a t -> ('a, out_value) Core.Std.Map.Poly.t
      val of_map : ('a, out_value) Core.Std.Map.Poly.t -> 'a t
      val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
      val sexp_of_t : ('-> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
    end
end