sig
  type 'a t
  type 'a enumerable = 'a t
  type 'a mappable = 'a t
  exception Invalid_arg of int * string * string
  val create : unit -> 'BatDynArray.t
  val make : int -> 'BatDynArray.t
  val init : int -> (int -> 'a) -> 'BatDynArray.t
  val singleton : '-> 'BatDynArray.t
  val get : 'BatDynArray.t -> int -> 'a
  val set : 'BatDynArray.t -> int -> '-> unit
  val upd : 'BatDynArray.t -> int -> ('-> 'a) -> unit
  val length : 'BatDynArray.t -> int
  val empty : 'BatDynArray.t -> bool
  val first : 'BatDynArray.t -> 'a
  val last : 'BatDynArray.t -> 'a
  val left : 'BatDynArray.t -> int -> 'BatDynArray.t
  val right : 'BatDynArray.t -> int -> 'BatDynArray.t
  val head : 'BatDynArray.t -> int -> 'BatDynArray.t
  val tail : 'BatDynArray.t -> int -> 'BatDynArray.t
  val insert : 'BatDynArray.t -> int -> '-> unit
  val add : 'BatDynArray.t -> '-> unit
  val append : 'BatDynArray.t -> 'BatDynArray.t -> unit
  val delete : 'BatDynArray.t -> int -> unit
  val delete_last : 'BatDynArray.t -> unit
  val delete_range : 'BatDynArray.t -> int -> int -> unit
  val remove_at : int -> 'BatDynArray.t -> unit
  val clear : 'BatDynArray.t -> unit
  val blit :
    'BatDynArray.t -> int -> 'BatDynArray.t -> int -> int -> unit
  val compact : 'BatDynArray.t -> unit
  val enum : 'BatDynArray.t -> 'BatEnum.t
  val of_enum : 'BatEnum.t -> 'BatDynArray.t
  val range : 'BatDynArray.t -> int BatEnum.t
  val to_list : 'BatDynArray.t -> 'a list
  val of_list : 'a list -> 'BatDynArray.t
  val to_array : 'BatDynArray.t -> 'a array
  val of_array : 'a array -> 'BatDynArray.t
  val copy : 'BatDynArray.t -> 'BatDynArray.t
  val sub : 'BatDynArray.t -> int -> int -> 'BatDynArray.t
  val fill : 'BatDynArray.t -> int -> int -> '-> unit
  val split : ('a * 'b) BatDynArray.t -> 'BatDynArray.t * 'BatDynArray.t
  val combine :
    'BatDynArray.t -> 'BatDynArray.t -> ('a * 'b) BatDynArray.t
  val iter : ('-> unit) -> 'BatDynArray.t -> unit
  val iteri : (int -> '-> unit) -> 'BatDynArray.t -> unit
  val map : ('-> 'b) -> 'BatDynArray.t -> 'BatDynArray.t
  val mapi : (int -> '-> 'b) -> 'BatDynArray.t -> 'BatDynArray.t
  val modify : ('-> 'a) -> 'BatDynArray.t -> unit
  val modifyi : (int -> '-> 'a) -> 'BatDynArray.t -> unit
  val fold_left : ('-> '-> 'a) -> '-> 'BatDynArray.t -> 'a
  val fold_right : ('-> '-> 'b) -> 'BatDynArray.t -> '-> 'b
  val fold_lefti : ('-> int -> '-> 'a) -> '-> 'BatDynArray.t -> 'a
  val fold_righti : (int -> '-> '-> 'a) -> 'BatDynArray.t -> '-> 'a
  val reduce : ('-> '-> 'a) -> 'BatDynArray.t -> 'a
  val keep : ('-> bool) -> 'BatDynArray.t -> unit
  val filter : ('-> bool) -> 'BatDynArray.t -> 'BatDynArray.t
  val find_all : ('-> bool) -> 'BatDynArray.t -> 'BatDynArray.t
  val filteri : (int -> '-> bool) -> 'BatDynArray.t -> 'BatDynArray.t
  val filter_map : ('-> 'b option) -> 'BatDynArray.t -> 'BatDynArray.t
  val partition :
    ('-> bool) -> 'BatDynArray.t -> 'BatDynArray.t * 'BatDynArray.t
  val for_all : ('-> bool) -> 'BatDynArray.t -> bool
  val exists : ('-> bool) -> 'BatDynArray.t -> bool
  val find : ('-> bool) -> 'BatDynArray.t -> 'a
  val findi : ('-> bool) -> 'BatDynArray.t -> int
  val index_of : ('-> bool) -> 'BatDynArray.t -> int
  val mem : '-> 'BatDynArray.t -> bool
  val memq : '-> 'BatDynArray.t -> bool
  val rev : 'BatDynArray.t -> 'BatDynArray.t
  val rev_in_place : 'BatDynArray.t -> unit
  val max : 'BatDynArray.t -> 'a
  val min : 'BatDynArray.t -> 'a
  val min_max : 'BatDynArray.t -> 'a * 'a
  val sum : int BatDynArray.t -> int
  val fsum : float BatDynArray.t -> float
  val kahan_sum : float BatDynArray.t -> float
  val avg : int BatDynArray.t -> float
  val favg : float BatDynArray.t -> float
  val iter2 :
    ('-> '-> unit) -> 'BatDynArray.t -> 'BatDynArray.t -> unit
  val iter2i :
    (int -> '-> '-> unit) -> 'BatDynArray.t -> 'BatDynArray.t -> unit
  val map2 :
    ('-> '-> 'c) ->
    'BatDynArray.t -> 'BatDynArray.t -> 'BatDynArray.t
  val map2i :
    (int -> '-> '-> 'c) ->
    'BatDynArray.t -> 'BatDynArray.t -> 'BatDynArray.t
  val for_all2 :
    ('-> '-> bool) -> 'BatDynArray.t -> 'BatDynArray.t -> bool
  val exists2 :
    ('-> '-> bool) -> 'BatDynArray.t -> 'BatDynArray.t -> bool
  val cartesian_product :
    'BatDynArray.t -> 'BatDynArray.t -> ('a * 'b) BatDynArray.t
  type resizer_t = currslots:int -> oldlength:int -> newlength:int -> int
  val set_resizer : 'BatDynArray.t -> BatDynArray.resizer_t -> unit
  val get_resizer : 'BatDynArray.t -> BatDynArray.resizer_t
  val default_resizer : BatDynArray.resizer_t
  val exponential_resizer : BatDynArray.resizer_t
  val step_resizer : int -> BatDynArray.resizer_t
  val conservative_exponential_resizer : BatDynArray.resizer_t
  val create_with : BatDynArray.resizer_t -> 'BatDynArray.t
  val unsafe_get : 'BatDynArray.t -> int -> 'a
  val unsafe_set : 'BatDynArray.t -> int -> '-> unit
  val unsafe_upd : 'BatDynArray.t -> int -> ('-> 'a) -> unit
  val print :
    ?first:string ->
    ?last:string ->
    ?sep:string ->
    ('BatInnerIO.output -> '-> unit) ->
    'BatInnerIO.output -> 'BatDynArray.t -> unit
  module Exceptionless :
    sig
      val find : ('-> bool) -> 'BatDynArray.t -> 'a option
      val findi : ('-> bool) -> 'BatDynArray.t -> int option
    end
  val invariants : 'BatDynArray.t -> unit
  val bool_invariants : 'BatDynArray.t -> bool
end