-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathbfs.c
124 lines (98 loc) · 3 KB
/
bfs.c
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
118
119
120
121
122
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <string.h>
#include <errno.h>
#include <stdbool.h>
#define V 512
#define E V*8
/* Markers used to bound trace regions of interest */
volatile char MARKER_START, MARKER_END;
static int csr_edges[E]; /* edge array */
static int csr_index[V + 1]; /* edge index */
static bool visited[V];
static int frontier[V];
int max_v_index=0;
void load_csr(char *csr_fn);
void bfs(int source);
void display();
int main(int argc, char* argv[]) {
int i, source = 0;
for (i = 0; i < V; i++) {
visited[i] = false;
frontier[i] = -1;
csr_index[i] = -1;
}
csr_index[i] = -1;
/****************修改路径*******************/
load_csr("./XXXX.txt");
/******************************************/
/* Record marker addresses */
FILE* marker_fp = fopen(".marker", "w");
assert(marker_fp);
fprintf(marker_fp, "%llx %llx",
(unsigned long long int) &MARKER_START,
(unsigned long long int) &MARKER_END );
fclose(marker_fp);
MARKER_START = 33; /* access marker to generate a trace record */
bfs(source);
MARKER_END = 34; /* access marker again */
/* validate result */
FILE* result_fp = fopen(".bfs_result", "w");
for (i = 0; i < V; i++ ) {
if (frontier[i] != -1) {
fprintf(result_fp, "%d\n", frontier[i]);
}
}
fclose(result_fp);
return 0;
} /*End of main()*/
/*
use script to sort, remap and dedup edge list file load preprocessed graphs for evaluation
add reverse edge to prepare a bi-directional graph for undirectional traversal load pre-processed edges into csr directly
E.g.:
grep -v ^# facebook_combined.txt | awk '{print $1" "$2"\n"$2" "$1}' | sort -n -k1 -k2 | uniq
*/
void load_csr(char *csr_fn) {
char buf[1000];
unsigned int num_v = 0, num_e = 0;
int v_from, v_to, v_prev = 0;
FILE* csr_fp = fopen(csr_fn, "r");
if(!csr_fp){
fprintf(stderr, "%s: %s\n", csr_fn, strerror(errno));
exit(1);
}
csr_index[0] = 0;
while(fgets(buf, 1000, csr_fp) != NULL) {
sscanf(buf, "%u %u", &v_from, &v_to);
if (v_from > v_prev) {
num_v++;
for (int i=(v_prev+1); i<=v_from; i++) csr_index[i] = num_e;
v_prev = v_from;
}
csr_edges[num_e] = v_to;
num_e++;
}
csr_index[v_from+1]=num_e;
max_v_index=v_from;
fclose(csr_fp);
} /*End of load_csr()*/
void bfs(int source) {
int v = source, n;
long long int i, front = 0, rear = 0;
visited[v] = true;
frontier[rear] = v;
while (front <= rear) {
v = frontier[front]; /* delete from queue */
front++;
for (i = csr_index[v]; i < csr_index[v + 1]; i++) {
/* Check for adjacent unvisited nodes */
n = csr_edges[i];
if (visited[n] == false) {
visited[n] = true;
rear++;
frontier[rear] = n;
}
}
}
} /*End of bfs()*/