1Stdlib.Bigarray(3)               OCaml library              Stdlib.Bigarray(3)
2
3
4

NAME

6       Stdlib.Bigarray - no description
7

Module

9       Module   Stdlib.Bigarray
10

Documentation

12       Module Bigarray
13        : (module Stdlib__Bigarray)
14
15
16
17
18
19
20
21
22
23   Element kinds
24       Bigarrays can contain elements of the following kinds:
25
26       -IEEE  single  precision  (32  bits)  floating-point  numbers  ( Bigar‐
27       ray.float32_elt ),
28
29       -IEEE double  precision  (64  bits)  floating-point  numbers  (  Bigar‐
30       ray.float64_elt ),
31
32       -IEEE  single  precision (2 * 32 bits) floating-point complex numbers (
33       Bigarray.complex32_elt ),
34
35       -IEEE double precision (2 * 64 bits) floating-point complex  numbers  (
36       Bigarray.complex64_elt ),
37
38       -8-bit  integers (signed or unsigned) ( Bigarray.int8_signed_elt or Bi‐
39       garray.int8_unsigned_elt ),
40
41       -16-bit integers (signed or unsigned)  (  Bigarray.int16_signed_elt  or
42       Bigarray.int16_unsigned_elt ),
43
44       -OCaml  integers  (signed,  31 bits on 32-bit architectures, 63 bits on
45       64-bit architectures) ( Bigarray.int_elt ),
46
47       -32-bit signed integers ( Bigarray.int32_elt ),
48
49       -64-bit signed integers ( Bigarray.int64_elt ),
50
51       -platform-native signed integers (32 bits on 32-bit  architectures,  64
52       bits on 64-bit architectures) ( Bigarray.nativeint_elt ).
53
54       Each  element kind is represented at the type level by one of the *_elt
55       types defined below (defined with a single constructor instead  of  ab‐
56       stract types for technical injectivity reasons).
57
58       type float32_elt =
59        | Float32_elt
60
61
62
63
64       type float64_elt =
65        | Float64_elt
66
67
68
69
70       type int8_signed_elt =
71        | Int8_signed_elt
72
73
74
75
76       type int8_unsigned_elt =
77        | Int8_unsigned_elt
78
79
80
81
82       type int16_signed_elt =
83        | Int16_signed_elt
84
85
86
87
88       type int16_unsigned_elt =
89        | Int16_unsigned_elt
90
91
92
93
94       type int32_elt =
95        | Int32_elt
96
97
98
99
100       type int64_elt =
101        | Int64_elt
102
103
104
105
106       type int_elt =
107        | Int_elt
108
109
110
111
112       type nativeint_elt =
113        | Nativeint_elt
114
115
116
117
118       type complex32_elt =
119        | Complex32_elt
120
121
122
123
124       type complex64_elt =
125        | Complex64_elt
126
127
128
129
130       type ('a, 'b) kind =
131        | Float32 : (float, float32_elt) kind
132        | Float64 : (float, float64_elt) kind
133        | Int8_signed : (int, int8_signed_elt) kind
134        | Int8_unsigned : (int, int8_unsigned_elt) kind
135        | Int16_signed : (int, int16_signed_elt) kind
136        | Int16_unsigned : (int, int16_unsigned_elt) kind
137        | Int32 : (int32, int32_elt) kind
138        | Int64 : (int64, int64_elt) kind
139        | Int : (int, int_elt) kind
140        | Nativeint : (nativeint, nativeint_elt) kind
141        | Complex32 : (Complex.t, complex32_elt) kind
142        | Complex64 : (Complex.t, complex64_elt) kind
143        | Char : (char, int8_unsigned_elt) kind
144
145
146       To  each element kind is associated an OCaml type, which is the type of
147       OCaml values that can be stored in the Bigarray or read back  from  it.
148       This type is not necessarily the same as the type of the array elements
149       proper: for instance, a Bigarray whose elements are of kind float32_elt
150       contains  32-bit single precision floats, but reading or writing one of
151       its elements from OCaml uses the OCaml type float  ,  which  is  64-bit
152       double precision floats.
153
154       The  GADT type ('a, 'b) kind captures this association of an OCaml type
155       'a for values read or written in the Bigarray, and of an  element  kind
156       'b  which represents the actual contents of the Bigarray. Its construc‐
157       tors list all possible associations of OCaml types with element  kinds,
158       and are re-exported below for backward-compatibility reasons.
159
160       Using  a  generalized  algebraic  datatype  (GADT)  here allows writing
161       well-typed polymorphic functions whose return type depend on the  argu‐
162       ment type, such as:
163
164
165         let zero : type a b. (a, b) kind -> a = function
166           | Float32 -> 0.0 | Complex32 -> Complex.zero
167           | Float64 -> 0.0 | Complex64 -> Complex.zero
168           | Int8_signed -> 0 | Int8_unsigned -> 0
169           | Int16_signed -> 0 | Int16_unsigned -> 0
170           | Int32 -> 0l | Int64 -> 0L
171           | Int -> 0 | Nativeint -> 0n
172           | Char -> '\000'
173
174
175
176
177       val float32 : (float, float32_elt) kind
178
179       See Bigarray.char .
180
181
182
183       val float64 : (float, float64_elt) kind
184
185       See Bigarray.char .
186
187
188
189       val complex32 : (Complex.t, complex32_elt) kind
190
191       See Bigarray.char .
192
193
194
195       val complex64 : (Complex.t, complex64_elt) kind
196
197       See Bigarray.char .
198
199
200
201       val int8_signed : (int, int8_signed_elt) kind
202
203       See Bigarray.char .
204
205
206
207       val int8_unsigned : (int, int8_unsigned_elt) kind
208
209       See Bigarray.char .
210
211
212
213       val int16_signed : (int, int16_signed_elt) kind
214
215       See Bigarray.char .
216
217
218
219       val int16_unsigned : (int, int16_unsigned_elt) kind
220
221       See Bigarray.char .
222
223
224
225       val int : (int, int_elt) kind
226
227       See Bigarray.char .
228
229
230
231       val int32 : (int32, int32_elt) kind
232
233       See Bigarray.char .
234
235
236
237       val int64 : (int64, int64_elt) kind
238
239       See Bigarray.char .
240
241
242
243       val nativeint : (nativeint, nativeint_elt) kind
244
245       See Bigarray.char .
246
247
248
249       val char : (char, int8_unsigned_elt) kind
250
251       As  shown  by  the  types  of  the  values  above,  Bigarrays  of  kind
252       float32_elt and float64_elt are accessed using the OCaml type  float  .
253       Bigarrays  of  complex kinds complex32_elt , complex64_elt are accessed
254       with the OCaml type Complex.t . Bigarrays of integer kinds are accessed
255       using the smallest OCaml integer type large enough to represent the ar‐
256       ray elements: int for 8- and  16-bit  integer  Bigarrays,  as  well  as
257       OCaml-integer  Bigarrays; int32 for 32-bit integer Bigarrays; int64 for
258       64-bit integer Bigarrays; and nativeint for platform-native integer Bi‐
259       garrays.   Finally, Bigarrays of kind int8_unsigned_elt can also be ac‐
260       cessed as arrays of characters instead of arrays of small integers,  by
261       using the kind value char instead of int8_unsigned .
262
263
264
265       val kind_size_in_bytes : ('a, 'b) kind -> int
266
267
268       kind_size_in_bytes k is the number of bytes used to store an element of
269       type k .
270
271
272       Since 4.03.0
273
274
275
276
277   Array layouts
278       type c_layout =
279        | C_layout_typ
280
281
282       See Bigarray.fortran_layout .
283
284
285       type fortran_layout =
286        | Fortran_layout_typ
287
288
289       To facilitate interoperability with existing C and Fortran  code,  this
290       library  supports  two different memory layouts for Bigarrays, one com‐
291       patible with the C conventions, the other compatible with  the  Fortran
292       conventions.
293
294       In  the C-style layout, array indices start at 0, and multi-dimensional
295       arrays are laid out in row-major format.  That  is,  for  a  two-dimen‐
296       sional  array, all elements of row 0 are contiguous in memory, followed
297       by all elements of row 1, etc.  In other terms, the array  elements  at
298       (x,y) and (x, y+1) are adjacent in memory.
299
300       In the Fortran-style layout, array indices start at 1, and multi-dimen‐
301       sional arrays are laid out in column-major  format.   That  is,  for  a
302       two-dimensional  array, all elements of column 0 are contiguous in mem‐
303       ory, followed by all elements of column 1, etc.  In  other  terms,  the
304       array elements at (x,y) and (x+1, y) are adjacent in memory.
305
306       Each  layout style is identified at the type level by the phantom types
307       Bigarray.c_layout and Bigarray.fortran_layout respectively.
308
309
310
311
312   Supported layouts
313       The GADT type 'a layout represents one of the two supported memory lay‐
314       outs:  C-style  or  Fortran-style.  Its constructors are re-exported as
315       values below for backward-compatibility reasons.
316
317       type 'a layout =
318        | C_layout : c_layout layout
319        | Fortran_layout : fortran_layout layout
320
321
322
323
324
325       val c_layout : c_layout layout
326
327
328
329
330       val fortran_layout : fortran_layout layout
331
332
333
334
335
336   Generic arrays (of arbitrarily many dimensions)
337       module Genarray : sig end
338
339
340
341
342
343
344   Zero-dimensional arrays
345       module Array0 : sig end
346
347
348       Zero-dimensional arrays. The Array0 structure provides operations simi‐
349       lar  to  those  of  Bigarray.Genarray  , but specialized to the case of
350       zero-dimensional arrays that only contain a single scalar value.  Stat‐
351       ically  knowing the number of dimensions of the array allows faster op‐
352       erations, and more precise static type-checking.
353
354
355       Since 4.05.0
356
357
358
359
360   One-dimensional arrays
361       module Array1 : sig end
362
363
364       One-dimensional arrays. The Array1 structure provides operations  simi‐
365       lar  to  those  of  Bigarray.Genarray  , but specialized to the case of
366       one-dimensional  arrays.   (The  Bigarray.Array2  and   Bigarray.Array3
367       structures  below provide operations specialized for two- and three-di‐
368       mensional arrays.)  Statically knowing the number of dimensions of  the
369       array allows faster operations, and more precise static type-checking.
370
371
372
373
374   Two-dimensional arrays
375       module Array2 : sig end
376
377
378       Two-dimensional  arrays. The Array2 structure provides operations simi‐
379       lar to those of Bigarray.Genarray , but  specialized  to  the  case  of
380       two-dimensional arrays.
381
382
383
384
385   Three-dimensional arrays
386       module Array3 : sig end
387
388
389       Three-dimensional arrays. The Array3 structure provides operations sim‐
390       ilar to those of Bigarray.Genarray , but specialized  to  the  case  of
391       three-dimensional arrays.
392
393
394
395
396   Coercions between generic Bigarrays and fixed-dimension Bigarrays
397       val  genarray_of_array0  : ('a, 'b, 'c) Array0.t -> ('a, 'b, 'c) Genar‐
398       ray.t
399
400       Return the generic Bigarray corresponding to the given zero-dimensional
401       Bigarray.
402
403
404       Since 4.05.0
405
406
407
408       val  genarray_of_array1  : ('a, 'b, 'c) Array1.t -> ('a, 'b, 'c) Genar‐
409       ray.t
410
411       Return the generic Bigarray corresponding to the given  one-dimensional
412       Bigarray.
413
414
415
416       val  genarray_of_array2  : ('a, 'b, 'c) Array2.t -> ('a, 'b, 'c) Genar‐
417       ray.t
418
419       Return the generic Bigarray corresponding to the given  two-dimensional
420       Bigarray.
421
422
423
424       val  genarray_of_array3  : ('a, 'b, 'c) Array3.t -> ('a, 'b, 'c) Genar‐
425       ray.t
426
427       Return the generic Bigarray corresponding  to  the  given  three-dimen‐
428       sional Bigarray.
429
430
431
432       val  array0_of_genarray  :  ('a, 'b, 'c) Genarray.t -> ('a, 'b, 'c) Ar‐
433       ray0.t
434
435       Return the zero-dimensional Bigarray corresponding to the given generic
436       Bigarray.
437
438
439       Since 4.05.0
440
441
442       Raises  Invalid_argument  if the generic Bigarray does not have exactly
443       zero dimension.
444
445
446
447       val array1_of_genarray : ('a, 'b, 'c) Genarray.t -> ('a,  'b,  'c)  Ar‐
448       ray1.t
449
450       Return  the one-dimensional Bigarray corresponding to the given generic
451       Bigarray.
452
453
454       Raises Invalid_argument if the generic Bigarray does not  have  exactly
455       one dimension.
456
457
458
459       val  array2_of_genarray  :  ('a, 'b, 'c) Genarray.t -> ('a, 'b, 'c) Ar‐
460       ray2.t
461
462       Return the two-dimensional Bigarray corresponding to the given  generic
463       Bigarray.
464
465
466       Raises  Invalid_argument  if the generic Bigarray does not have exactly
467       two dimensions.
468
469
470
471       val array3_of_genarray : ('a, 'b, 'c) Genarray.t -> ('a,  'b,  'c)  Ar‐
472       ray3.t
473
474       Return  the  three-dimensional  Bigarray  corresponding  to  the  given
475       generic Bigarray.
476
477
478       Raises Invalid_argument if the generic Bigarray does not  have  exactly
479       three dimensions.
480
481
482
483
484   Re-shaping Bigarrays
485       val  reshape  :  ('a,  'b,  'c) Genarray.t -> int array -> ('a, 'b, 'c)
486       Genarray.t
487
488
489       reshape b [|d1;...;dN|] converts the Bigarray b to a N -dimensional ar‐
490       ray of dimensions d1 ...  dN .  The returned array and the original ar‐
491       ray b share their data and have the same layout.  For instance,  assum‐
492       ing  that  b  is  a  one-dimensional  array  of dimension 12, reshape b
493       [|3;4|] returns a two-dimensional array b' of dimensions 3 and 4.  If b
494       has  C layout, the element (x,y) of b' corresponds to the element x * 3
495       + y of b .  If b has Fortran layout, the element  (x,y)  of  b'  corre‐
496       sponds  to  the  element  x + (y - 1) * 4 of b .  The returned Bigarray
497       must have exactly the same number of elements as the original  Bigarray
498       b  .  That is, the product of the dimensions of b must be equal to i1 *
499       ... * iN .  Otherwise, Invalid_argument is raised.
500
501
502
503       val reshape_0 : ('a, 'b, 'c) Genarray.t -> ('a, 'b, 'c) Array0.t
504
505       Specialized version of Bigarray.reshape for  reshaping  to  zero-dimen‐
506       sional arrays.
507
508
509       Since 4.05.0
510
511
512
513       val reshape_1 : ('a, 'b, 'c) Genarray.t -> int -> ('a, 'b, 'c) Array1.t
514
515       Specialized  version  of  Bigarray.reshape  for reshaping to one-dimen‐
516       sional arrays.
517
518
519
520       val reshape_2 : ('a, 'b, 'c) Genarray.t -> int -> int -> ('a,  'b,  'c)
521       Array2.t
522
523       Specialized  version  of  Bigarray.reshape  for reshaping to two-dimen‐
524       sional arrays.
525
526
527
528       val reshape_3 : ('a, 'b, 'c) Genarray.t -> int -> int ->  int  ->  ('a,
529       'b, 'c) Array3.t
530
531       Specialized  version  of Bigarray.reshape for reshaping to three-dimen‐
532       sional arrays.
533
534
535
536
537
538OCamldoc                          2023-01-23                Stdlib.Bigarray(3)
Impressum