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