mirror of
https://github.com/yuzu-emu/FasTC.git
synced 2025-01-07 01:55:37 +00:00
Add matrix transpose
This commit is contained in:
parent
98bc157e00
commit
0c4b226c78
|
@ -98,6 +98,17 @@ namespace FasTC {
|
|||
return result;
|
||||
}
|
||||
|
||||
// Transposition
|
||||
MatrixBase<T, nCols, nRows> Transpose() const {
|
||||
MatrixBase<T, nCols, nRows> result;
|
||||
for(int r = 0; r < nRows; r++) {
|
||||
for(int c = 0; c < nCols; c++) {
|
||||
result(c, r) = (*this)(r, c);
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
// Double dot product
|
||||
template<typename _T>
|
||||
T DDot(const MatrixBase<_T, nRows, nCols> &m) {
|
||||
|
|
|
@ -156,6 +156,21 @@ TEST(MatrixBase, MatrixMultiplication) {
|
|||
EXPECT_NEAR(amb(1, 4), 45, kEpsilon);
|
||||
}
|
||||
|
||||
TEST(MatrixBase, Transposition) {
|
||||
FasTC::MatrixBase<int, 3, 5> a;
|
||||
a(0, 0) = -1; a(0, 1) = 2; a(0, 2) = -4; a(0, 3) = 5; a(0, 4) = 0;
|
||||
a(1, 0) = 1; a(1, 1) = 2; a(1, 2) = 4; a(1, 3) = 6; a(1, 4) = 3;
|
||||
a(2, 0) = -1; a(2, 1) = -2; a(2, 2) = -3; a(2, 3) = -4; a(2, 4) = 5;
|
||||
|
||||
FasTC::MatrixBase<int, 5, 3> b = a.Transpose();
|
||||
|
||||
for(int i = 0; i < 3; i++) {
|
||||
for(int j = 0; j < 5; j++) {
|
||||
EXPECT_EQ(a(i, j), b(j, i));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
TEST(MatrixBase, VectorMultiplication) {
|
||||
// Stub
|
||||
EXPECT_EQ(0, 1);
|
||||
|
|
Loading…
Reference in a new issue