sig
  type 'a t = { compare : '-> '-> int; set : 'Sette.t; }
  val empty : ('-> '-> int) -> 'PSette.t
  val is_empty : 'PSette.t -> bool
  val mem : '-> 'PSette.t -> bool
  val add : '-> 'PSette.t -> 'PSette.t
  val singleton : ('-> '-> int) -> '-> 'PSette.t
  val remove : '-> 'PSette.t -> 'PSette.t
  val union : 'PSette.t -> 'PSette.t -> 'PSette.t
  val inter : 'PSette.t -> 'PSette.t -> 'PSette.t
  val diff : 'PSette.t -> 'PSette.t -> 'PSette.t
  val compare : 'PSette.t -> 'PSette.t -> int
  val equal : 'PSette.t -> 'PSette.t -> bool
  val subset : 'PSette.t -> 'PSette.t -> bool
  val iter : ('-> unit) -> 'PSette.t -> unit
  val fold : ('-> '-> 'b) -> 'PSette.t -> '-> 'b
  val for_all : ('-> bool) -> 'PSette.t -> bool
  val exists : ('-> bool) -> 'PSette.t -> bool
  val filter : ('-> bool) -> 'PSette.t -> 'PSette.t
  val partition : ('-> bool) -> 'PSette.t -> 'PSette.t * 'PSette.t
  val cardinal : 'PSette.t -> int
  val elements : 'PSette.t -> 'a list
  val min_elt : 'PSette.t -> 'a
  val max_elt : 'PSette.t -> 'a
  val choose : 'PSette.t -> 'a
  val print :
    ?first:(unit, Format.formatter, unit) Pervasives.format ->
    ?sep:(unit, Format.formatter, unit) Pervasives.format ->
    ?last:(unit, Format.formatter, unit) Pervasives.format ->
    (Format.formatter -> '-> unit) ->
    Format.formatter -> 'PSette.t -> unit
  val make : ('-> '-> int) -> 'Sette.t -> 'PSette.t
end