annotate louvain/graph.cpp @ 9:511266aa9235 draft

Uploaded
author petrn
date Fri, 20 Dec 2019 14:24:11 +0000
parents f6ebec6e235e
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
1 // File: graph.cpp
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
2 // -- simple graph handling source file
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
3 //-----------------------------------------------------------------------------
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
4 // Community detection
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
5 // Based on the article "Fast unfolding of community hierarchies in large networks"
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
6 // Copyright (C) 2008 V. Blondel, J.-L. Guillaume, R. Lambiotte, E. Lefebvre
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
7 //
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
8 // This program must not be distributed without agreement of the above mentionned authors.
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
9 //-----------------------------------------------------------------------------
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
10 // Author : E. Lefebvre, adapted by J.-L. Guillaume
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
11 // Email : jean-loup.guillaume@lip6.fr
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
12 // Location : Paris, France
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
13 // Time : February 2008
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
14 //-----------------------------------------------------------------------------
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
15 // see readme.txt for more details
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
16
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
17 #include "graph.h"
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
18
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
19 using namespace std;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
20
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
21 Graph::Graph(char *filename, int type) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
22 ifstream finput;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
23 finput.open(filename,fstream::in);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
24
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
25 int nb_links=0;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
26
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
27 while (!finput.eof()) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
28 unsigned int src, dest;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
29 double weight=1.;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
30
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
31 if (type==WEIGHTED) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
32 finput >> src >> dest >> weight;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
33 } else {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
34 finput >> src >> dest;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
35 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
36
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
37 if (finput) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
38 if (links.size()<=max(src,dest)+1) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
39 links.resize(max(src,dest)+1);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
40 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
41
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
42 links[src].push_back(make_pair(dest,weight));
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
43 if (src!=dest)
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
44 links[dest].push_back(make_pair(src,weight));
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
45
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
46 nb_links++;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
47 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
48 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
49
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
50 finput.close();
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
51 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
52
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
53 void
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
54 Graph::renumber(int type) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
55 vector<int> linked(links.size(),-1);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
56 vector<int> renum(links.size(),-1);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
57 int nb=0;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
58
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
59 for (unsigned int i=0 ; i<links.size() ; i++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
60 for (unsigned int j=0 ; j<links[i].size() ; j++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
61 linked[i]=1;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
62 linked[links[i][j].first]=1;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
63 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
64 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
65
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
66 for (unsigned int i=0 ; i<links.size() ; i++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
67 if (linked[i]==1)
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
68 renum[i]=nb++;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
69 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
70
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
71 for (unsigned int i=0 ; i<links.size() ; i++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
72 if (linked[i]==1) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
73 for (unsigned int j=0 ; j<links[i].size() ; j++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
74 links[i][j].first = renum[links[i][j].first];
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
75 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
76 links[renum[i]]=links[i];
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
77 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
78 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
79 links.resize(nb);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
80 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
81
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
82 void
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
83 Graph::clean(int type) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
84 for (unsigned int i=0 ; i<links.size() ; i++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
85 map<int, float> m;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
86 map<int, float>::iterator it;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
87
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
88 for (unsigned int j=0 ; j<links[i].size() ; j++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
89 it = m.find(links[i][j].first);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
90 if (it==m.end())
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
91 m.insert(make_pair(links[i][j].first, links[i][j].second));
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
92 else if (type==WEIGHTED)
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
93 it->second+=links[i][j].second;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
94 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
95
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
96 vector<pair<int,float> > v;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
97 for (it = m.begin() ; it!=m.end() ; it++)
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
98 v.push_back(*it);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
99 links[i].clear();
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
100 links[i]=v;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
101 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
102 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
103
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
104 void
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
105 Graph::display(int type) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
106 for (unsigned int i=0 ; i<links.size() ; i++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
107 for (unsigned int j=0 ; j<links[i].size() ; j++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
108 int dest = links[i][j].first;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
109 float weight = links[i][j].second;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
110 if (type==WEIGHTED)
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
111 cout << i << " " << dest << " " << weight << endl;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
112 else
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
113 cout << i << " " << dest << endl;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
114 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
115 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
116 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
117
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
118 void
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
119 Graph::display_binary(char *filename, char *filename_w, int type) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
120 ofstream foutput;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
121 foutput.open(filename, fstream::out | fstream::binary);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
122
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
123 unsigned int s = links.size();
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
124
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
125 // outputs number of nodes
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
126 foutput.write((char *)(&s),4);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
127
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
128 // outputs cumulative degree sequence
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
129 long tot=0;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
130 for (unsigned int i=0 ; i<s ; i++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
131 tot+=(long)links[i].size();
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
132 foutput.write((char *)(&tot),8);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
133 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
134
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
135 // outputs links
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
136 for (unsigned int i=0 ; i<s ; i++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
137 for (unsigned int j=0 ; j<links[i].size() ; j++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
138 int dest = links[i][j].first;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
139 foutput.write((char *)(&dest),4);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
140 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
141 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
142 foutput.close();
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
143
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
144 // outputs weights in a separate file
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
145 if (type==WEIGHTED) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
146 ofstream foutput_w;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
147 foutput_w.open(filename_w,fstream::out | fstream::binary);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
148 for (unsigned int i=0 ; i<s ; i++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
149 for (unsigned int j=0 ; j<links[i].size() ; j++) {
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
150 float weight = links[i][j].second;
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
151 foutput_w.write((char *)(&weight),4);
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
152 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
153 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
154 foutput_w.close();
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
155 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
156 }
f6ebec6e235e Uploaded
petrn
parents:
diff changeset
157