00001
00007 #include "common.h"
00008 #include "InfoStream.h"
00009 #include "AlgNbor.h"
00010
00011 #define TINYLOAD 0.0005
00012
00013 AlgNbor::AlgNbor(int pe, computeInfo *computeArray, patchInfo *patchArray,
00014 processorInfo *processorArray, int nComps,
00015 int nPatches, int nPes, int nNbs) :
00016 Rebalancer(computeArray, patchArray,
00017 processorArray, nComps,
00018 nPatches, nPes)
00019 {
00020 strategyName = "AlgNbor";
00021 mype = pe;
00022 nNbors = nNbs;
00023 strategy();
00024 }
00025
00026 void AlgNbor::strategy()
00027 {
00028 int i, j;
00029 double startTime = CmiWallTimer();
00030
00031
00032
00033 for (i=0; i<numComputes; i++) {
00034 assign((computeInfo *) &(computes[i]),
00035 (processorInfo *) &(processors[computes[i].oldProcessor]));
00036 }
00037
00038
00039 if (processors[mype].available == CmiFalse) return;
00040
00041
00042 double myload = processors[mype].load;
00043 double avgload = 0.0;
00044 for (i=0; i<P; i++) {
00045 if (processors[i].Id >= 0) {
00046
00047 avgload += processors[i].load;
00048 }
00049 }
00050 avgload /= (nNbors+1);
00051
00052 if (myload <= avgload) return;
00053
00054 CmiPrintf("[%d]:Myload: %f, avrage load: %f. \n", mype, myload, avgload);
00055
00056 Set *lightProcessors = new Set();
00057 for (i=0; i<P; i++) {
00058 if (processors[i].Id >= 0 && i != mype)
00059 if (processors[i].load < processors[mype].load)
00060 lightProcessors->insert((InfoRecord *) &(processors[i]));
00061 }
00062
00063 int done = 0;
00064 while (processors[mype].load > avgload)
00065 {
00066 processorInfo* goodP[3][3];
00067 computeInfo* goodCompute[3][3];
00068 double goodSize[3][3];
00069 processorInfo* bestP;
00070
00071 Iterator nextProcessor;
00072 if (lightProcessors->numElements() == 0) break;
00073 processorInfo *p = (processorInfo *)lightProcessors->iterator((Iterator *) &nextProcessor);
00074 for(i=0; i < 3; i++)
00075 for(j=0; j<3; j++) {
00076 goodP[i][j] = 0;
00077 goodCompute[i][j] = 0;
00078 goodSize[i][j] = 0.;
00079 }
00080 while (p)
00081 {
00082 Iterator nextCompute;
00083 nextCompute.id = 0;
00084 if (processors[mype].computeSet.numElements() == 0) break;
00085 computeInfo *c = (computeInfo *)
00086 processors[mype].computeSet.iterator((Iterator *)&nextCompute);
00087 while (c) {
00088
00089 if (c->load + p->load < processors[mype].load - c->load) {
00090 int nPatches, nProxies, badForComm;
00091 numAvailable(c,p,&nPatches,&nProxies,&badForComm);
00092
00093 if ( c->load > goodSize[nPatches][nProxies] ) {
00094 goodSize[nPatches][nProxies] = c->load;
00095 goodCompute[nPatches][nProxies] = c;
00096 goodP[nPatches][nProxies] = p;
00097 }
00098 }
00099
00100 nextCompute.id++;
00101 c = (computeInfo *) processors[mype].computeSet.
00102 next((Iterator *)&nextCompute);
00103 }
00104 p = (processorInfo *)
00105 lightProcessors->next((Iterator *) &nextProcessor);
00106 }
00107 if (goodCompute[2][0]) {
00108 deAssign(goodCompute[2][0], &processors[mype]);
00109 assign(goodCompute[2][0], goodP[2][0]);
00110 bestP = goodP[2][0];
00111 } else if (goodCompute[1][1]) {
00112 deAssign(goodCompute[1][1], &processors[mype]);
00113 assign(goodCompute[1][1], goodP[1][1]);
00114 bestP = goodP[1][1];
00115 } else if (goodCompute[0][2]) {
00116 deAssign(goodCompute[0][2], &processors[mype]);
00117 assign(goodCompute[0][2], goodP[0][2]);
00118 bestP = goodP[0][2];
00119 } else if (goodCompute[1][0]) {
00120 deAssign(goodCompute[1][0], &processors[mype]);
00121 assign(goodCompute[1][0], goodP[1][0]);
00122 bestP = goodP[1][0];
00123 } else if (goodCompute[0][1]) {
00124 deAssign(goodCompute[0][1], &processors[mype]);
00125 assign(goodCompute[0][1], goodP[0][1]);
00126 bestP = goodP[0][1];
00127 } else if (goodCompute[0][0]) {
00128 deAssign(goodCompute[0][0], &processors[mype]);
00129 assign(goodCompute[0][0], goodP[0][0]);
00130 bestP = goodP[0][0];
00131 } else {
00132 iout << iINFO << "AlgNbor: No receiver found" << "\n" << endi;
00133 break;
00134 }
00135 if (bestP->load > processors[mype].load)
00136 lightProcessors->remove(bestP);
00137 }
00138
00139
00140
00141
00142
00143
00144
00145
00146
00147
00148
00149
00150
00151
00152
00153
00154
00155
00156
00157
00158
00159
00160
00161
00162
00163
00164
00165
00166
00167
00168
00169
00170
00171
00172
00173
00174
00175
00176
00177
00178
00179
00180
00181
00182
00183
00184
00185
00186
00187
00188
00189
00190
00191
00192
00193
00194
00195
00196
00197
00198
00199
00200
00201
00202
00203
00204
00205
00206
00207
00208
00209
00210
00211
00212
00213
00214
00215
00216
00217
00218
00219
00220
00221
00222
00223
00224
00225
00226
00227
00228
00229
00230
00231
00232
00233
00234
00235
00236
00237
00238
00239
00240
00241
00242
00243
00244
00245
00246
00247
00248 CmiPrintf("AlgNbor finish time: %f.\n", CmiWallTimer()-startTime);
00249 }
00250
00251
00252
00253
00254
00255
00256
00257
00258
00259
00260
00261
00262
00263
00264