sig
  module type S =
    sig
      type +'a t
      type key = int
      val empty : 'Ptmap.S.t
      val is_empty : 'Ptmap.S.t -> bool
      val add :
        ?merge:('-> '-> 'a) -> int -> '-> 'Ptmap.S.t -> 'Ptmap.S.t
      val modify : int -> ('a option -> 'a) -> 'Ptmap.S.t -> 'Ptmap.S.t
      val find : int -> 'Ptmap.S.t -> 'a
      val findi_element : (int -> '-> bool) -> 'Ptmap.S.t -> int * 'a
      val find_element : ('-> bool) -> 'Ptmap.S.t -> 'a
      val remove : int -> 'Ptmap.S.t -> 'Ptmap.S.t
      val mem : int -> 'Ptmap.S.t -> bool
      val iter : (int -> '-> unit) -> 'Ptmap.S.t -> unit
      val map : ('-> 'b) -> 'Ptmap.S.t -> 'Ptmap.S.t
      val mapi : (int -> '-> 'b) -> 'Ptmap.S.t -> 'Ptmap.S.t
      val fold : (int -> '-> '-> 'b) -> 'Ptmap.S.t -> '-> 'b
      val compare : ('-> '-> int) -> 'Ptmap.S.t -> 'Ptmap.S.t -> int
      val equal : ('-> '-> bool) -> 'Ptmap.S.t -> 'Ptmap.S.t -> bool
      val merge :
        ('-> '-> 'a) -> 'Ptmap.S.t -> 'Ptmap.S.t -> 'Ptmap.S.t
      val merge_first : 'Ptmap.S.t -> 'Ptmap.S.t -> 'Ptmap.S.t
      val diff :
        ('-> '-> bool) -> 'Ptmap.S.t -> 'Ptmap.S.t -> 'Ptmap.S.t
      val choose_and_remove : 'Ptmap.S.t -> int * 'a * 'Ptmap.S.t
      val inter : 'Ptmap.S.t -> 'Ptmap.S.t -> 'Ptmap.S.t
      val inter_map2 :
        ('-> '-> 'a) -> 'Ptmap.S.t -> 'Ptmap.S.t -> 'Ptmap.S.t
      val keys_subset : 'Ptmap.S.t -> 'Ptmap.S.t -> bool
      val subset : ('-> '-> bool) -> 'Ptmap.S.t -> 'Ptmap.S.t -> bool
      val cardinal : 'Ptmap.S.t -> int
      val exists : (int -> '-> bool) -> 'Ptmap.S.t -> bool
      val filter : ('-> bool) -> 'Ptmap.S.t -> 'Ptmap.S.t
      val filteri : (int -> '-> bool) -> 'Ptmap.S.t -> 'Ptmap.S.t
      val filter_map : ('-> 'b option) -> 'Ptmap.S.t -> 'Ptmap.S.t
      val partition :
        ('-> bool) -> 'Ptmap.S.t -> 'Ptmap.S.t * 'Ptmap.S.t
      val elements : 'Ptmap.S.t -> (int * 'a) list
    end
  type +'a t
  type key = int
  val empty : 'a t
  val is_empty : 'a t -> bool
  val add : ?merge:('-> '-> 'a) -> int -> '-> 'a t -> 'a t
  val modify : int -> ('a option -> 'a) -> 'a t -> 'a t
  val find : int -> 'a t -> 'a
  val findi_element : (int -> '-> bool) -> 'a t -> int * 'a
  val find_element : ('-> bool) -> 'a t -> 'a
  val remove : int -> 'a t -> 'a t
  val mem : int -> 'a t -> bool
  val iter : (int -> '-> unit) -> 'a t -> unit
  val map : ('-> 'b) -> 'a t -> 'b t
  val mapi : (int -> '-> 'b) -> 'a t -> 'b t
  val fold : (int -> '-> '-> 'b) -> 'a t -> '-> 'b
  val compare : ('-> '-> int) -> 'a t -> 'a t -> int
  val equal : ('-> '-> bool) -> 'a t -> 'a t -> bool
  val merge : ('-> '-> 'a) -> 'a t -> 'a t -> 'a t
  val merge_first : 'a t -> 'a t -> 'a t
  val diff : ('-> '-> bool) -> 'a t -> 'a t -> 'a t
  val choose_and_remove : 'a t -> int * 'a * 'a t
  val inter : 'a t -> 'a t -> 'a t
  val inter_map2 : ('-> '-> 'a) -> 'a t -> 'a t -> 'a t
  val keys_subset : 'a t -> 'a t -> bool
  val subset : ('-> '-> bool) -> 'a t -> 'a t -> bool
  val cardinal : 'a t -> int
  val exists : (int -> '-> bool) -> 'a t -> bool
  val filter : ('-> bool) -> 'a t -> 'a t
  val filteri : (int -> '-> bool) -> 'a t -> 'a t
  val filter_map : ('-> 'b option) -> 'a t -> 'b t
  val partition : ('-> bool) -> 'a t -> 'a t * 'a t
  val elements : 'a t -> (int * 'a) list
end