-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathGroupBy.cuh
117 lines (100 loc) · 2.34 KB
/
GroupBy.cuh
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
#ifndef __GROUPBY__
#define __GROUPBY__
#include "comm.h"
template<typename vertex_t, typename index_t>
int GroupBy(
index_t num_bfs,
vertex_t *source_list,
vertex_t *new_list,
csr_graph ggraph
){
index_t *hubmap=new index_t[ggraph->vert_count];
index_t *huboff=new index_t[ggraph->vert_count];
memset(hubmap,0,sizeof(index_t)*ggraph->vert_count);
memset(huboff,0,sizeof(index_t)*ggraph->vert_count);
/*counting eligible instances*/
for(index_t i=0;i<num_bfs;i++)
{
index_t beg=ggraph->beg_pos[source_list[i]];
index_t end=ggraph->beg_pos[source_list[i]+1];
/*out-degree <= sdegree*/
if(end-beg>128) continue;
for(index_t j=beg;j<end;j++)
{
/*has hub neighbor*/
if(ggraph->beg_pos[ggraph->adj_list[j]+1]-
ggraph->beg_pos[ggraph->adj_list[j]] > 128)
{
hubmap[ggraph->adj_list[j]]++;
break;
}
}
}
/*prefix-sum counted data*/
huboff[0]=0;
for(index_t i=1;i<ggraph->vert_count;i++)
huboff[i]=huboff[i-1]+hubmap[i-1];
index_t remainoff=huboff[ggraph->vert_count-1]+hubmap[ggraph->vert_count-1];
index_t test=0;
/*formulating group*/
for(index_t i=0;i<num_bfs;i++)
{
index_t beg=ggraph->beg_pos[source_list[i]];
index_t end=ggraph->beg_pos[source_list[i]+1];
/*non-eligible instance*/
if(end-beg>128)
{
new_list[remainoff]=source_list[i];
remainoff++;
test++;
continue;
}
/*eligible instance*/
bool isEligible=false;
for(index_t j=beg;j<end;j++)
{
/*has hub neighbor*/
if(ggraph->beg_pos[ggraph->adj_list[j]+1]-
ggraph->beg_pos[ggraph->adj_list[j]] > 128)
{
new_list[huboff[ggraph->adj_list[j]]]=source_list[i];
huboff[ggraph->adj_list[j]]++;
isEligible=true;
break;
}
}
if(!isEligible)
{
new_list[remainoff]=source_list[i];
remainoff++;
test++;
}
}
std::ofstream myfile("origin_source.dat");
std::ofstream newfile("new_source.dat");
for(index_t i=0;i<num_bfs;i++)
{
myfile<<source_list[i]<<"\n";
newfile<<new_list[i]<<"\n";
}
myfile.close();
newfile.close();
index_t remain=num_bfs;
index_t grouped=0;
std::cout<<"Eligible-BFS(by-source-remain): ";
for(index_t i=0;i<ggraph->vert_count;i++)
{
if(hubmap[i])
{
std::cout<<hubmap[i]<<" ";
grouped+=hubmap[i];
}
}
remain-=grouped;
std::cout<<remain<<"\n";
std::cout<<"Get test: "<<test<<"\n";
delete[] hubmap;
delete[] huboff;
return 0;
}
#endif