Class MatrixMatrixMult_MT_FDRM
This class contains various types of matrix matrix multiplication operations for FMatrix1Row
.
Two algorithms that are equivalent can often have very different runtime performance. This is because of how modern computers uses fast memory caches to speed up reading/writing to data. Depending on the order in which variables are processed different algorithms can run much faster than others, even if the number of operations is the same.
Algorithms that are labeled as 'reorder' are designed to avoid caching jumping issues, some times at the cost of increasing the number of operations. This is important for large matrices. The straight forward implementation seems to be faster for small matrices.
Algorithms that are labeled as 'aux' use an auxiliary array of length n. This array is used to create a copy of an out of sequence column vector that is referenced several times. This reduces the number of cache misses. If the 'aux' parameter passed in is null then the array is declared internally.
Typically the straight forward implementation runs about 30% faster on smaller matrices and about 5 times slower on larger matrices. This is all computer architecture and matrix shape/size specific.
DO NOT MODIFY. Automatically generated code created by GenerateMatrixMatrixMult_FDRM
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionstatic void
mult_reorder
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
mult_reorder
(FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
mult_small
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
mult_small
(FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multAdd_reorder
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multAdd_reorder
(FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multAdd_small
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multAdd_small
(FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multAddTransA_reorder
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
static void
multAddTransA_small
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
static void
multAddTransAB
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multAddTransAB
(FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multAddTransB
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multAddTransB
(FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multTransA_reorder
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
static void
multTransA_small
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
static void
multTransAB
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multTransAB
(FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multTransB
(float alpha, FMatrix1Row A, FMatrix1Row B, FMatrix1Row C) static void
multTransB
(FMatrix1Row A, FMatrix1Row B, FMatrix1Row C)
-
Constructor Details
-
MatrixMatrixMult_MT_FDRM
public MatrixMatrixMult_MT_FDRM()
-
-
Method Details
-
mult_reorder
-
mult_small
-
multTransA_reorder
-
multTransA_small
-
multTransAB
-
multTransB
-
multAdd_reorder
-
multAdd_small
-
multAddTransA_reorder
-
multAddTransA_small
-
multAddTransAB
-
multAddTransB
-
mult_reorder
-
mult_small
-
multTransA_reorder
-
multTransA_small
-
multTransAB
-
multTransB
-
multAdd_reorder
-
multAdd_small
-
multAddTransA_reorder
-
multAddTransA_small
-
multAddTransAB
-
multAddTransB
-