/* * Sample code for the DIS Update Stressmark * * This source code is the completely correct source code based on * the example codes provided by Atlantic Aerospace Division, Titan * Systems Corporation, 2000. * * If you just compile and generate the executables from this source * code, this code would be enough. However, if you wish to get a complete * understanding of this stressmark, it is strongly suggested that you * read the Benchmark Analysis and Specifications Document Version 1.0 * before going on since the detailed comments are given in this documents. * the comments are not repeated here. */ #include "DISstressmarkRNG.h" #include "extra.h" #include #include #include #include #define MIN_FIELD_SIZE 16 #define MAX_FIELD_SIZE 16777216 #define MIN_WINDOW_SIZE 1 #define MAX_WINDOW_SIZE 15 #define MIN_HOP_LIMIT 1 #define MAX_HOP_LIMIT 4294967295U #define MIN_SEED -2147483647 #define MAX_SEED -1 /* *main() */ int main(int argc, char **argv) { unsigned int *field; unsigned int f; unsigned int index; unsigned short int w; unsigned int maxhops; int seed; time_t startTime, endTime; unsigned int initial; unsigned int minStop; unsigned int maxStop; unsigned int hops; unsigned int l; assert(fscanf(stdin, "%u %u %u %d %u %u %u", &f, &l, &maxhops, &seed, &initial, &minStop, &maxStop) == 7); assert((f >= MIN_FIELD_SIZE) && (f <= MAX_FIELD_SIZE)); w = (unsigned int)l; assert((w >= MIN_WINDOW_SIZE) && (w <= MAX_WINDOW_SIZE)); assert(w % 2 == 1); assert(f > w); assert((maxhops >= MIN_HOP_LIMIT) && (maxhops <= MAX_HOP_LIMIT)); assert((seed >= MIN_SEED) && (seed <= MAX_SEED)); assert((initial >= 0) && (initial < f)); assert((minStop >= 0) && (minStop < f)); assert((maxStop >= 0) && (maxStop < f)); if ((field = (unsigned int *)malloc(f * sizeof(int))) == NULL) return (-1); SET_UP randInit(seed); for_each_job { for (l = 0; l < f; l++) { field[l] = randInt(0, f - w); } startTime = time(NULL); hops = 0; index = initial; while ((hops < maxhops) && (!((index >= minStop) && (index < maxStop)))) { int sum; unsigned int ll, lll; unsigned int max, min; unsigned int partition; unsigned int high; max = MAX_FIELD_SIZE; min = 0; high = 0; sum = 0; for (ll = 0; ll < w; ll++) { unsigned int balance; unsigned int x; x = field[index + ll]; sum += x; if (x > max) high++; else if (x > min) { /* start else* */ partition = x; balance = 0; for (lll = ll + 1; lll < w; lll++) { if (field[index + lll] > partition) balance++; } if (balance + high == w / 2) break; else if (balance + high > w / 2) { min = partition; } /* end if */ else { max = partition; high++; } /* end else */ } if (min == max) break; } /* end else* */ field[index] = sum % (f - w); index = (partition + hops) % (f - w); hops++; } /* end for loop */ } endTime = time(NULL); volatile int _stop_optimizer = hops; //fprintf(stdout, "%u hops\n", hops); fprintf(stderr, "time for update stressmark = %f seconds.\n", difftime(endTime, startTime)); free(field); WRITE_TO_FILE return (0); }