sig
  type 'a t
  val empty : 'Gen_intf.S.t
  val singleton : '-> 'Gen_intf.S.t
  val return : '-> 'Gen_intf.S.t
  val repeat : '-> 'Gen_intf.S.t
  val iterate : '-> ('-> 'a) -> 'Gen_intf.S.t
  val unfold : ('-> ('a * 'b) option) -> '-> 'Gen_intf.S.t
  val init : ?limit:int -> (int -> 'a) -> 'Gen_intf.S.t
  val is_empty : 'Gen_intf.S.t -> bool
  val fold : ('-> '-> 'b) -> '-> 'Gen_intf.S.t -> 'b
  val reduce : ('-> '-> 'a) -> 'Gen_intf.S.t -> 'a
  val scan : ('-> '-> 'b) -> '-> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val unfold_scan :
    ('-> '-> 'b * 'c) -> '-> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val iter : ('-> unit) -> 'Gen_intf.S.t -> unit
  val iteri : (int -> '-> unit) -> 'Gen_intf.S.t -> unit
  val length : 'Gen_intf.S.t -> int
  val map : ('-> 'b) -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val mapi : (int -> '-> 'b) -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val fold_map : ('-> '-> 'b) -> '-> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val append : 'Gen_intf.S.t -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val flatten : 'Gen_intf.gen Gen_intf.S.t -> 'Gen_intf.S.t
  val flat_map :
    ('-> 'Gen_intf.gen) -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val mem : ?eq:('-> '-> bool) -> '-> 'Gen_intf.S.t -> bool
  val take : int -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val drop : int -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val nth : int -> 'Gen_intf.S.t -> 'a
  val take_nth : int -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val filter : ('-> bool) -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val take_while : ('-> bool) -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val fold_while :
    ('-> '-> 'a * [ `Continue | `Stop ]) -> '-> 'Gen_intf.S.t -> 'a
  val drop_while : ('-> bool) -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val filter_map : ('-> 'b option) -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val zip_index : 'Gen_intf.S.t -> (int * 'a) Gen_intf.S.t
  val unzip : ('a * 'b) Gen_intf.S.t -> 'Gen_intf.S.t * 'Gen_intf.S.t
  val partition :
    ('-> bool) -> 'Gen_intf.S.t -> 'Gen_intf.S.t * 'Gen_intf.S.t
  val for_all : ('-> bool) -> 'Gen_intf.S.t -> bool
  val exists : ('-> bool) -> 'Gen_intf.S.t -> bool
  val min : ?lt:('-> '-> bool) -> 'Gen_intf.S.t -> 'a
  val max : ?lt:('-> '-> bool) -> 'Gen_intf.S.t -> 'a
  val eq :
    ?eq:('-> '-> bool) -> 'Gen_intf.S.t -> 'Gen_intf.S.t -> bool
  val lexico :
    ?cmp:('-> '-> int) -> 'Gen_intf.S.t -> 'Gen_intf.S.t -> int
  val compare :
    ?cmp:('-> '-> int) -> 'Gen_intf.S.t -> 'Gen_intf.S.t -> int
  val find : ('-> bool) -> 'Gen_intf.S.t -> 'a option
  val sum : int Gen_intf.S.t -> int
  val map2 :
    ('-> '-> 'c) -> 'Gen_intf.S.t -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val iter2 :
    ('-> '-> unit) -> 'Gen_intf.S.t -> 'Gen_intf.S.t -> unit
  val fold2 :
    ('acc -> '-> '-> 'acc) ->
    'acc -> 'Gen_intf.S.t -> 'Gen_intf.S.t -> 'acc
  val for_all2 :
    ('-> '-> bool) -> 'Gen_intf.S.t -> 'Gen_intf.S.t -> bool
  val exists2 :
    ('-> '-> bool) -> 'Gen_intf.S.t -> 'Gen_intf.S.t -> bool
  val zip_with :
    ('-> '-> 'c) -> 'Gen_intf.S.t -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val zip : 'Gen_intf.S.t -> 'Gen_intf.S.t -> ('a * 'b) Gen_intf.S.t
  val merge : 'Gen_intf.gen Gen_intf.S.t -> 'Gen_intf.S.t
  val intersection :
    ?cmp:('-> '-> int) ->
    'Gen_intf.S.t -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val sorted_merge :
    ?cmp:('-> '-> int) ->
    'Gen_intf.S.t -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val sorted_merge_n :
    ?cmp:('-> '-> int) -> 'Gen_intf.S.t list -> 'Gen_intf.S.t
  val tee : ?n:int -> 'Gen_intf.S.t -> 'Gen_intf.gen list
  val round_robin : ?n:int -> 'Gen_intf.S.t -> 'Gen_intf.gen list
  val interleave : 'Gen_intf.S.t -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val intersperse : '-> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val product : 'Gen_intf.S.t -> 'Gen_intf.S.t -> ('a * 'b) Gen_intf.S.t
  val group :
    ?eq:('-> '-> bool) -> 'Gen_intf.S.t -> 'a list Gen_intf.S.t
  val uniq : ?eq:('-> '-> bool) -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val sort : ?cmp:('-> '-> int) -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val sort_uniq :
    ?cmp:('-> '-> int) -> 'Gen_intf.S.t -> 'Gen_intf.S.t
  val chunks : int -> 'Gen_intf.S.t -> 'a array Gen_intf.S.t
  val permutations : 'Gen_intf.S.t -> 'a list Gen_intf.S.t
  val permutations_heap : 'Gen_intf.S.t -> 'a array Gen_intf.S.t
  val combinations : int -> 'Gen_intf.S.t -> 'a list Gen_intf.S.t
  val power_set : 'Gen_intf.S.t -> 'a list Gen_intf.S.t
  val of_list : 'a list -> 'Gen_intf.S.t
  val to_list : 'Gen_intf.S.t -> 'a list
  val to_rev_list : 'Gen_intf.S.t -> 'a list
  val to_array : 'Gen_intf.S.t -> 'a array
  val of_array : ?start:int -> ?len:int -> 'a array -> 'Gen_intf.S.t
  val of_string : ?start:int -> ?len:int -> string -> char Gen_intf.S.t
  val to_string : char Gen_intf.S.t -> string
  val to_buffer : Buffer.t -> char Gen_intf.S.t -> unit
  val rand_int : int -> int Gen_intf.S.t
  val int_range : ?step:int -> int -> int -> int Gen_intf.S.t
  val lines : char Gen_intf.S.t -> string Gen_intf.S.t
  val unlines : string Gen_intf.S.t -> char Gen_intf.S.t
  module Infix :
    sig
      val ( -- ) : int -> int -> int Gen_intf.S.t
      val ( >>= ) :
        'Gen_intf.S.t -> ('-> 'Gen_intf.gen) -> 'Gen_intf.S.t
      val ( >>| ) : 'Gen_intf.S.t -> ('-> 'b) -> 'Gen_intf.S.t
      val ( >|= ) : 'Gen_intf.S.t -> ('-> 'b) -> 'Gen_intf.S.t
    end
  val ( -- ) : int -> int -> int Gen_intf.S.t
  val ( >>= ) : 'Gen_intf.S.t -> ('-> 'Gen_intf.gen) -> 'Gen_intf.S.t
  val ( >>| ) : 'Gen_intf.S.t -> ('-> 'b) -> 'Gen_intf.S.t
  val ( >|= ) : 'Gen_intf.S.t -> ('-> 'b) -> 'Gen_intf.S.t
  val pp :
    ?start:string ->
    ?stop:string ->
    ?sep:string ->
    ?horizontal:bool ->
    (Format.formatter -> '-> unit) ->
    Format.formatter -> 'Gen_intf.S.t -> unit
end