sig
type 'a t = 'a array
val mem : ?equal:('a -> 'a -> bool) -> 'a t -> 'a -> bool
val length : 'a t -> int
val is_empty : 'a t -> bool
val iter : 'a t -> f:('a -> unit) -> unit
val fold : 'a t -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum
val exists : 'a t -> f:('a -> bool) -> bool
val for_all : 'a t -> f:('a -> bool) -> bool
val count : 'a t -> f:('a -> bool) -> int
val find : 'a t -> f:('a -> bool) -> 'a option
val find_map : 'a t -> f:('a -> 'b option) -> 'b option
val to_list : 'a t -> 'a list
val to_array : 'a t -> 'a array
val max_length : int
external get : 'a t -> int -> 'a = "%array_safe_get"
external set : 'a t -> int -> 'a -> unit = "%array_safe_set"
external unsafe_get : 'a t -> int -> 'a = "%array_unsafe_get"
external unsafe_set : 'a t -> int -> 'a -> unit = "%array_unsafe_set"
val create : len:int -> 'a -> 'a t
val init : int -> f:(int -> 'a) -> 'a t
val make_matrix : dimx:int -> dimy:int -> 'a -> 'a t t
val append : 'a t -> 'a t -> 'a t
val concat : 'a t list -> 'a t
val sub : 'a t -> pos:int -> len:int -> 'a t
val copy : 'a t -> 'a t
val fill : 'a t -> pos:int -> len:int -> 'a -> unit
val blit :
src:'a t -> src_pos:int -> dst:'a t -> dst_pos:int -> len:int -> unit
val of_list : 'a list -> 'a t
val map : f:('a -> 'b) -> 'a t -> 'b t
val iteri : f:(int -> 'a -> unit) -> 'a t -> unit
val mapi : f:(int -> 'a -> 'b) -> 'a t -> 'b t
val foldi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b) -> 'b
val fold_right : 'a t -> f:('a -> 'b -> 'b) -> init:'b -> 'b
val sort : cmp:('a -> 'a -> int) -> 'a t -> unit
val stable_sort : cmp:('a -> 'a -> int) -> 'a t -> unit
val is_sorted : 'a t -> cmp:('a -> 'a -> int) -> bool
val concat_map : 'a t -> f:('a -> 'b array) -> 'b array
val partition_tf : 'a t -> f:('a -> bool) -> 'a t * 'a t
val partitioni_tf : 'a t -> f:(int -> 'a -> bool) -> 'a t * 'a t
val cartesian_product : 'a t -> 'b t -> ('a * 'b) t
val normalize : 'a t -> int -> int
val slice : 'a t -> int -> int -> 'a t
val nget : 'a t -> int -> 'a
val nset : 'a t -> int -> 'a -> unit
val filter_opt : 'a option t -> 'a t
val filter_map : 'a t -> f:('a -> 'b option) -> 'b t
val filter_mapi : 'a t -> f:(int -> 'a -> 'b option) -> 'b t
val iter2_exn : 'a t -> 'b t -> f:('a -> 'b -> unit) -> unit
val map2_exn : 'a t -> 'b t -> f:('a -> 'b -> 'c) -> 'c t
val fold2_exn : 'a t -> 'b t -> init:'c -> f:('c -> 'a -> 'b -> 'c) -> 'c
val for_all2_exn : 'a t -> 'b t -> f:('a -> 'b -> bool) -> bool
val filter : f:('a -> bool) -> 'a t -> 'a t
val filteri : f:(int -> 'a -> bool) -> 'a t -> 'a t
val swap : 'a t -> int -> int -> unit
val rev_inplace : 'a t -> unit
val of_list_rev : 'a list -> 'a t
val of_list_map : 'a list -> f:('a -> 'b) -> 'b t
val of_list_rev_map : 'a list -> f:('a -> 'b) -> 'b t
val replace : 'a t -> int -> f:('a -> 'a) -> unit
val replace_all : 'a t -> f:('a -> 'a) -> unit
val find_exn : 'a t -> f:('a -> bool) -> 'a
val findi : 'a t -> f:(int -> 'a -> bool) -> (int * 'a) option
val findi_exn : 'a t -> f:(int -> 'a -> bool) -> int * 'a
val reduce : 'a t -> f:('a -> 'a -> 'a) -> 'a option
val reduce_exn : 'a t -> f:('a -> 'a -> 'a) -> 'a
val permute : ?random_state:Core.Core_random.State.t -> 'a t -> unit
val combine : 'a t -> 'b t -> ('a * 'b) t
val split : ('a * 'b) t -> 'a t * 'b t
val sorted_copy : 'a t -> cmp:('a -> 'a -> int) -> 'a t
val last : 'a t -> 'a
val empty : unit -> 'a t
val equal : 'a t -> 'a t -> equal:('a -> 'a -> bool) -> bool
module Infix : sig val ( <|> ) : 'a t -> int * int -> 'a t end
val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
val sexp_of_t : ('a -> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
val bin_t : 'a Bin_prot.Type_class.t -> 'a t Bin_prot.Type_class.t
val bin_read_t :
'a Bin_prot.Unsafe_read_c.reader -> 'a t Bin_prot.Read_ml.reader
val bin_read_t_ :
'a Bin_prot.Unsafe_read_c.reader -> 'a t Bin_prot.Unsafe_read_c.reader
val bin_read_t__ :
'a Bin_prot.Unsafe_read_c.reader ->
(int -> 'a t) Bin_prot.Unsafe_read_c.reader
val bin_reader_t :
'a Bin_prot.Type_class.reader -> 'a t Bin_prot.Type_class.reader
val bin_size_t : 'a Bin_prot.Size.sizer -> 'a t Bin_prot.Size.sizer
val bin_write_t :
'a Bin_prot.Unsafe_write_c.writer -> 'a t Bin_prot.Write_ml.writer
val bin_write_t_ :
'a Bin_prot.Unsafe_write_c.writer -> 'a t Bin_prot.Unsafe_write_c.writer
val bin_writer_t :
'a Bin_prot.Type_class.writer -> 'a t Bin_prot.Type_class.writer
val ounit_tests : unit -> OUnit.test
val foldi : init:'a -> 'b array -> f:(int -> 'a -> 'b -> 'a) -> 'a
val random_split :
?random_state:Core.Std.Random.State.t ->
'a array -> p:float -> 'a array * 'a array
val random_sub :
?random_state:Core.Std.Random.State.t -> 'a array -> p:float -> 'a array
module Access_control :
sig
type ('a, 'z) any = ('a, 'z) Extended_array.Access_control.any
module Immutable :
sig
type 'a t = ('a, Core.Std.immutable) any
val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
val sexp_of_t : ('a -> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
val bin_size_t : ('a, 'a t) Bin_prot.Size.sizer1
val bin_write_t : ('a, 'a t) Bin_prot.Map_to_safe.writer1
val bin_write_t_ : ('a, 'a t) Bin_prot.Unsafe_write_c.writer1
val bin_read_t : ('a, 'a t) Bin_prot.Map_to_safe.reader1
val bin_read_t_ : ('a, 'a t) Bin_prot.Unsafe_read_c.reader1
val bin_read_t__ : ('a, int -> 'a t) Bin_prot.Unsafe_read_c.reader1
val bin_writer_t : ('a, 'a t) Bin_prot.Type_class.S1.writer
val bin_reader_t : ('a, 'a t) Bin_prot.Type_class.S1.reader
val bin_t : ('a, 'a t) Bin_prot.Type_class.S1.t
end
module Read_only :
sig
type 'a t = ('a, Core.Std.read_only) any
val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
val sexp_of_t : ('a -> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
val bin_size_t : ('a, 'a t) Bin_prot.Size.sizer1
val bin_write_t : ('a, 'a t) Bin_prot.Map_to_safe.writer1
val bin_write_t_ : ('a, 'a t) Bin_prot.Unsafe_write_c.writer1
val bin_read_t : ('a, 'a t) Bin_prot.Map_to_safe.reader1
val bin_read_t_ : ('a, 'a t) Bin_prot.Unsafe_read_c.reader1
val bin_read_t__ : ('a, int -> 'a t) Bin_prot.Unsafe_read_c.reader1
val bin_writer_t : ('a, 'a t) Bin_prot.Type_class.S1.writer
val bin_reader_t : ('a, 'a t) Bin_prot.Type_class.S1.reader
val bin_t : ('a, 'a t) Bin_prot.Type_class.S1.t
end
module Read_write :
sig
type 'a t = ('a, Core.Std.read_write) any
val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
val sexp_of_t : ('a -> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
val bin_size_t : ('a, 'a t) Bin_prot.Size.sizer1
val bin_write_t : ('a, 'a t) Bin_prot.Map_to_safe.writer1
val bin_write_t_ : ('a, 'a t) Bin_prot.Unsafe_write_c.writer1
val bin_read_t : ('a, 'a t) Bin_prot.Map_to_safe.reader1
val bin_read_t_ : ('a, 'a t) Bin_prot.Unsafe_read_c.reader1
val bin_read_t__ : ('a, int -> 'a t) Bin_prot.Unsafe_read_c.reader1
val bin_writer_t : ('a, 'a t) Bin_prot.Type_class.S1.writer
val bin_reader_t : ('a, 'a t) Bin_prot.Type_class.S1.reader
val bin_t : ('a, 'a t) Bin_prot.Type_class.S1.t
end
type 'a t = 'a Immutable.t
val t_of_sexp : (Sexplib.Sexp.t -> 'a) -> Sexplib.Sexp.t -> 'a t
val sexp_of_t : ('a -> Sexplib.Sexp.t) -> 'a t -> Sexplib.Sexp.t
val bin_size_t : ('a, 'a t) Bin_prot.Size.sizer1
val bin_write_t : ('a, 'a t) Bin_prot.Map_to_safe.writer1
val bin_write_t_ : ('a, 'a t) Bin_prot.Unsafe_write_c.writer1
val bin_read_t : ('a, 'a t) Bin_prot.Map_to_safe.reader1
val bin_read_t_ : ('a, 'a t) Bin_prot.Unsafe_read_c.reader1
val bin_read_t__ : ('a, int -> 'a t) Bin_prot.Unsafe_read_c.reader1
val bin_writer_t : ('a, 'a t) Bin_prot.Type_class.S1.writer
val bin_reader_t : ('a, 'a t) Bin_prot.Type_class.S1.reader
val bin_t : ('a, 'a t) Bin_prot.Type_class.S1.t
val create : len:int -> 'a -> ('a, 'b) any
val init : int -> f:(int -> 'a) -> ('a, 'b) any
val of_array : 'a array -> 'a Read_write.t
val of_array_copy : 'a array -> ('a, 'b) any
val to_array_copy : ('a, 'b) any -> 'a array
val get : ('a, 'b) any -> int -> 'a
val set : 'a Read_write.t -> int -> 'a -> unit
val append : ('a, 'b) any -> ('a, 'c) any -> ('a, 'd) any
val copy : ('a, 'b) any -> ('a, 'c) any
val map : f:('a -> 'b) -> ('a, 'c) any -> ('b, 'd) any
val mapi : f:(int -> 'a -> 'b) -> ('a, 'c) any -> ('b, 'd) any
val iteri : f:(int -> 'a -> unit) -> ('a, 'b) any -> unit
val filter_opt : ('a option, 'b) any -> ('a, 'c) any
val filter_map : ('a, 'c) any -> f:('a -> 'b option) -> ('b, 'd) any
val filter_mapi :
('a, 'c) any -> f:(int -> 'a -> 'b option) -> ('b, 'd) any
val map2_exn :
('a, 'd) any -> ('b, 'e) any -> f:('a -> 'b -> 'c) -> ('c, 'f) any
val findi : ('a, 'b) any -> f:(int -> 'a -> bool) -> (int * 'a) option
val blit :
src:('a, 'b) any ->
src_pos:int -> dst:'a Read_write.t -> dst_pos:int -> len:int -> unit
val permute :
?random_state:Core.Std.Random.State.t -> 'a Read_write.t -> unit
val fill : 'a Read_write.t -> pos:int -> len:int -> 'a -> unit
val of_list : 'a list -> ('a, 'b) any
val mem : ?equal:('a -> 'a -> bool) -> ('a, 'b) any -> 'a -> bool
val length : ('a, 'b) any -> int
val is_empty : ('a, 'b) any -> bool
val iter : ('a, 'b) any -> f:('a -> unit) -> unit
val fold :
('a, 'b) any -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum
val exists : ('a, 'b) any -> f:('a -> bool) -> bool
val for_all : ('a, 'b) any -> f:('a -> bool) -> bool
val count : ('a, 'b) any -> f:('a -> bool) -> int
val find : ('a, 'b) any -> f:('a -> bool) -> 'a option
val find_map : ('a, 'c) any -> f:('a -> 'b option) -> 'b option
val to_list : ('a, 'b) any -> 'a list
val to_array : ('a, 'b) any -> 'a array
val bin_any :
'a Core.Std.Bin_prot.Type_class.t ->
'z Core.Std.Bin_prot.Type_class.t ->
('a, 'z) any Core.Std.Bin_prot.Type_class.t
val bin_read_any :
'a Core.Std.Bin_prot.Unsafe_read_c.reader ->
'z Core.Std.Bin_prot.Unsafe_read_c.reader ->
('a, 'z) any Core.Std.Bin_prot.Read_ml.reader
val bin_read_any_ :
'a Core.Std.Bin_prot.Unsafe_read_c.reader ->
'z Core.Std.Bin_prot.Unsafe_read_c.reader ->
('a, 'z) any Core.Std.Bin_prot.Unsafe_read_c.reader
val bin_read_any__ :
'a Core.Std.Bin_prot.Unsafe_read_c.reader ->
'z Core.Std.Bin_prot.Unsafe_read_c.reader ->
(int -> ('a, 'z) any) Core.Std.Bin_prot.Unsafe_read_c.reader
val bin_reader_any :
'a Core.Std.Bin_prot.Type_class.reader ->
'z Core.Std.Bin_prot.Type_class.reader ->
('a, 'z) any Core.Std.Bin_prot.Type_class.reader
val bin_size_any :
'a Core.Std.Bin_prot.Size.sizer ->
'z Core.Std.Bin_prot.Size.sizer ->
('a, 'z) any Core.Std.Bin_prot.Size.sizer
val bin_write_any :
'a Core.Std.Bin_prot.Unsafe_write_c.writer ->
'z Core.Std.Bin_prot.Unsafe_write_c.writer ->
('a, 'z) any Core.Std.Bin_prot.Write_ml.writer
val bin_write_any_ :
'a Core.Std.Bin_prot.Unsafe_write_c.writer ->
'z Core.Std.Bin_prot.Unsafe_write_c.writer ->
('a, 'z) any Core.Std.Bin_prot.Unsafe_write_c.writer
val bin_writer_any :
'a Core.Std.Bin_prot.Type_class.writer ->
'z Core.Std.Bin_prot.Type_class.writer ->
('a, 'z) any Core.Std.Bin_prot.Type_class.writer
val any_of_sexp :
(Sexplib.Sexp.t -> 'a) ->
(Sexplib.Sexp.t -> 'z) -> Sexplib.Sexp.t -> ('a, 'z) any
val sexp_of_any :
('a -> Sexplib.Sexp.t) ->
('z -> Sexplib.Sexp.t) -> ('a, 'z) any -> Sexplib.Sexp.t
end
val ounit_tests : unit -> OUnit.test
end