Chris@10: Chris@10:
Chris@10:Chris@10: Previous: Dynamic Arrays in C, Chris@10: Up: Multi-dimensional Array Format Chris@10:
A different method for allocating multi-dimensional arrays in C is Chris@10: often suggested that is incompatible with FFTW: using it will Chris@10: cause FFTW to die a painful death. We discuss the technique here, Chris@10: however, because it is so commonly known and used. This method is to Chris@10: create arrays of pointers of arrays of pointers of ...etcetera. Chris@10: For example, the analogue in this method to the example above is: Chris@10: Chris@10:
int i,j;
Chris@10: fftw_complex ***a_bad_array; /* another way to make a 5x12x27 array */
Chris@10:
Chris@10: a_bad_array = (fftw_complex ***) malloc(5 * sizeof(fftw_complex **));
Chris@10: for (i = 0; i < 5; ++i) {
Chris@10: a_bad_array[i] =
Chris@10: (fftw_complex **) malloc(12 * sizeof(fftw_complex *));
Chris@10: for (j = 0; j < 12; ++j)
Chris@10: a_bad_array[i][j] =
Chris@10: (fftw_complex *) malloc(27 * sizeof(fftw_complex));
Chris@10: }
Chris@10:
Chris@10: As you can see, this sort of array is inconvenient to allocate (and
Chris@10: deallocate). On the other hand, it has the advantage that the
Chris@10: (i,j,k)-th element can be referenced simply by
Chris@10: a_bad_array[i][j][k]
.
Chris@10:
Chris@10:
If you like this technique and want to maximize convenience in accessing
Chris@10: the array, but still want to pass the array to FFTW, you can use a
Chris@10: hybrid method. Allocate the array as one contiguous block, but also
Chris@10: declare an array of arrays of pointers that point to appropriate places
Chris@10: in the block. That sort of trick is beyond the scope of this
Chris@10: documentation; for more information on multi-dimensional arrays in C,
Chris@10: see the comp.lang.c
Chris@10: FAQ.
Chris@10:
Chris@10:
Chris@10:
Chris@10: