-
Notifications
You must be signed in to change notification settings - Fork 0
/
driver.c
149 lines (113 loc) · 3.68 KB
/
driver.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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
#include "header.h"
void validate(int* output, int globalNumElements) {
int i = 0;
assert(output != NULL);
for(i = 0; i < globalNumElements - 1; i++) {
if (output[i] > output[i+1]) {
printf("************* NOT sorted *************\n");
return;
}
}
printf("============= SORTED ===========\n");
}
extern int compare (const void * a, const void * b);
long long
timeval_diff(struct timeval *difference,
struct timeval *end_time,
struct timeval *start_time) {
struct timeval temp_diff;
if(difference == NULL){
difference=&temp_diff;
}
difference->tv_sec = end_time->tv_sec - start_time->tv_sec ;
difference->tv_usec = end_time->tv_usec - start_time->tv_usec;
while(difference->tv_usec < 0){
difference->tv_usec += 1000000;
difference->tv_sec -= 1;
}
return 1000000LL * difference->tv_sec + difference->tv_usec;
} /* timeval_diff() */
int main(int argc, char **argv)
{
// file pointers
FILE* fin = NULL;
FILE* fout = NULL;
// variables
int* globalInput = NULL;
int* input = NULL;
int* mirror = NULL;
int* output = NULL;
int globalNumElements, dataLength, sizeToRecv, i, j;
MPI_Comm comm;
int commRank, commSize;
// time related
long long diff;
struct timeval starttime, endtime, timediff;
MPI_Init( &argc, &argv );
MPI_Comm_rank( MPI_COMM_WORLD, &commRank );
MPI_Comm_size( MPI_COMM_WORLD, &commSize );
if (commRank == 0) {
//read input_size and input
if((fin = fopen("input.txt", "r")) == NULL)
{printf("Error opening input file\n"); exit(0);}
fscanf(fin, "%d", &globalNumElements);
if( !(globalInput = (int *)calloc(globalNumElements, sizeof(int))) )
{printf("Memory error\n"); exit(0);}
if( !(mirror = (int *)calloc(globalNumElements, sizeof(int))) )
{printf("Memory error\n"); exit(0);}
for(i = 0; i < globalNumElements || feof(fin); i++)
{
fscanf(fin, "%d", &globalInput[i]);
mirror[i] = globalInput[i];
}
if(i < globalNumElements)
{printf("Invalid input\n"); exit(0);}
}
MPI_Bcast (&globalNumElements, 1, MPI_INT, 0, MPI_COMM_WORLD);
if( !(input = (int *)calloc(globalNumElements, sizeof(int))) )
{printf("Memory error\n"); exit(0);}
dataLength = globalNumElements / commSize;
MPI_Scatter (globalInput, dataLength, MPI_INT, input, dataLength, MPI_INT, 0, MPI_COMM_WORLD);
comm = MPI_COMM_WORLD;
MPI_Barrier(MPI_COMM_WORLD);
if (commRank == 0) {
gettimeofday(&starttime,0x0);
}
// CALL TO SORT FUNCTION
output = mpiqsort(input, globalNumElements, &dataLength, comm, commRank, commSize);
MPI_Barrier(MPI_COMM_WORLD);
if (commRank == 0) {
gettimeofday(&endtime,0x0);
j = 0;
for(i = 1; i < commSize; i++) {
MPI_Recv (&sizeToRecv, 1, MPI_INT, i, i, MPI_COMM_WORLD, NULL);
MPI_Recv (globalInput + j, sizeToRecv, MPI_INT, i, i, MPI_COMM_WORLD, NULL);
j += sizeToRecv;
}
if((fout = fopen("output.txt", "w")) == NULL) {
printf("Error opening output file\n");
exit(0);
}
fprintf(fout, "%d\n", globalNumElements);
for (i = 0; i < dataLength; i++)
fprintf(fout, "%d\n", output[i]);
for (i = 0; i < globalNumElements - dataLength; i++)
fprintf(fout, "%d\n", globalInput[i]);
fclose (fout);
diff = timeval_diff(&timediff,&endtime,&starttime);
printf("Time to sort = %lld micro seconds\n", diff);
gettimeofday(&starttime,0x0);
qsort(mirror,globalNumElements,sizeof(int),compare);
gettimeofday(&endtime,0x0);
long long sdiff = timeval_diff(&timediff,&endtime,&starttime);
printf("Time to serial sort = %lld micro seconds\n", sdiff);
double speedup = (double)sdiff / diff;
printf("Speedup is %lf\n",speedup);
}
else {
MPI_Send (&dataLength, 1, MPI_INT, 0, commRank, MPI_COMM_WORLD);
MPI_Send (output, dataLength, MPI_INT, 0, commRank, MPI_COMM_WORLD);
}
MPI_Finalize();
return 0;
}