sig
  type 'a sequence = ('-> unit) -> unit
  type 'a gen = unit -> 'a option
  type 'a printer = Format.formatter -> '-> unit
  type 'a ktree = unit -> [ `Nil | `Node of 'a * 'CCHashTrie.ktree list ]
  module Transient :
    sig
      type t
      val create : unit -> CCHashTrie.Transient.t
      val equal : CCHashTrie.Transient.t -> CCHashTrie.Transient.t -> bool
      val frozen : CCHashTrie.Transient.t -> bool
      val active : CCHashTrie.Transient.t -> bool
      val freeze : CCHashTrie.Transient.t -> unit
      val with_ : (CCHashTrie.Transient.t -> 'a) -> 'a
      exception Frozen
    end
  module type S =
    sig
      type key
      type 'a t
      val empty : 'CCHashTrie.S.t
      val is_empty : 'CCHashTrie.S.t -> bool
      val singleton : CCHashTrie.S.key -> '-> 'CCHashTrie.S.t
      val add :
        CCHashTrie.S.key -> '-> 'CCHashTrie.S.t -> 'CCHashTrie.S.t
      val mem : CCHashTrie.S.key -> 'CCHashTrie.S.t -> bool
      val get : CCHashTrie.S.key -> 'CCHashTrie.S.t -> 'a option
      val get_exn : CCHashTrie.S.key -> 'CCHashTrie.S.t -> 'a
      val remove : CCHashTrie.S.key -> 'CCHashTrie.S.t -> 'CCHashTrie.S.t
      val update :
        CCHashTrie.S.key ->
        f:('a option -> 'a option) -> 'CCHashTrie.S.t -> 'CCHashTrie.S.t
      val add_mut :
        id:CCHashTrie.Transient.t ->
        CCHashTrie.S.key -> '-> 'CCHashTrie.S.t -> 'CCHashTrie.S.t
      val remove_mut :
        id:CCHashTrie.Transient.t ->
        CCHashTrie.S.key -> 'CCHashTrie.S.t -> 'CCHashTrie.S.t
      val update_mut :
        id:CCHashTrie.Transient.t ->
        CCHashTrie.S.key ->
        f:('a option -> 'a option) -> 'CCHashTrie.S.t -> 'CCHashTrie.S.t
      val cardinal : 'CCHashTrie.S.t -> int
      val choose : 'CCHashTrie.S.t -> (CCHashTrie.S.key * 'a) option
      val choose_exn : 'CCHashTrie.S.t -> CCHashTrie.S.key * 'a
      val iter :
        f:(CCHashTrie.S.key -> '-> unit) -> 'CCHashTrie.S.t -> unit
      val fold :
        f:('-> CCHashTrie.S.key -> '-> 'b) ->
        x:'-> 'CCHashTrie.S.t -> 'b
      val to_list : 'CCHashTrie.S.t -> (CCHashTrie.S.key * 'a) list
      val add_list :
        'CCHashTrie.S.t ->
        (CCHashTrie.S.key * 'a) list -> 'CCHashTrie.S.t
      val add_list_mut :
        id:CCHashTrie.Transient.t ->
        'CCHashTrie.S.t ->
        (CCHashTrie.S.key * 'a) list -> 'CCHashTrie.S.t
      val of_list : (CCHashTrie.S.key * 'a) list -> 'CCHashTrie.S.t
      val add_seq :
        'CCHashTrie.S.t ->
        (CCHashTrie.S.key * 'a) CCHashTrie.sequence -> 'CCHashTrie.S.t
      val add_seq_mut :
        id:CCHashTrie.Transient.t ->
        'CCHashTrie.S.t ->
        (CCHashTrie.S.key * 'a) CCHashTrie.sequence -> 'CCHashTrie.S.t
      val of_seq :
        (CCHashTrie.S.key * 'a) CCHashTrie.sequence -> 'CCHashTrie.S.t
      val to_seq :
        'CCHashTrie.S.t -> (CCHashTrie.S.key * 'a) CCHashTrie.sequence
      val add_gen :
        'CCHashTrie.S.t ->
        (CCHashTrie.S.key * 'a) CCHashTrie.gen -> 'CCHashTrie.S.t
      val add_gen_mut :
        id:CCHashTrie.Transient.t ->
        'CCHashTrie.S.t ->
        (CCHashTrie.S.key * 'a) CCHashTrie.gen -> 'CCHashTrie.S.t
      val of_gen :
        (CCHashTrie.S.key * 'a) CCHashTrie.gen -> 'CCHashTrie.S.t
      val to_gen :
        'CCHashTrie.S.t -> (CCHashTrie.S.key * 'a) CCHashTrie.gen
      val print :
        CCHashTrie.S.key CCHashTrie.printer ->
        'CCHashTrie.printer -> 'CCHashTrie.S.t CCHashTrie.printer
      val as_tree :
        'CCHashTrie.S.t ->
        [ `L of int * (CCHashTrie.S.key * 'a) list | `N ] CCHashTrie.ktree
    end
  module type KEY =
    sig
      type t
      val equal : CCHashTrie.KEY.t -> CCHashTrie.KEY.t -> bool
      val hash : CCHashTrie.KEY.t -> int
    end
  module Make :
    functor (K : KEY->
      sig
        type key = K.t
        type 'a t
        val empty : 'a t
        val is_empty : 'a t -> bool
        val singleton : key -> '-> 'a t
        val add : key -> '-> 'a t -> 'a t
        val mem : key -> 'a t -> bool
        val get : key -> 'a t -> 'a option
        val get_exn : key -> 'a t -> 'a
        val remove : key -> 'a t -> 'a t
        val update : key -> f:('a option -> 'a option) -> 'a t -> 'a t
        val add_mut : id:Transient.t -> key -> '-> 'a t -> 'a t
        val remove_mut : id:Transient.t -> key -> 'a t -> 'a t
        val update_mut :
          id:Transient.t -> key -> f:('a option -> 'a option) -> 'a t -> 'a t
        val cardinal : 'a t -> int
        val choose : 'a t -> (key * 'a) option
        val choose_exn : 'a t -> key * 'a
        val iter : f:(key -> '-> unit) -> 'a t -> unit
        val fold : f:('-> key -> '-> 'b) -> x:'-> 'a t -> 'b
        val to_list : 'a t -> (key * 'a) list
        val add_list : 'a t -> (key * 'a) list -> 'a t
        val add_list_mut : id:Transient.t -> 'a t -> (key * 'a) list -> 'a t
        val of_list : (key * 'a) list -> 'a t
        val add_seq : 'a t -> (key * 'a) sequence -> 'a t
        val add_seq_mut :
          id:Transient.t -> 'a t -> (key * 'a) sequence -> 'a t
        val of_seq : (key * 'a) sequence -> 'a t
        val to_seq : 'a t -> (key * 'a) sequence
        val add_gen : 'a t -> (key * 'a) gen -> 'a t
        val add_gen_mut : id:Transient.t -> 'a t -> (key * 'a) gen -> 'a t
        val of_gen : (key * 'a) gen -> 'a t
        val to_gen : 'a t -> (key * 'a) gen
        val print : key printer -> 'a printer -> 'a t printer
        val as_tree : 'a t -> [ `L of int * (key * 'a) list | `N ] ktree
      end
  val popcount : int -> int
end