sig
type 'a t = { compare : 'a -> 'a -> int; set : 'a Sette.t; }
val empty : ('a -> 'a -> int) -> 'a PSette.t
val is_empty : 'a PSette.t -> bool
val mem : 'a -> 'a PSette.t -> bool
val add : 'a -> 'a PSette.t -> 'a PSette.t
val singleton : ('a -> 'a -> int) -> 'a -> 'a PSette.t
val remove : 'a -> 'a PSette.t -> 'a PSette.t
val union : 'a PSette.t -> 'a PSette.t -> 'a PSette.t
val inter : 'a PSette.t -> 'a PSette.t -> 'a PSette.t
val diff : 'a PSette.t -> 'a PSette.t -> 'a PSette.t
val compare : 'a PSette.t -> 'a PSette.t -> int
val equal : 'a PSette.t -> 'a PSette.t -> bool
val subset : 'a PSette.t -> 'a PSette.t -> bool
val iter : ('a -> unit) -> 'a PSette.t -> unit
val fold : ('a -> 'b -> 'b) -> 'a PSette.t -> 'b -> 'b
val for_all : ('a -> bool) -> 'a PSette.t -> bool
val exists : ('a -> bool) -> 'a PSette.t -> bool
val filter : ('a -> bool) -> 'a PSette.t -> 'a PSette.t
val partition : ('a -> bool) -> 'a PSette.t -> 'a PSette.t * 'a PSette.t
val cardinal : 'a PSette.t -> int
val elements : 'a PSette.t -> 'a list
val min_elt : 'a PSette.t -> 'a
val max_elt : 'a PSette.t -> 'a
val choose : 'a 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 -> 'a -> unit) ->
Format.formatter -> 'a PSette.t -> unit
val make : ('a -> 'a -> int) -> 'a Sette.t -> 'a PSette.t
end