# Row- and column-major order

(Redirected from Row-major order)
Jump to: navigation, search

In computing, row-major order and column-major order describe methods for arranging multidimensional arrays in linear storage such as random access memory.

In row-major order, consecutive elements of the rows of the array are contiguous in memory; in column-major order, consecutive elements of the columns are contiguous.

Array layout is critical for correctly passing arrays between programs written in different languages. It is also important for performance when traversing an array because accessing array elements that are contiguous in memory is usually faster than accessing elements which are not, due to caching. In some media such as tape or NAND flash memory, accessing sequentially is orders of magnitude faster than nonsequential access.[citation needed]

## Explanation and example

There are two aspects: row/column, and major/minor.

In matrix notation, the first/left index indicates the row, and the second/right index indicates the column, e.g., a1,2 is in the first row and in the second column. Even though the row is indicated by the first index and the column by the second index, no grouping order between dimensions is implied yet. This convention is carried over to two-dimensional arrays in computer languages,[1] although often with indexes starting at 0 instead of 1.

An obvious way to order objects with more than one attribute is to first group and order them by one attribute, and then, within each such group, group and order them by another attribute, etc. (not all attributes have to participate in ordering). If more than one attribute participate in ordering, the first would be called major and the last minor. If two attributes participate in ordering, it is sufficient to name only the major attribute.

Applied to two-dimensional arrays, e.g., for row-major order, all elements of the first row come before all elements of the second row, etc., and, within each row, elements are ordered by column. As one steps though consecutive memory locations, the index associated with the major order varies slowest, and the index associated with the minor order varies fastest (unless there is only one index value in that dimension).

This array

${\displaystyle A={\begin{bmatrix}a_{11}&a_{12}&a_{13}\\a_{21}&a_{22}&a_{23}\end{bmatrix}}}$

would be stored as follows in the two orders:

## Programming languages and libraries

Programming languages or their standard libraries that support multi-dimensional arrays typically have a native row-major or column-major storage order for these arrays.

Row-major order is used in C/C++/Objective-C (for C-style arrays), Mathematica, PL/I, Pascal, Speakeasy, SAS, and C#/CLI/.Net.

Column-major order is used in Fortran, OpenGL and OpenGL ES, MATLAB,[2] GNU Octave, S-Plus,[3] R,[4] Julia,[5] Rasdaman[citation needed], Scilab.

A typical alternative is to use Iliffe vectors, which store elements in the same row contiguously (like row-major order), but not the rows themselves. They are used in Java,[6] Scala,[7] and Swift.

Support for multi-dimensional arrays may also be provided by external libraries, which may even support arbitrary orderings, where each dimension has a stride value, and row-major or column-major are just two possible resulting interpretations.

Row-major order is the default in NumPy[8] (for Python).

Torch (for Lua, which has no built-in support[9]) changed from column-major[10] to row-major[11] default order.

## Transposition

As exchanging the indices of an array is the essence of array transposition, an array stored as row-major but read as column-major (or vice versa) will appear transposed. As actually performing this rearrangement in memory is typically an expensive operation, some systems provide options to specify individual matrices as being stored transposed. The programmer must then decide whether or not to rearrange the elements in memory, based on the actual usage (including the number of times that the array is reused in a computation).

For example, the Basic Linear Algebra Subprograms functions are passed flags indicating which arrays are transposed.[12]

## Address calculation in general

The concept generalizes to arrays with more than two dimensions.

For a d-dimensional ${\displaystyle N_{1}\times N_{2}\times \cdots \times N_{d}}$ array with dimensions Nk (k=1...d), a given element of this array is specified by a tuple ${\displaystyle (n_{1},n_{2},\ldots ,n_{d})}$ of d (zero-based) indices ${\displaystyle n_{k}\in [0,N_{k}-1]}$.

In row-major order, the last dimension is contiguous, so that the memory-offset of this element is given by:

${\displaystyle n_{d}+N_{d}\cdot (n_{d-1}+N_{d-1}\cdot (n_{d-2}+N_{d-2}\cdot (\cdots +N_{2}n_{1})\cdots )))=\sum _{k=1}^{d}\left(\prod _{\ell =k+1}^{d}N_{\ell }\right)n_{k}}$

In column-major order, the first dimension is contiguous, so that the memory-offset of this element is given by:

${\displaystyle n_{1}+N_{1}\cdot (n_{2}+N_{2}\cdot (n_{3}+N_{3}\cdot (\cdots +N_{d-1}n_{d})\cdots )))=\sum _{k=1}^{d}\left(\prod _{\ell =1}^{k-1}N_{\ell }\right)n_{k}}$

For a given order, the stride in dimension k is given by the multiplication value in parentheses before index nk in the right hand-side summations above.

More generally, there are d! possible orders for a given array, one for each permutation of dimensions (with row-major and column-order just 2 special cases), although the lists of stride values are not necessarily permutations of each other, e.g., in the 2-by-3 example above, the strides are (3,1) for row-major and (1,2) for column-major.

## References

1. ^ "Arrays and Formatted I/O". FORTRAN Tutorial. Retrieved 19 November 2016.
2. ^ MATLAB documentation, MATLAB Data Storage (retrieved from Mathworks.co.uk, January 2014).
3. ^ Spiegelhalter et al. (2003, p. 17): Spiegelhalter, David; Thomas, Andrew; Best, Nicky; Lunn, Dave (January 2003), "Formatting of data: S-Plus format", WinBUGS User Manual (Version 1.4 ed.), Robinson Way, Cambridge CB2 2SR, UK: MRC Biostatistics Unit, Institute of Public Health, PDF document
4. ^ An Introduction to R, Section 5.1: Arrays (retrieved March 2010).
5. ^ "Multi-dimensional Arrays". Julia. Retrieved 6 February 2016.
6. ^ "Java Language Specification". Oracle. Retrieved 13 February 2016.
7. ^ "object Array". Scala Standard Library. Retrieved 1 May 2016.
8. ^ "The N-dimensional array (ndarray)". SciPy.org. Retrieved 3 April 2016.
9. ^ "11.2 – Matrices and Multi-Dimensional Arrays". Retrieved 6 February 2016.
10. ^ "Tensor". Retrieved 6 February 2016.
11. ^ "Tensor". Torch Package Reference Manual. Retrieved 8 May 2016.
12. ^ "BLAS (Basic Linear Algebra Subprograms)". Retrieved 2015-05-16.