Set.PolyA polymorphic Set.
type 'elt t = ('elt, Comparator.Poly.comparator_witness) tinclude Container.Generic with type ('a, 'b) t := 'a t with type 'a elt := 'aval length : _ t -> intval is_empty : _ t -> boolval iter : 'a t -> f:('a -> unit) -> unitval fold : 'a t -> init:'acc -> f:('acc -> 'a -> 'acc) -> 'accval exists : 'a t -> f:('a -> bool) -> boolval for_all : 'a t -> f:('a -> bool) -> boolval count : 'a t -> f:('a -> bool) -> intval sum : 
  (module Container.Summable with type t = 'sum) ->
  'a t ->
  f:('a -> 'sum) ->
  'sumval find : 'a t -> f:('a -> bool) -> 'a optionval find_map : 'a t -> f:('a -> 'b option) -> 'b optionval to_list : 'a t -> 'a listval to_array : 'a t -> 'a arrayval invariants : 'a t -> boolval mem : 'a t -> 'a -> booloverride Container's mem
val symmetric_diff : 'a t -> 'a t -> ('a, 'a) Either.t Sequence.tmodule Named : sig ... endval fold_until : 
  'a t ->
  init:'acc ->
  f:('acc -> 'a -> ('acc, 'final) Container.Continue_or_stop.t) ->
  finish:('acc -> 'final) ->
  'finalval fold_right : 'a t -> init:'acc -> f:('a -> 'acc -> 'acc) -> 'accval elements : 'a t -> 'a listval min_elt : 'a t -> 'a optionval min_elt_exn : 'a t -> 'aval max_elt : 'a t -> 'a optionval max_elt_exn : 'a t -> 'aval choose : 'a t -> 'a optionval choose_exn : 'a t -> 'aval find_exn : 'a t -> f:('a -> bool) -> 'aval nth : 'a t -> int -> 'a optionval to_sequence : 
  ?order:[ `Increasing | `Decreasing ] ->
  ?greater_or_equal_to:'a ->
  ?less_or_equal_to:'a ->
  'a t ->
  'a Sequence.tval binary_search : 
  'a t ->
  compare:('a -> 'key -> int) ->
  Binary_searchable.Which_target_by_key.t ->
  'key ->
  'a optionval binary_search_segmented : 
  'a t ->
  segment_of:('a -> [ `Left | `Right ]) ->
  Binary_searchable.Which_target_by_segment.t ->
  'a optionval merge_to_sequence : 
  ?order:[ `Increasing | `Decreasing ] ->
  ?greater_or_equal_to:'a ->
  ?less_or_equal_to:'a ->
  'a t ->
  'a t ->
  ('a, 'a) Sequence.Merge_with_duplicates_element.t Sequence.tval empty : 'a tval singleton : 'a -> 'a tval of_list : 'a list -> 'a tval of_sequence : 'a Sequence.t -> 'a tval of_array : 'a array -> 'a tval of_sorted_array : 'a array -> 'a t Or_error.tval of_sorted_array_unchecked : 'a array -> 'a tval of_increasing_iterator_unchecked : len:int -> f:(int -> 'a) -> 'a tThe types of map and filter_map are subtle. The input set, ('a, _) set, reflects the fact that these functions take a set of *any* type, with any comparator, while the output set, ('b, 'cmp) t, reflects that the output set has the particular 'cmp of the creation function. The comparator can come in one of three ways, depending on which set module is used
Set.map -- comparator comes as an argumentSet.Poly.map -- comparator is polymorphic comparisonFoo.Set.map -- comparator is Foo.comparator