deba@1833: #include deba@1833: #include deba@1833: #include deba@1833: #include deba@1833: #include deba@1833: deba@1833: #include "test_tools.h" deba@1833: deba@1833: deba@1833: #include deba@1833: #include deba@1833: #include deba@1833: deba@1833: using namespace std; deba@1833: using namespace lemon; deba@1833: deba@1833: void checkRadixSort() { deba@1833: int n = 10000; deba@1833: vector data1(n), data2(n); deba@1833: for (int i = 0; i < n; ++i) { deba@1833: data1[i] = data2[i] = (int)(1000 * (rand() / (RAND_MAX + 1.0))) - 500; deba@1833: } deba@1833: radixSort(data1.begin(), data1.end()); deba@1833: sort(data2.begin(), data2.end()); deba@1833: for (int i = 0; i < n; ++i) { deba@1833: check(data1[i] == data2[i], "Test failed"); deba@1833: } deba@1833: } deba@1833: deba@1833: deba@1833: void checkCounterSort() { deba@1833: int n = 10000; deba@1833: vector data1(n), data2(n); deba@1833: for (int i = 0; i < n; ++i) { deba@1833: data1[i] = data2[i] = (int)(1000 * (rand() / (RAND_MAX + 1.0))) - 500; deba@1833: } deba@1833: counterSort(data1.begin(), data1.end()); deba@1833: sort(data2.begin(), data2.end()); deba@1833: for (int i = 0; i < n; ++i) { deba@1833: check(data1[i] == data2[i], "Test failed"); deba@1833: } deba@1833: } deba@1833: deba@1833: void checkSorts() { deba@1833: checkRadixSort(); deba@1833: checkCounterSort(); deba@1833: } deba@1833: deba@1833: void checkGraphRadixSort() { deba@1833: typedef SmartGraph Graph; deba@1833: typedef Graph::Node Node; deba@1833: typedef Graph::Edge Edge; deba@1833: deba@1833: const int n = 100; deba@1833: const int e = (int)(n * log((double)n)); deba@1833: deba@1833: Graph graph; deba@1833: vector nodes; deba@1833: deba@1833: for (int i = 0; i < n; ++i) { deba@1833: nodes.push_back(graph.addNode()); deba@1833: } deba@1833: vector edges; deba@1833: for (int i = 0; i < e; ++i) { deba@1833: int s = (int)(n * (double)rand() / (RAND_MAX + 1.0)); deba@1833: int t = (int)(n * (double)rand() / (RAND_MAX + 1.0)); deba@1833: edges.push_back(graph.addEdge(nodes[s], nodes[t])); deba@1833: } deba@1833: deba@1833: radixSort(edges.begin(), edges.end(), deba@1833: mapFunctor(composeMap(IdMap(graph), deba@1833: sourceMap(graph)))); deba@1833: deba@1833: Graph::EdgeMap was(graph, false); deba@1833: deba@1833: for (int i = 0; i < (int)edges.size(); ++i) { deba@1833: check(!was[edges[i]], "Test failed"); deba@1833: was[edges[i]] = true; deba@1833: } deba@1833: deba@1833: for (int i = 1; i < (int)edges.size(); ++i) { deba@1833: check(graph.id(graph.source(edges[i - 1])) <= deba@1833: graph.id(graph.source(edges[i])), "Test failed"); deba@1833: } deba@1833: deba@1833: } deba@1833: deba@1833: void checkGraphCounterSort() { deba@1833: typedef SmartGraph Graph; deba@1833: typedef Graph::Node Node; deba@1833: typedef Graph::Edge Edge; deba@1833: deba@1833: const int n = 100; deba@1833: const int e = (int)(n * log((double)n)); deba@1833: deba@1833: Graph graph; deba@1833: vector nodes; deba@1833: deba@1833: for (int i = 0; i < n; ++i) { deba@1833: nodes.push_back(graph.addNode()); deba@1833: } deba@1833: vector edges; deba@1833: for (int i = 0; i < e; ++i) { deba@1833: int s = (int)(n * (double)rand() / (RAND_MAX + 1.0)); deba@1833: int t = (int)(n * (double)rand() / (RAND_MAX + 1.0)); deba@1833: edges.push_back(graph.addEdge(nodes[s], nodes[t])); deba@1833: } deba@1833: deba@1833: counterSort(edges.begin(), edges.end(), deba@1833: mapFunctor(composeMap(IdMap(graph), deba@1833: sourceMap(graph)))); deba@1833: deba@1833: counterSort(edges.begin(), edges.end(), deba@1833: mapFunctor(composeMap(IdMap(graph), deba@1833: targetMap(graph)))); deba@1833: deba@1833: Graph::EdgeMap was(graph, false); deba@1833: deba@1833: for (int i = 0; i < (int)edges.size(); ++i) { deba@1833: check(!was[edges[i]], "Test failed"); deba@1833: was[edges[i]] = true; deba@1833: } deba@1833: deba@1833: for (int i = 1; i < (int)edges.size(); ++i) { deba@1833: check(graph.id(graph.target(edges[i - 1])) < deba@1833: graph.id(graph.target(edges[i])) || deba@1833: (graph.id(graph.target(edges[i - 1])) == deba@1833: graph.id(graph.target(edges[i])) && deba@1833: graph.id(graph.source(edges[i - 1])) <= deba@1833: graph.id(graph.source(edges[i]))), "Test failed"); deba@1833: } deba@1833: deba@1833: } deba@1833: deba@1833: void checkGraphSorts() { deba@1833: checkGraphRadixSort(); deba@1833: checkGraphCounterSort(); deba@1833: } deba@1833: deba@1833: int main() { deba@1833: checkSorts(); deba@1833: checkGraphSorts(); deba@1833: return 0; deba@1833: }