|  
 | Module Bigarray.Genarraymodule Genarray: type (
The type  Genarray.tis the type of big arrays with variable
     numbers of dimensions.  Any number of dimensions between 1 and 16
     is supported.
     The three type parameters to  
 (float, float32_elt, fortran_layout) Genarray.tis the type of generic big arrays containing 32-bit floats
     in Fortran layout; reads and writes in this array use the
     Caml typefloat.val create : Genarray.create kind layout dimensionsreturns a new big array
     whose element kind is determined by the parameterkind(one offloat32,float64,int8_signed, etc) and whose layout is
     determined by the parameterlayout(one ofc_layoutorfortran_layout).  Thedimensionsparameter is an array of
     integers that indicate the size of the big array in each dimension.
     The length ofdimensionsdetermines the number of dimensions
     of the bigarray.
     For instance,  
     Big arrays returned by  
      val num_dims : 
Return the number of dimensions of the given big array. val dims : Genarray.dims areturns all dimensions of the big arraya,
     as an array of integers of lengthGenarray.num_dims a.val nth_dim : Genarray.nth_dim a nreturns then-th dimension of the
     big arraya.  The first dimension corresponds ton = 0;
     the second dimension corresponds ton = 1; the last dimension,
     ton = Genarray.num_dims a - 1.
     RaiseInvalid_argifnis less than 0 or greater or equal thanGenarray.num_dims a.val kind : 
Return the kind of the given big array. val layout : 
Return the layout of the given big array. val get : 
Read an element of a generic big array.
      Genarray.get a [|i1; ...; iN|]returns the element ofawhose coordinates arei1in the first dimension,i2in
     the second dimension, ...,iNin theN-th dimension.
     If  
     If  val set : 
Assign an element of a generic big array.
      Genarray.set a [|i1; ...; iN|] vstores the valuevin the
     element ofawhose coordinates arei1in the first dimension,i2in the second dimension, ...,iNin theN-th dimension.
     The array  
     If  val sub_left : 
Extract a sub-array of the given big array by restricting the
     first (left-most) dimension.   Genarray.sub_left a ofs lenreturns a big array with the same number of dimensions asa,
     and the same dimensions asa, except the first dimension,
     which corresponds to the interval[ofs ... ofs + len - 1]of the first dimension ofa.  No copying of elements is
     involved: the sub-array and the original array share the same
     storage space.  In other terms, the element at coordinates[|i1; ...; iN|]of the sub-array is identical to the
     element at coordinates[|i1+ofs; ...; iN|]of the original
     arraya.
      val sub_right : 
Extract a sub-array of the given big array by restricting the
     last (right-most) dimension.   Genarray.sub_right a ofs lenreturns a big array with the same number of dimensions asa,
     and the same dimensions asa, except the last dimension,
     which corresponds to the interval[ofs ... ofs + len - 1]of the last dimension ofa.  No copying of elements is
     involved: the sub-array and the original array share the same
     storage space.  In other terms, the element at coordinates[|i1; ...; iN|]of the sub-array is identical to the
     element at coordinates[|i1; ...; iN+ofs|]of the original
     arraya.
      val slice_left : 
Extract a sub-array of lower dimension from the given big array
     by fixing one or several of the first (left-most) coordinates.
      Genarray.slice_left a [|i1; ... ; iM|]returns the ``slice''
     ofaobtained by setting the firstMcoordinates toi1, ...,iM.  IfahasNdimensions, the slice has
     dimensionN - M, and the element at coordinates[|j1; ...; j(N-M)|]in the slice is identical to the element
     at coordinates[|i1; ...; iM; j1; ...; j(N-M)|]in the original
     arraya.  No copying of elements is involved: the slice and
     the original array share the same storage space.
      val slice_right : 
Extract a sub-array of lower dimension from the given big array
     by fixing one or several of the last (right-most) coordinates.
      Genarray.slice_right a [|i1; ... ; iM|]returns the ``slice''
     ofaobtained by setting the lastMcoordinates toi1, ...,iM.  IfahasNdimensions, the slice has
     dimensionN - M, and the element at coordinates[|j1; ...; j(N-M)|]in the slice is identical to the element
     at coordinates[|j1; ...; j(N-M); i1; ...; iM|]in the original
     arraya.  No copying of elements is involved: the slice and
     the original array share the same storage space.
      val blit : 
Copy all elements of a big array in another big array.
      Genarray.blit src dstcopies all elements ofsrcintodst.  Both arrayssrcanddstmust have the same number of
     dimensions and equal dimensions.  Copying a sub-array ofsrcto a sub-array ofdstcan be achieved by applyingGenarray.blitto sub-array or slices ofsrcanddst.val fill : 
Set all elements of a big array to a given value.
      Genarray.fill a vstores the valuevin all elements of
     the big arraya.  Setting only some elements ofatovcan be achieved by applyingGenarray.fillto a sub-array
     or a slice ofa.val map_file : 
Memory mapping of a file as a big array.
      Genarray.map_file fd kind layout shared dimsreturns a big array of kindkind, layoutlayout,
     and dimensions as specified indims.  The data contained in
     this big array are the contents of the file referred to by
     the file descriptorfd(as opened previously withUnix.openfile, for example).  Ifsharedistrue,
     all modifications performed on the array are reflected in
     the file.  This requires thatfdbe opened with write permissions.
     Ifsharedisfalse, modifications performed on the array
     are done in memory only, using copy-on-write of the modified
     pages; the underlying file is not affected.
      
     To adjust automatically the dimensions of the big array to
     the actual size of the file, the major dimension (that is,
     the first dimension for an array with C layout, and the last
     dimension for an array with Fortran layout) can be given as
      
     If all dimensions of the big array are given, the file size is
     matched against the size of the big array.  If the file is larger
     than the big array, only the initial portion of the file is
     mapped to the big array.  If the file is smaller than the big
     array, the file is automatically grown to the size of the big array.
     This requires write permissions on  |