-
Notifications
You must be signed in to change notification settings - Fork 0
/
matrix_math_test.cpp
113 lines (90 loc) · 2.29 KB
/
matrix_math_test.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/*
* Matrix Math Test
*
*/
#include "neural/math/matrix_math.h"
#include <gtest/gtest.h>
using namespace neural;
using namespace std;
// TEST(TestCaseName, IndividualTestName)
TEST(MatrixMathTest, TestMatMul)
{
TMatrix lhs = {
{4.0, 3.0},
{2.0, 1.0}
};
TMatrix rhs = {
{1.0, 2.0},
{3.0, 4.0}
};
TMatrix result = MatrixMath::Multiply(lhs, rhs);
EXPECT_EQ(2, result.size());
EXPECT_EQ(2, result.at(0).size());
/*
(0,0) = 4*1 + 3*3 = 13
(0,1) = 4*2 + 3*4 = 20
(1,0) = 2*1 + 1*3 = 5
(1,1) = 2*2 + 1*4 = 8
*/
EXPECT_EQ(13.0, result.at(0).at(0));
EXPECT_EQ(20.0, result.at(0).at(1));
EXPECT_EQ(5.0, result.at(1).at(0));
EXPECT_EQ(8.0, result.at(1).at(1));
}
TEST(MatrixMathTest, TestTranspose)
{
TMatrix mat = {
{5.0, 4.0, 3.0},
{2.0, 1.0, 0.0}
};
TMatrix transpose = MatrixMath::Transpose(mat);
EXPECT_EQ(3, transpose.size());
EXPECT_EQ(2, transpose.at(0).size());
/*
5.0, 2.0,
4.0, 1.0,
3.0, 0.0
*/
EXPECT_EQ(5.0, transpose.at(0).at(0));
EXPECT_EQ(2.0, transpose.at(0).at(1));
EXPECT_EQ(4.0, transpose.at(1).at(0));
EXPECT_EQ(1.0, transpose.at(1).at(1));
EXPECT_EQ(3.0, transpose.at(2).at(0));
EXPECT_EQ(0.0, transpose.at(2).at(1));
}
TEST(MatrixMathTest, TestAddCol)
{
TMatrix mat = {
{5.0, 4.0, 3.0},
{2.0, 1.0, 0.0}
};
TMatrix newMat = MatrixMath::AddCol(mat, 1.0);
EXPECT_EQ(2, newMat.size());
EXPECT_EQ(4, newMat.at(0).size());
EXPECT_EQ(5.0, newMat.at(0).at(0));
EXPECT_EQ(4.0, newMat.at(0).at(1));
EXPECT_EQ(3.0, newMat.at(0).at(2));
EXPECT_EQ(1.0, newMat.at(0).at(3));
EXPECT_EQ(2.0, newMat.at(1).at(0));
EXPECT_EQ(1.0, newMat.at(1).at(1));
EXPECT_EQ(0.0, newMat.at(1).at(2));
EXPECT_EQ(1.0, newMat.at(1).at(3));
}
TEST(MatrixMathTest, TestRemoveCol)
{
TMatrix mat = {
{5.0, 4.0, 3.0},
{2.0, 1.0, 0.0}
};
TMatrix newMat = MatrixMath::RemoveCol(mat);
EXPECT_EQ(2, newMat.size());
EXPECT_EQ(2, newMat.at(0).size());
/*
5.0, 4.0,
2.0, 1.0,
*/
EXPECT_EQ(5.0, newMat.at(0).at(0));
EXPECT_EQ(4.0, newMat.at(0).at(1));
EXPECT_EQ(2.0, newMat.at(1).at(0));
EXPECT_EQ(1.0, newMat.at(1).at(1));
}