forked from lantian2012/CS207
-
Notifications
You must be signed in to change notification settings - Fork 0
/
test_edges.cpp
executable file
·180 lines (138 loc) · 4.96 KB
/
test_edges.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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
#include "Graph.hpp"
#include "CS207/Util.hpp"
// Define the GraphType HERE
typedef Graph<int> GraphType;
typedef GraphType::node_type Node;
typedef GraphType::edge_type Edge;
using namespace std;
using namespace CS207;
static unsigned fail_count = 0;
template <typename T>
void sf_print(T a, string msg = "") {
(void) a;
cerr << msg << " [Success]" << endl;
}
void sf_print(bool sf, string msg = "") {
if (sf)
cerr << msg << " [Success]" << endl;
else {
cerr << msg << " [FAIL]" << endl;
++fail_count;
}
}
int main()
{
GraphType g;
Point p1(CS207::random(), CS207::random(), CS207::random());
Point p2(CS207::random(), CS207::random(), CS207::random());
cerr << "Edge is " << sizeof(Edge) << " bytes";
sf_print(sizeof(Edge) <= 32);
sf_print(g.add_node(p1), "Inserting Node");
sf_print(g.add_node(p2), "Inserting Node");
sf_print(g.num_nodes() == 2, "Graph has 2 Nodes");
sf_print(g.add_edge(g.node(0), g.node(1)), "Inserting Edge");
sf_print(g.num_edges() == 1, "Graph has 1 Edge");
sf_print(g.edge(0), "Getting Edge");
Edge e = g.edge(0);
sf_print(g.has_edge(e.node1(), e.node2()), "Graph has_edge e");
sf_print(g.has_edge(e.node2(), e.node1()), "Graph has_edge e transpose");
sf_print((e.node1() == g.node(0) && e.node2() == g.node(1)) ||
(e.node1() == g.node(1) && e.node2() == g.node(0)),
"Edge nodes check out");
sf_print(g.remove_edge(e.node1(), e.node2()),
"remove_edge return value is true");
sf_print(g.num_edges() == 0, "Graph has 0 edges");
sf_print(!g.has_edge(g.node(0), g.node(1)), "Graph !has_edge");
sf_print(!g.remove_edge(g.node(0), g.node(1)),
"remove_edge return value is false");
sf_print(g.add_edge(g.node(0), g.node(1)), "Inserting Edge");
sf_print(g.add_edge(g.node(0), g.node(1)), "Inserting Edge Again");
sf_print(g.num_edges() == 1, "Graph has 1 Edge");
g.remove_node(g.node(1));
sf_print(g.num_nodes() == 1, "Removing Node ...");
sf_print(g.num_edges() == 0, "Edge removed b/c of Node");
cerr << "Clearing...";
g.clear();
sf_print(g.num_nodes() == 0 && g.num_edges() == 0);
cerr << "Adding 100 Nodes...";
for (int k = 0; k < 100; ++k) {
g.add_node(Point(CS207::random(), CS207::random(), CS207::random()));
}
sf_print(true);
// Adding 100 Edges
for (unsigned k = 0; k < 100; ++k) {
unsigned n1 = (unsigned) CS207::random(0, g.num_nodes());
unsigned n2 = (unsigned) CS207::random(0, g.num_nodes());
while (n1 == n2 || g.has_edge(g.node(n1), g.node(n2))) {
n1 = (unsigned) CS207::random(0, g.num_nodes());
n2 = (unsigned) CS207::random(0, g.num_nodes());
}
Edge e = g.add_edge(g.node(n1), g.node(n2));
if (k == 43) {
sf_print(g.has_edge(e.node1(), e.node2()), "Graph has_edge e");
sf_print((e.node1() == g.node(n1) && e.node2() == g.node(n2)) ||
(e.node1() == g.node(n2) && e.node2() == g.node(n1)),
"Edge nodes check out");
}
}
sf_print(g.num_nodes() == 100 && g.num_edges() == 100, "100 Nodes, 100 Edges");
// Remove 50 Edges
for (unsigned k = 0; k < 50; ++k) {
unsigned n1, n2;
do {
n1 = (unsigned) CS207::random(0, g.num_nodes());
n2 = (unsigned) CS207::random(0, g.num_nodes());
} while (!g.has_edge(g.node(n1), g.node(n2)));
g.remove_edge(g.node(n1), g.node(n2));
if (k == 23)
sf_print(!g.has_edge(g.node(n1), g.node(n2)),
"Graph !has_edge after remove");
}
sf_print(g.num_edges() == 50, "Removed 50 Edges");
// Count edges the long way
unsigned count_edges = 0;
for (unsigned k = 0; k < g.num_nodes(); ++k) {
for (unsigned j = k+1; j < g.num_nodes(); ++j) {
if (g.has_edge(g.node(k), g.node(j)))
++count_edges;
}
}
sf_print(count_edges == g.num_edges(), "Edge count agrees");
// Remove 50 Nodes...
for (unsigned k = 0; k < 50; ++k) {
unsigned n = (unsigned) CS207::random(0, g.num_nodes());
g.remove_node(g.node(n));
}
sf_print(g.num_nodes() == 50, "Removed 50 Nodes");
// Count edges the long way
count_edges = 0;
for (unsigned k = 0; k < g.num_nodes(); ++k) {
for (unsigned j = k+1; j < g.num_nodes(); ++j) {
if (g.has_edge(g.node(k), g.node(j)))
++count_edges;
}
}
sf_print(count_edges == g.num_edges(), "Edge count agrees");
cerr << "Clearing...";
g.clear();
sf_print(g.num_nodes() == 0 && g.num_edges() == 0);
GraphType g2;
cerr << "Adding 10 Nodes to Graph1 and Graph2...";
for (unsigned k = 0; k < 10; ++k) {
Point p(CS207::random(), CS207::random(), CS207::random());
g.add_node(p);
g2.add_node(p);
}
sf_print(true);
Edge e1 = g.add_edge(g.node(3), g.node(4));
Edge e2 = g2.add_edge(g2.node(3), g2.node(4));
sf_print(e1 != e2, "G1-G2 Edge comparison !=");
sf_print(e1 < e2 || e2 < e1, "G1-G2 Edge comparison < >");
if (fail_count) {
std::cerr << "\n" << fail_count
<< (fail_count > 1 ? " FAILURES" : " FAILURE") << std::endl;
return 1;
} else
return 0;
return 0;
}