官术网_书友最值得收藏!

Matrix storage

Now that you know that the matrix layout is going to be column matrices, the next question is how to store the actual matrix. Matrix storage is a confusing topic.

Since a matrix is stored in memory as a linear array, let's figure out what elements should be placed where. A row-major matrix is stored in memory one row at a time. A column-major matrix is stored one column at a time.

Since both row- and column-major matrices contain the same vectors, the final linear mapping ends up being the same, regardless of the major of the matrix. The following Figure 3.3 demonstrates this:

Figure 3.3: Matrix storage mapping to a linear array

Figure 3.3: Matrix storage mapping to a linear array

The matrix class you will be building is a column-major matrix with column storage; this means there will be a discrepancy between the physical memory layout of the matrix and the logical placement of its elements. It's easy to treat a matrix with a linear memory layout as a row matrix but remember that each of those rows is actually a column.

Important note

The typical mapping of a two-dimensional grid to linear storage is "row * numberOfColumns + column". This mapping won't work for storing a column-major matrix. When looking at a matrix, the element in column 2, row 3 should have a linear index of 7, but the previous mapping yields 14. Instead, to account for the column-major storage, the mapping formula is "column * numberOfRows + row".

Understanding how a matrix is stored in memory is important, it's going to affect how data is stored and how APIs can access that data. In the next section, you will start to implement a matrix structure.

主站蜘蛛池模板: 神农架林区| 广宗县| 图木舒克市| 商洛市| 天津市| 本溪市| 神池县| 鄂伦春自治旗| 昌吉市| 贵德县| 荔波县| 易门县| 钟山县| 石首市| 辉县市| 靖州| 政和县| 高清| 吐鲁番市| 平罗县| 武威市| 尼玛县| 浏阳市| 左云县| 澄城县| 霞浦县| 射洪县| 明光市| 海南省| 延寿县| 鹿泉市| 政和县| 广宁县| 象山县| 南部县| 通渭县| 沧州市| 新干县| 华容县| 达州市| 新龙县|