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

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.

主站蜘蛛池模板: 侯马市| 台南县| 邮箱| 蒲城县| 乐陵市| 青海省| 宣城市| 洞口县| 福泉市| 康保县| 南皮县| 江源县| 灌云县| 乐清市| 淮安市| 监利县| 广安市| 奎屯市| 土默特左旗| 广德县| 虎林市| 津南区| 土默特右旗| 桦甸市| 石林| 楚雄市| 莒南县| 东丰县| 新疆| 麻江县| 吴堡县| 嘉禾县| 林口县| 麻栗坡县| 扶沟县| 康保县| 驻马店市| 喀喇| 丹寨县| 徐州市| 台东市|