2017-08-03 18:08:39 +08:00
|
|
|
#include <cstdio>
|
|
|
|
#include <cstdlib>
|
|
|
|
#include <fstream>
|
|
|
|
#include <iostream>
|
|
|
|
#include <map>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "graph.hpp"
|
|
|
|
#include "spinner.hpp"
|
|
|
|
|
|
|
|
void PrintStatistics(const Distributed &distributed) {
|
|
|
|
using std::cout;
|
|
|
|
using std::endl;
|
2017-08-17 21:36:58 +08:00
|
|
|
for (const ShardedStorage &mnode : distributed) {
|
|
|
|
cout << " ShardedStorage " << mnode.mnid_ << ":";
|
|
|
|
cout << " #vertices = " << mnode.VertexCount();
|
2017-08-03 18:08:39 +08:00
|
|
|
int64_t edge_count{0};
|
2017-08-17 21:36:58 +08:00
|
|
|
for (const auto &gid_vertex_pair : mnode) {
|
|
|
|
edge_count += gid_vertex_pair.second.edges_in().size();
|
|
|
|
edge_count += gid_vertex_pair.second.edges_out().size();
|
2017-08-03 18:08:39 +08:00
|
|
|
}
|
|
|
|
cout << ", #edges = " << edge_count;
|
2017-08-17 21:36:58 +08:00
|
|
|
cout << ", #cuts = " << mnode.BoundaryEdgeCount() << endl;
|
2017-08-03 18:08:39 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads an undirected graph from file.
|
|
|
|
* - first line of the file: vertices_count, edges_count
|
|
|
|
* - next edges_count lines contain vertices that form an edge
|
|
|
|
* example:
|
|
|
|
* https://snap.stanford.edu/data/facebook_combined.txt.gz
|
|
|
|
* add number of vertices and edges in the first line of that file
|
|
|
|
*/
|
2017-08-17 21:36:58 +08:00
|
|
|
Distributed ReadGraph(std::string filename, int mnode_count) {
|
|
|
|
Distributed distributed(mnode_count);
|
2017-08-03 18:08:39 +08:00
|
|
|
|
|
|
|
std::fstream fs;
|
|
|
|
fs.open(filename, std::fstream::in);
|
|
|
|
if (fs.fail()) return distributed;
|
|
|
|
|
|
|
|
int vertex_count, edge_count;
|
|
|
|
fs >> vertex_count >> edge_count;
|
|
|
|
|
2017-08-17 21:36:58 +08:00
|
|
|
// assign vertices to random mnodes
|
|
|
|
std::vector<GlobalVertAddress> vertices;
|
2017-08-03 18:08:39 +08:00
|
|
|
for (int i = 0; i < vertex_count; ++i)
|
2017-08-17 21:36:58 +08:00
|
|
|
vertices.emplace_back(distributed.MakeVertex(rand() % mnode_count));
|
2017-08-03 18:08:39 +08:00
|
|
|
|
|
|
|
// add edges
|
|
|
|
for (int i = 0; i < edge_count; ++i) {
|
|
|
|
size_t u, v;
|
|
|
|
fs >> u >> v;
|
2017-08-17 21:36:58 +08:00
|
|
|
assert(u < vertices.size() && v < vertices.size());
|
|
|
|
distributed.MakeEdge(vertices[u], vertices[v]);
|
2017-08-03 18:08:39 +08:00
|
|
|
}
|
|
|
|
fs.close();
|
|
|
|
return distributed;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, const char *argv[]) {
|
|
|
|
srand(time(NULL));
|
|
|
|
|
|
|
|
if (argc == 1) {
|
|
|
|
std::cout << "Usage:" << std::endl;
|
|
|
|
std::cout << argv[0] << " filename partitions iterations" << std::endl;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::cout << "Memgraph spinner test " << std::endl;
|
|
|
|
std::string filename(argv[1]);
|
|
|
|
int partitions = std::max(1, atoi(argv[2]));
|
|
|
|
int iterations = std::max(1, atoi(argv[3]));
|
|
|
|
|
|
|
|
Distributed distributed = ReadGraph(filename, partitions);
|
|
|
|
PrintStatistics(distributed);
|
|
|
|
for (int iter = 0; iter < iterations; ++iter) {
|
|
|
|
spinner::PerformSpinnerStep(distributed);
|
|
|
|
std::cout << "Iteration " << iter << std::endl;
|
|
|
|
PrintStatistics(distributed);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|