forked from ModelDBRepository/82894
-
Notifications
You must be signed in to change notification settings - Fork 0
/
balcomp.hoc
94 lines (85 loc) · 2.1 KB
/
balcomp.hoc
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
{localloadfile("nrngui.hoc")}
{localloadfile("loadbal.hoc")}
objref gidvec, cvec, splitxlist, splitixlist, cpu, splitcplx, splitindex, bal
objref splitbres, splitbrlist
bal = new LoadBalance()
gidvec = new Vector()
cvec = new Vector()
splitxlist = new List()
splitixlist = new List()
splitbrlist = new List()
cpu = new Vector()
splitcplx = new Vector()
splitindex = new Vector()
splitbres = new Vector()
proc rdat() {local i, j, k, n1, n2, n3, c, n3 localobj f, vecx, vecix, vecb
f = new File()
f.ropen($s1)
n1 = f.scanvar()
for i=0, n1-1 {
n2 = f.scanvar()
for j=0, n2-1 {
f.scanvar()
gid = f.scanvar()
c = f.scanvar()
n3 = f.scanvar()
gidvec.append(gid)
cvec.append(c)
vecx = new Vector(n3)
vecix = new Vector(n3)
vecb = new Vector(n3)
for k = 0, n3-1 {
vecx.x[k] = f.scanvar()
vecix.x[k] = f.scanvar()
vecb.x[k] = f.scanvar()
}
splitxlist.append(vecx)
splitixlist.append(vecix)
splitbrlist.append(vecb)
}
}
}
func balance() {local i, err localobj f, si, s
s =new String()
sprint(s.s, "%s.dat", $s2)
rdat(s.s)
err = bal.distrib($1, cvec, splitxlist, splitixlist, \
cpu, splitcplx, splitindex, splitbrlist, splitbres)
f = new File()
sprint(s.s, "%s.%d", $s2, $1)
f.wopen(s.s)
f.printf("%d\n", gidvec.size)
si = cpu.sortindex
for i=0, gidvec.size-1 {
f.printf("%d %d %d %d %d %d\n", cpu.x[si.x[i]], \
gidvec.x[si.x[i]], splitindex.x[si.x[i]], \
splitbres.x[si.x[i]], \
splitcplx.x[si.x[i]], cvec.x[si.x[i]], \
bal.cplx.x[cpu.x[si.x[i]]] )
}
f.close()
return err
}
objref pc
pc = new ParallelContext()
ncpu = 32*2^(pc.id)
percenterr = balance(ncpu, "balance")
//bal.cplx.printf
//print cvec.sum
//print bal.cplx.sum
{printf("ncpu=%d load balance error = %d%% average load = %d max load = %d\n", ncpu, percenterr, cvec.sum/ncpu, bal.cplx.max)}
proc chkbal() {local i localobj ix, split
ix = new Vector()
split= new Vector()
for i=0, cpu.max-1 {
ix.indvwhere(cpu, "==", i)
split.index(splitindex, ix)
if (split.indvwhere("!=", 0).size > 1) {
printf("cpu %d with %d\n", i, split.size)
}
}
}
chkbal()
{pc.runworker()}
{pc.done()}
quit()