sig
  type ('a, 'b) t = ('a, 'b) Extlib.MultiPMap.t
  val empty : ('a, 'b) t
  val is_empty : ('a, 'b) t -> bool
  val create : ('-> '-> int) -> ('-> '-> int) -> ('a, 'b) t
  val add : '-> '-> ('a, 'b) t -> ('a, 'b) t
  val find : '-> ('a, 'b) t -> 'Extlib.PSet.t
  val remove_all : '-> ('a, 'b) t -> ('a, 'b) t
  val remove : '-> '-> ('a, 'b) t -> ('a, 'b) t
  val mem : '-> ('a, 'b) t -> bool
  val iter : ('-> 'Extlib.PSet.t -> unit) -> ('a, 'b) t -> unit
  val map :
    ('Extlib.PSet.t -> 'Extlib.PSet.t) ->
    (('-> '-> int) -> '-> '-> int) -> ('c, 'a) t -> ('c, 'b) t
  val mapi :
    ('-> 'Extlib.PSet.t -> 'Extlib.PSet.t) ->
    (('-> '-> int) -> '-> '-> int) -> ('a, 'b) t -> ('a, 'c) t
  val fold : ('Extlib.PSet.t -> '-> 'b) -> ('c, 'a) t -> '-> 'b
  val foldi : ('-> 'Extlib.PSet.t -> '-> 'c) -> ('a, 'b) t -> '-> 'c
  val enum : ('a, 'b) t -> ('a * 'b) Extlib.Enum.t
  val of_enum :
    ?keys:('-> '-> int) ->
    ?data:('-> '-> int) -> ('a * 'b) Extlib.Enum.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
  val print :
    ?first:string ->
    ?last:string ->
    ?sep:string ->
    ('Extlib.InnerIO.output -> '-> unit) ->
    ('Extlib.InnerIO.output -> '-> unit) ->
    'Extlib.InnerIO.output -> ('b, 'c) t -> unit
end