sig
  type 'a sequence = ('a -> unit) -> unit
  type 'a klist = unit -> [ `Cons of 'a * 'a CCArrayLabels.klist | `Nil ]
  type 'a gen = unit -> 'a option
  type 'a equal = 'a -> 'a -> bool
  type 'a ord = 'a -> 'a -> int
  type 'a random_gen = Random.State.t -> 'a
  type 'a printer = Format.formatter -> 'a -> unit
  external make : int -> 'a -> 'a array = "caml_make_vect"
  external create : int -> 'a -> 'a array = "caml_make_vect"
  val init : int -> f:(int -> 'a) -> 'a array
  val make_matrix : dimx:int -> dimy:int -> 'a -> 'a array array
  val create_matrix : dimx:int -> dimy:int -> 'a -> 'a array array
  val append : 'a array -> 'a array -> 'a array
  val concat : 'a array list -> 'a array
  val sub : 'a array -> pos:int -> len:int -> 'a array
  val copy : 'a array -> 'a array
  val fill : 'a array -> pos:int -> len:int -> 'a -> unit
  val to_list : 'a array -> 'a list
  val of_list : 'a list -> 'a array
  val mapi : f:(int -> 'a -> 'b) -> 'a array -> 'b array
  val fold_left : f:('a -> 'b -> 'a) -> init:'a -> 'b array -> 'a
  val fold_right : f:('b -> 'a -> 'a) -> 'b array -> init:'a -> 'a
  val mem : 'a -> set:'a array -> bool
  val memq : 'a -> set:'a array -> bool
  external create_float : int -> float array = "caml_make_float_vect"
  val make_float : int -> float array
  val sort : cmp:('a -> 'a -> int) -> 'a array -> unit
  val stable_sort : cmp:('a -> 'a -> int) -> 'a array -> unit
  val fast_sort : cmp:('a -> 'a -> int) -> 'a array -> unit
  external unsafe_get : 'a array -> int -> 'a = "%array_unsafe_get"
  external unsafe_set : 'a array -> int -> 'a -> unit = "%array_unsafe_set"
  type 'a t = 'a array
  val empty : 'a CCArrayLabels.t
  val equal :
    'a CCArrayLabels.equal -> 'a CCArrayLabels.t CCArrayLabels.equal
  val compare : 'a CCArrayLabels.ord -> 'a CCArrayLabels.t CCArrayLabels.ord
  val get : 'a CCArrayLabels.t -> int -> 'a
  val get_safe : 'a CCArrayLabels.t -> int -> 'a option
  val set : 'a CCArrayLabels.t -> int -> 'a -> unit
  val length : 'a CCArrayLabels.t -> int
  val fold : f:('a -> 'b -> 'a) -> init:'a -> 'b CCArrayLabels.t -> 'a
  val foldi :
    f:('a -> int -> 'b -> 'a) -> init:'a -> 'b CCArrayLabels.t -> 'a
  val fold_while :
    f:('a -> 'b -> 'a * [ `Continue | `Stop ]) ->
    init:'a -> 'b CCArrayLabels.t -> 'a
  val iter : f:('a -> unit) -> 'a CCArrayLabels.t -> unit
  val iteri : f:(int -> 'a -> unit) -> 'a CCArrayLabels.t -> unit
  val blit :
    'a CCArrayLabels.t -> int -> 'a CCArrayLabels.t -> int -> int -> unit
  val reverse_in_place : 'a CCArrayLabels.t -> unit
  val sorted : f:('a -> 'a -> int) -> 'a CCArrayLabels.t -> 'a array
  val sort_indices : f:('a -> 'a -> int) -> 'a CCArrayLabels.t -> int array
  val sort_ranking : f:('a -> 'a -> int) -> 'a CCArrayLabels.t -> int array
  val find : f:('a -> 'b option) -> 'a CCArrayLabels.t -> 'b option
  val findi : f:(int -> 'a -> 'b option) -> 'a CCArrayLabels.t -> 'b option
  val find_idx : f:('a -> bool) -> 'a CCArrayLabels.t -> (int * 'a) option
  val lookup :
    ?cmp:'a CCArrayLabels.ord -> key:'a -> 'a CCArrayLabels.t -> int option
  val lookup_exn :
    ?cmp:'a CCArrayLabels.ord -> key:'a -> 'a CCArrayLabels.t -> int
  val bsearch :
    ?cmp:('a -> 'a -> int) ->
    key:'a ->
    'a CCArrayLabels.t ->
    [ `All_bigger | `All_lower | `At of int | `Empty | `Just_after of int ]
  val for_all : f:('a -> bool) -> 'a CCArrayLabels.t -> bool
  val for_all2 :
    f:('a -> 'b -> bool) -> 'a CCArrayLabels.t -> 'b CCArrayLabels.t -> bool
  val exists : f:('a -> bool) -> 'a CCArrayLabels.t -> bool
  val exists2 :
    f:('a -> 'b -> bool) -> 'a CCArrayLabels.t -> 'b CCArrayLabels.t -> bool
  val fold2 :
    f:('acc -> 'a -> 'b -> 'acc) ->
    init:'acc -> 'a CCArrayLabels.t -> 'b CCArrayLabels.t -> 'acc
  val iter2 :
    f:('a -> 'b -> unit) -> 'a CCArrayLabels.t -> 'b CCArrayLabels.t -> unit
  val shuffle : 'a CCArrayLabels.t -> unit
  val shuffle_with : Random.State.t -> 'a CCArrayLabels.t -> unit
  val random_choose : 'a CCArrayLabels.t -> 'a CCArrayLabels.random_gen
  val to_seq : 'a CCArrayLabels.t -> 'a CCArrayLabels.sequence
  val to_gen : 'a CCArrayLabels.t -> 'a CCArrayLabels.gen
  val to_klist : 'a CCArrayLabels.t -> 'a CCArrayLabels.klist
  val pp :
    ?sep:string ->
    'a CCArrayLabels.printer -> 'a CCArrayLabels.t CCArrayLabels.printer
  val pp_i :
    ?sep:string ->
    (int -> 'a CCArrayLabels.printer) ->
    'a CCArrayLabels.t CCArrayLabels.printer
  val map : f:('a -> 'b) -> 'a CCArrayLabels.t -> 'b CCArrayLabels.t
  val map2 :
    f:('a -> 'b -> 'c) ->
    'a CCArrayLabels.t -> 'b CCArrayLabels.t -> 'c CCArrayLabels.t
  val rev : 'a CCArrayLabels.t -> 'a CCArrayLabels.t
  val filter : f:('a -> bool) -> 'a CCArrayLabels.t -> 'a CCArrayLabels.t
  val filter_map :
    f:('a -> 'b option) -> 'a CCArrayLabels.t -> 'b CCArrayLabels.t
  val flat_map :
    f:('a -> 'b CCArrayLabels.t) -> 'a CCArrayLabels.t -> 'b array
  val ( >>= ) :
    'a CCArrayLabels.t -> ('a -> 'b CCArrayLabels.t) -> 'b CCArrayLabels.t
  val ( >>| ) : 'a CCArrayLabels.t -> ('a -> 'b) -> 'b CCArrayLabels.t
  val ( >|= ) : 'a CCArrayLabels.t -> ('a -> 'b) -> 'b CCArrayLabels.t
  val except_idx : 'a CCArrayLabels.t -> int -> 'a list
  val ( -- ) : int -> int -> int CCArrayLabels.t
  val ( --^ ) : int -> int -> int CCArrayLabels.t
  val random :
    'a CCArrayLabels.random_gen ->
    'a CCArrayLabels.t CCArrayLabels.random_gen
  val random_non_empty :
    'a CCArrayLabels.random_gen ->
    'a CCArrayLabels.t CCArrayLabels.random_gen
  val random_len :
    int ->
    'a CCArrayLabels.random_gen ->
    'a CCArrayLabels.t CCArrayLabels.random_gen
  module type MONO_ARRAY =
    sig
      type elt
      type t
      val length : CCArrayLabels.MONO_ARRAY.t -> int
      val get :
        CCArrayLabels.MONO_ARRAY.t -> int -> CCArrayLabels.MONO_ARRAY.elt
      val set :
        CCArrayLabels.MONO_ARRAY.t ->
        int -> CCArrayLabels.MONO_ARRAY.elt -> unit
    end
  val sort_generic :
    (module CCArrayLabels.MONO_ARRAY with type elt = 'elt and type t = 'arr) ->
    ?cmp:('elt -> 'elt -> int) -> 'arr -> unit
end