Commit 1dea95fb9241ca7e1e9b578aca2b2d0aced9efdf
1 parent
3604dfae01
Exists in
master
add upper border to 100
Showing 1 changed file with 101 additions and 103 deletions Side-by-side Diff
lab3/mpi_heat2D.c
View file @
1dea95f
| ... | ... | @@ -73,10 +73,10 @@ |
| 73 | 73 | float EPSILON=_EPSILON; |
| 74 | 74 | |
| 75 | 75 | |
| 76 | - /* INITIALIZE MPI */ | |
| 76 | + /* INITIALIZE MPI */ | |
| 77 | 77 | MPI_Init(&argc, &argv); |
| 78 | - | |
| 79 | - /* GET THE PROCESSOR ID AND NUMBER OF PROCESSORS */ | |
| 78 | + | |
| 79 | + /* GET THE PROCESSOR ID AND NUMBER OF PROCESSORS */ | |
| 80 | 80 | MPI_Comm_rank(MPI_COMM_WORLD, &rank); |
| 81 | 81 | MPI_Comm_size(MPI_COMM_WORLD, &size); |
| 82 | 82 | |
| ... | ... | @@ -90,7 +90,7 @@ |
| 90 | 90 | fprintf(stderr,"\t\texample N = 100, EPSILON = 0.1\n"); |
| 91 | 91 | return -1; |
| 92 | 92 | } |
| 93 | - | |
| 93 | + | |
| 94 | 94 | N = M = atoi(argv[1]); |
| 95 | 95 | EPSILON = atof(argv[2]); |
| 96 | 96 | |
| 97 | 97 | |
| 98 | 98 | |
| 99 | 99 | |
| 100 | 100 | |
| 101 | 101 | |
| 102 | 102 | |
| 103 | 103 | |
| 104 | 104 | |
| 105 | 105 | |
| 106 | 106 | |
| 107 | 107 | |
| 108 | 108 | |
| 109 | 109 | |
| 110 | 110 | |
| 111 | 111 | |
| ... | ... | @@ -102,64 +102,71 @@ |
| 102 | 102 | |
| 103 | 103 | } |
| 104 | 104 | |
| 105 | - //Wait for rank 0 , all process start here | |
| 106 | - MPI_Barrier(MPI_COMM_WORLD); | |
| 105 | + //Wait for rank 0 , all process start here | |
| 106 | + MPI_Barrier(MPI_COMM_WORLD); | |
| 107 | 107 | |
| 108 | - //Exchange N | |
| 109 | - MPI_Bcast(&N , 1, MPI_FLOAT, 0 , MPI_COMM_WORLD); | |
| 110 | - //Exchange EPSILON | |
| 111 | - MPI_Bcast(&EPSILON , 1, MPI_FLOAT, 0 , MPI_COMM_WORLD); | |
| 108 | + //Exchange N | |
| 109 | + MPI_Bcast(&N , 1, MPI_FLOAT, 0 , MPI_COMM_WORLD); | |
| 110 | + //Exchange EPSILON | |
| 111 | + MPI_Bcast(&EPSILON , 1, MPI_FLOAT, 0 , MPI_COMM_WORLD); | |
| 112 | 112 | |
| 113 | - //local size | |
| 114 | - M = (N-2)/size + 2; | |
| 113 | + //local size | |
| 114 | + M = (N-2) / size + 2 ; | |
| 115 | 115 | |
| 116 | - float *u = (float *)malloc(N * M * sizeof(float)); | |
| 117 | - float *unew = (float *)malloc(N * M * sizeof(float)); | |
| 116 | + float *u = (float *)malloc(N * M * sizeof(float)); | |
| 117 | + float *unew = (float *)malloc(N * M * sizeof(float)); | |
| 118 | 118 | |
| 119 | - if(u==0 || unew ==0) | |
| 120 | - { | |
| 121 | - perror("Can't allocated data\n"); | |
| 122 | - return -1; | |
| 123 | - } | |
| 119 | + if(u==0 || unew ==0) | |
| 120 | + { | |
| 121 | + perror("Can't allocated data\n"); | |
| 122 | + return -1; | |
| 123 | + } | |
| 124 | 124 | |
| 125 | - if(rank==0) { | |
| 126 | - | |
| 127 | - printf ( "\n" ); | |
| 128 | - printf ( "HEATED_PLATE\n" ); | |
| 129 | - printf ( " Parallel MPI version using %d processors \n",size ); | |
| 130 | - printf ( " A program to solve for the steady state temperature distribution\n" ); | |
| 131 | - printf ( " over a rectangular plate.\n" ); | |
| 132 | - printf ( "\n" ); | |
| 133 | - printf ( " Spatial grid of %d by %d points.\n", N, N ); | |
| 134 | - printf ( " Each processor will use grid of %d +2 by %d points.\n", M-2, N ); | |
| 135 | - printf ( " The iteration will end until tolerance <= %f\n\n",EPSILON); | |
| 136 | - | |
| 137 | - } | |
| 138 | - | |
| 139 | - /* Initialize grid and create input file | |
| 140 | - * each process initialize its part | |
| 141 | - * */ | |
| 125 | + if(rank==0) { | |
| 142 | 126 | |
| 143 | - inidat(rank,size,M,N,u,unew); | |
| 127 | + printf ( "\n" ); | |
| 128 | + printf ( "HEATED_PLATE\n" ); | |
| 129 | + printf ( " Parallel MPI version using %d processors \n",size ); | |
| 130 | + printf ( " A program to solve for the steady state temperature distribution\n" ); | |
| 131 | + printf ( " over a rectangular plate.\n" ); | |
| 132 | + printf ( "\n" ); | |
| 133 | + printf ( " Spatial grid of %d by %d points.\n", N, N ); | |
| 134 | + printf ( " Each processor will use grid of %d by %d points.\n", M, N ); | |
| 135 | + printf ( " The iteration will end until tolerance <= %f\n\n",EPSILON); | |
| 144 | 136 | |
| 145 | - prtdat(rank,size,M,N,u, "initial.dat"); | |
| 137 | + } | |
| 146 | 138 | |
| 139 | + /* Initialize grid and create input file | |
| 140 | + * each process initialize its part | |
| 141 | + * */ | |
| 147 | 142 | |
| 148 | - /* | |
| 149 | - * iterate until the new solution unew differs from the old solution u | |
| 143 | + inidat(rank,size,M,N,u,unew); | |
| 144 | + | |
| 145 | + prtdat(rank,size,M,N,u, "initial.dat"); | |
| 146 | + | |
| 147 | + | |
| 148 | + float diff, globaldiff=1.0; | |
| 149 | + int iter=0; | |
| 150 | + | |
| 151 | + /* | |
| 152 | + * iterate (JACOBI ITERATION) until the new solution unew differs from the old solution u | |
| 150 | 153 | * by no more than EPSILON. |
| 151 | - * */ | |
| 154 | + **/ | |
| 152 | 155 | |
| 153 | - float diff=1.0; | |
| 154 | - int iter=0; | |
| 156 | + while(globaldiff> EPSILON) { | |
| 155 | 157 | |
| 156 | - while(diff> EPSILON) { | |
| 158 | + diff= update(rank,size,M,N, u, unew); | |
| 157 | 159 | |
| 158 | - diff= update(rank,size,M,N, u, unew); | |
| 160 | + /** | |
| 161 | + * COMPUTE GLOBAL CONVERGENCE | |
| 162 | + * */ | |
| 159 | 163 | |
| 164 | + MPI_Allreduce(&diff, &globaldiff , 1, MPI_FLOAT, MPI_MAX, MPI_COMM_WORLD); | |
| 165 | + | |
| 166 | + | |
| 160 | 167 | if(rank==0) |
| 161 | 168 | if(iter%ITER_PRINT==0) |
| 162 | - printf("Processor #%d, iteration %d, epsilon = %f\n ", rank,iter,diff); | |
| 169 | + printf("Processor #%d, iteration %d, epsilon = %f\n ", rank,iter,globaldiff); | |
| 163 | 170 | iter++; |
| 164 | 171 | } |
| 165 | 172 | |
| 166 | 173 | |
| 167 | 174 | |
| ... | ... | @@ -177,27 +184,26 @@ |
| 177 | 184 | float update(int rank, int size, int nx,int ny, float *u, float *unew){ |
| 178 | 185 | int ix, iy; |
| 179 | 186 | float diff=0.0; |
| 180 | - float globaldiff; | |
| 181 | 187 | MPI_Status status; |
| 182 | 188 | |
| 183 | 189 | |
| 184 | - /* | |
| 185 | - * EXCHANGE GHOST CELL | |
| 186 | - */ | |
| 187 | - if (rank > 0 && rank< size-1) | |
| 188 | - { | |
| 189 | - MPI_Sendrecv(&u[ny*(nx-2)], ny, MPI_FLOAT, rank+1, 0, | |
| 190 | - &u[ny*0], ny, MPI_FLOAT, rank-1, 0, MPI_COMM_WORLD, &status); | |
| 191 | - MPI_Sendrecv(&u[ny*1], ny, MPI_FLOAT, rank-1, 1, | |
| 192 | - &u[ny*(nx-1)], ny, MPI_FLOAT, rank+1, 1, MPI_COMM_WORLD, &status); | |
| 193 | - } | |
| 190 | + /* | |
| 191 | + * EXCHANGE GHOST CELL | |
| 192 | + */ | |
| 193 | + if (rank > 0 && rank< size-1) | |
| 194 | + { | |
| 195 | + MPI_Sendrecv(&u[ny*(nx-2)], ny, MPI_FLOAT, rank+1, 0, | |
| 196 | + &u[ny*0], ny, MPI_FLOAT, rank-1, 0, MPI_COMM_WORLD, &status); | |
| 197 | + MPI_Sendrecv(&u[ny*1], ny, MPI_FLOAT, rank-1, 1, | |
| 198 | + &u[ny*(nx-1)], ny, MPI_FLOAT, rank+1, 1, MPI_COMM_WORLD, &status); | |
| 199 | + } | |
| 194 | 200 | |
| 195 | - else if (rank == 0 && rank< size-1) | |
| 196 | - MPI_Sendrecv(&u[ny*(nx-2)], ny, MPI_FLOAT, rank+1, 0, | |
| 197 | - &u[ny*(nx-1)], ny, MPI_FLOAT, rank+1, 1, MPI_COMM_WORLD, &status); | |
| 198 | - else if ( rank> 0 && rank == size-1) | |
| 199 | - MPI_Sendrecv(&u[ny*1], ny, MPI_FLOAT, rank-1, 1, | |
| 200 | - &u[ny*0], ny, MPI_FLOAT, rank-1, 0, MPI_COMM_WORLD, &status); | |
| 201 | + else if (rank == 0) | |
| 202 | + MPI_Sendrecv(&u[ny*(nx-2)], ny, MPI_FLOAT, rank+1, 0, | |
| 203 | + &u[ny*(nx-1)], ny, MPI_FLOAT, rank+1, 1, MPI_COMM_WORLD, &status); | |
| 204 | + else if (rank == size-1) | |
| 205 | + MPI_Sendrecv(&u[ny*1], ny, MPI_FLOAT, rank-1, 1, | |
| 206 | + &u[ny*0], ny, MPI_FLOAT, rank-1, 0, MPI_COMM_WORLD, &status); | |
| 201 | 207 | |
| 202 | 208 | |
| 203 | 209 | |
| ... | ... | @@ -218,19 +224,6 @@ |
| 218 | 224 | } |
| 219 | 225 | |
| 220 | 226 | |
| 221 | - /** | |
| 222 | - * COMPUTE GLOBAL CONVERGENCE | |
| 223 | - * | |
| 224 | - * */ | |
| 225 | - | |
| 226 | - MPI_Allreduce(&diff, &globaldiff , 1, MPI_FLOAT, MPI_MAX, MPI_COMM_WORLD); | |
| 227 | - | |
| 228 | - | |
| 229 | - /** | |
| 230 | - * COPY OLD DATA | |
| 231 | - * */ | |
| 232 | - | |
| 233 | - | |
| 234 | 227 | for (ix = 1; ix < nx-1; ix++) { |
| 235 | 228 | for (iy = 1; iy < ny-1; iy++) { |
| 236 | 229 | u[ix*ny+iy] = unew[ix*ny+iy]; |
| ... | ... | @@ -238,7 +231,7 @@ |
| 238 | 231 | } |
| 239 | 232 | |
| 240 | 233 | |
| 241 | - return globaldiff; | |
| 234 | + return diff; | |
| 242 | 235 | } |
| 243 | 236 | |
| 244 | 237 | /***************************************************************************** |
| 245 | 238 | |
| 246 | 239 | |
| 247 | 240 | |
| ... | ... | @@ -260,32 +253,37 @@ |
| 260 | 253 | u[ix*ny+iy]=0.0; |
| 261 | 254 | } |
| 262 | 255 | |
| 263 | - //boundary left | |
| 264 | - for (ix = 1; ix < nx-1; ix++){ | |
| 256 | + //boundary left | |
| 257 | + for (ix = 0; ix < nx; ix++){ | |
| 265 | 258 | u[ix*ny]=100.0; |
| 266 | 259 | |
| 267 | 260 | } |
| 268 | 261 | |
| 269 | 262 | //boundary right |
| 270 | - for (ix = 1; ix < nx-1; ix++){ | |
| 263 | + for (ix = 0; ix < nx; ix++){ | |
| 271 | 264 | u[ix*ny+ (ny-1)]=100.0; |
| 272 | 265 | |
| 273 | 266 | } |
| 274 | 267 | |
| 275 | 268 | //boundary down |
| 276 | - for (iy = 0; iy < ny; iy++){ | |
| 277 | - | |
| 278 | - if(rank==size-1) { | |
| 279 | - u[(nx-1)*(ny)+iy]=100.0; | |
| 280 | - }else | |
| 281 | - { | |
| 282 | - u[(nx-1)*(ny)+iy]=0.0; | |
| 283 | - } | |
| 269 | + for (iy = 1; iy < ny-1; iy++){ | |
| 270 | + | |
| 271 | + if(rank==size-1) { | |
| 272 | + u[(nx-1)*(ny)+iy]=100.0; | |
| 273 | + u[0]=100.0; | |
| 274 | + | |
| 275 | + }else | |
| 276 | + { | |
| 277 | + u[(nx-1)*(ny)+iy]=0.0; | |
| 278 | + } | |
| 284 | 279 | } |
| 285 | 280 | |
| 286 | 281 | //boundary top |
| 287 | - for (iy = 0; iy < ny; iy++){ | |
| 288 | - u[iy]=0.0; | |
| 282 | + for (iy = 1; iy < ny-1; iy++){ | |
| 283 | + if(rank==0) | |
| 284 | + u[iy]=100.0; | |
| 285 | + else | |
| 286 | + u[iy]=0.0; | |
| 289 | 287 | |
| 290 | 288 | } |
| 291 | 289 | |
| 292 | 290 | |
| 293 | 291 | |
| ... | ... | @@ -300,13 +298,13 @@ |
| 300 | 298 | { |
| 301 | 299 | int ix, iy; |
| 302 | 300 | FILE *fp; |
| 303 | - | |
| 301 | + | |
| 304 | 302 | char str[255]; |
| 305 | - | |
| 303 | + | |
| 306 | 304 | sprintf(str, "%d_%s", rank,fname); |
| 307 | 305 | |
| 308 | 306 | fp = fopen(str, "w"); |
| 309 | - | |
| 307 | + | |
| 310 | 308 | for (ix = 0 ; ix < nx; ix++) { |
| 311 | 309 | for (iy =0; iy < ny; iy++) { |
| 312 | 310 | |
| ... | ... | @@ -335,7 +333,7 @@ |
| 335 | 333 | * * */ |
| 336 | 334 | |
| 337 | 335 | |
| 338 | - print2file(rank,nx,ny,u,fname); | |
| 336 | + print2file(rank,nx,ny,u,fname); | |
| 339 | 337 | |
| 340 | 338 | } |