include Set.S
type elttype t
val empty : tval is_empty : t -> boolval mem : elt -> t -> boolval add : elt -> t -> tval singleton : elt -> tval remove : elt -> t -> tval union : t -> t -> tval inter : t -> t -> tval diff : t -> t -> tval compare : t -> t -> intval equal : t -> t -> boolval subset : t -> t -> boolval iter : (elt -> unit) -> t -> unitval map : (elt -> elt) -> t -> tval fold : (elt -> 'a -> 'a) -> t -> 'a -> 'aval for_all : (elt -> bool) -> t -> boolval exists : (elt -> bool) -> t -> boolval filter : (elt -> bool) -> t -> tval partition : (elt -> bool) -> t -> t * tval cardinal : t -> intval elements : t -> elt listval min_elt : t -> eltval min_elt_opt : t -> elt optionval max_elt : t -> eltval max_elt_opt : t -> elt optionval choose : t -> eltval choose_opt : t -> elt optionval split : elt -> t -> t * bool * tval find : elt -> t -> eltval find_opt : elt -> t -> elt optionval find_first : (elt -> bool) -> t -> eltval find_first_opt : (elt -> bool) -> t -> elt optionval find_last : (elt -> bool) -> t -> eltval find_last_opt : (elt -> bool) -> t -> elt optionval of_list : elt list -> t
val of_seq : elt sequence -> tval to_seq : t -> elt sequenceval to_list : t -> elt listval of_list : elt list -> t