-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest.cu
124 lines (104 loc) · 3.05 KB
/
test.cu
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
114
115
116
117
118
119
120
121
122
123
124
#include "nnUtils.h"
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <math.h>
void testGetIndex();
void testGetNumNetworkWeights();
void testGetNumValueNodes();
void testGetValueIndex();
void testGetNumErrorNodes();
void testGetErrorIndex();
void testCreateNetwork();
void testSumVectors();
int main(int argc, char *argv[])
{
testGetIndex();
testGetNumNetworkWeights();
testGetNumValueNodes();
testGetValueIndex();
testGetNumErrorNodes();
testGetErrorIndex();
testCreateNetwork();
testSumVectors();
printf("All assertions passed.");
}
void testGetIndex()
{
int layerSizes[] = {2, 3, 2};
assert(getIndex(1, 0, 0, layerSizes) == 0);
assert(getIndex(1, 2, 2, layerSizes) == 8);
assert(getIndex(2, 1, 1, layerSizes) == 14);
int layerSizes2[] = {784, 20, 10};
assert(getIndex(1, 15, 201, layerSizes2) == 11976);
assert(getIndex(2, 7, 12, layerSizes2) == 15859);
}
void testGetNumNetworkWeights()
{
int layerSizes[] = {2, 3, 2};
assert(getNumNetworkWeights(3, layerSizes) == 17);
int layerSizes2[] = {784, 20, 10};
assert(getNumNetworkWeights(3, layerSizes2) == 15910);
int layerSizes3[] = {558, 85, 238, 12};
assert(getNumNetworkWeights(4, layerSizes3) == 70851);
}
void testGetNumValueNodes()
{
int layerSizes[] = {2, 3, 2};
assert(getNumValueNodes(3, layerSizes) == 2 + 3 + 2);
int layerSizes3[] = {558, 85, 238, 12};
assert(getNumValueNodes(4, layerSizes3) == 558 + 85 + 238 + 12);
}
void testGetValueIndex()
{
int layerSizes[] = {2, 3, 2};
assert(getValueIndex(layerSizes, 2, 0) == 5);
int layerSizes3[] = {558, 85, 238, 12};
assert(getValueIndex(layerSizes3, 2, 27) == 558 + 85 + 27);
}
void testGetNumErrorNodes()
{
int layerSizes[] = {2, 3, 2};
assert(getNumErrorNodes(3, layerSizes) == 3 + 2);
int layerSizes3[] = {558, 85, 238, 12};
assert(getNumErrorNodes(4, layerSizes3) == 85 + 238 + 12);
}
void testGetErrorIndex()
{
int layerSizes[] = {2, 3, 2};
assert(getErrorIndex(layerSizes, 2, 0) == 3);
int layerSizes3[] = {558, 85, 238, 12};
assert(getErrorIndex(layerSizes3, 2, 27) == 85 + 27);
}
void testCreateNetwork()
{
int layerSizes[] = {784, 20, 10};
float *net = createNetwork(3, layerSizes);
assert(net[getIndex(2, 7, 12, layerSizes)] == 15859);
int layerSizes2[] = {558, 85, 238, 12};
float *net2 = createNetwork(4, layerSizes2);
assert(net2[52134] == 52134);
}
void testSumVectors()
{
float h_list_1[] = {
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,
};
float correct[] = {
55, 60, 65, 70, 75
};
int vectorLength = 5;
float *d_list_1;
cudaMalloc(&d_list_1, sizeof(h_list_1));
cudaMemcpy(d_list_1, h_list_1, sizeof(h_list_1), cudaMemcpyHostToDevice);
sumVectors<<<1, 3>>>(d_list_1, 5, 5);
cudaMemcpy(h_list_1, d_list_1, sizeof(h_list_1), cudaMemcpyDeviceToHost);
for (int i = 0; i < vectorLength; i ++)
{
assert(h_list_1[i] == correct[i]);
}
}