annotate louvain/main_hierarchy.cpp @ 0:1d1b9e1b2e2f draft

Uploaded
author petr-novak
date Thu, 19 Dec 2019 10:24:45 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
1 // File: main_hierarchy.cpp
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
2 // -- output community structure handling (number of levels, communities of one level)
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
3 //-----------------------------------------------------------------------------
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
4 // Community detection
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
5 // Based on the article "Fast unfolding of community hierarchies in large networks"
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
6 // Copyright (C) 2008 V. Blondel, J.-L. Guillaume, R. Lambiotte, E. Lefebvre
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
7 //
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
8 // This program must not be distributed without agreement of the above mentionned authors.
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
9 //-----------------------------------------------------------------------------
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
10 // Author : E. Lefebvre, adapted by J.-L. Guillaume
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
11 // Email : jean-loup.guillaume@lip6.fr
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
12 // Location : Paris, France
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
13 // Time : February 2008
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
14 //-----------------------------------------------------------------------------
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
15 // see readme.txt for more details
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
16
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
17 #include <stdlib.h>
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
18 #include <stdio.h>
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
19 #include <iostream>
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
20 #include <iomanip>
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
21 #include <fstream>
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
22 #include <vector>
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
23 #include <map>
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
24 #include <set>
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
25 #include <algorithm>
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
26
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
27 using namespace std;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
28
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
29 int display_level = -1;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
30 char *filename = NULL;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
31
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
32 void
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
33 usage(char *prog_name, const char *more) {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
34 cerr << more;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
35 cerr << "usage: " << prog_name << " input_file [options]" << endl << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
36 cerr << "input_file: read the community tree from this file." << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
37 cerr << "-l xx\t display the community structure for the level xx." << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
38 cerr << "\t outputs the community for each node." << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
39 cerr << "\t xx must belong to [-1,N] if N is the number of levels." << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
40 cerr << "-n\t displays the number of levels and the size of each level." << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
41 cerr << "\t equivalent to -l -1." << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
42 cerr << "-h\tshow this usage message." << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
43 exit(0);
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
44 }
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
45
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
46 void
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
47 parse_args(int argc, char **argv) {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
48 if (argc<2)
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
49 usage(argv[0], "Bad arguments number\n");
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
50
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
51 for (int i = 1; i < argc; i++) {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
52 if(argv[i][0] == '-') {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
53 switch(argv[i][1]) {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
54 case 'l':
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
55 display_level = atoi(argv[i+1]);
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
56 i++;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
57 break;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
58 case 'n':
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
59 display_level = -1;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
60 break;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
61 default:
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
62 usage(argv[0], "Unknown option\n");
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
63 }
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
64 } else {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
65 if (filename==NULL)
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
66 filename = argv[i];
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
67 else
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
68 usage(argv[0], "More than one filename\n");
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
69 }
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
70 }
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
71 if (filename==NULL)
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
72 usage(argv[0], "No input file has been provided.\n");
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
73 }
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
74 int
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
75 main(int argc, char **argv) {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
76 parse_args(argc, argv);
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
77
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
78 vector<vector<int> >levels;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
79
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
80 ifstream finput;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
81 finput.open(filename,fstream::in);
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
82
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
83 int l=-1;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
84 while (!finput.eof()) {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
85 int node, nodecomm;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
86 finput >> node >> nodecomm;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
87
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
88 if (finput) {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
89 if (node==0) {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
90 l++;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
91 levels.resize(l+1);
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
92 }
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
93 levels[l].push_back(nodecomm);
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
94 }
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
95 }
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
96
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
97 if (display_level==-1) {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
98 cout << "Number of levels: " << levels.size() << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
99 for (unsigned int i=0 ; i<levels.size();i++)
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
100 cout << "level " << i << ": " << levels[i].size() << " nodes" << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
101 } else if (display_level<0 || (unsigned)display_level>=levels.size()) {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
102 cerr << "Incorrect level\n";
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
103 } else {
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
104 vector<int> n2c(levels[0].size());
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
105
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
106 for (unsigned int i=0 ; i<levels[0].size() ; i++)
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
107 n2c[i]=i;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
108
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
109 for (l=0 ; l<display_level ; l++)
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
110 for (unsigned int node=0 ; node<levels[0].size() ; node++)
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
111 n2c[node] = levels[l][n2c[node]];
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
112
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
113 for (unsigned int node=0 ; node<levels[0].size() ; node++)
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
114 cout << node << " " << n2c[node] << endl;
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
115 }
1d1b9e1b2e2f Uploaded
petr-novak
parents:
diff changeset
116 }