Я пытаюсь сделать MPI_Bcast в цикле, передающем каждый элемент фрагмента массива, соответствующего процессу. Проблема в том, что функция stencil()
работает через MPI_bcast, она не работает внутри функции, в конце программы каждыйпроцесс имеет свои результаты, но не результаты других процессов.Я знаю, может быть, это не лучшее решение, но мне нужна только эта работа, и я не знаю, почему она не работает
#include "mpi.h"
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <sys/time.h>
#define N 4
#define ITERS 1
#define ARRAY_SIZE (N+2) * (N+2)
// N and ITERS might be input arguments
double **A;
long usecs (void)
{
struct timeval t;
gettimeofday(&t,NULL);
return t.tv_sec*1000000+t.tv_usec;
}
void initialize (double **A)
{
int i,j;
for(i =0; i < N+2 ; i++){
for(j =0; j < N+2 ; j++){
if(i== 0 || j == 0 || i == (N+1) || j == (N +1) )
A[i][j] = 0.0;
else
A[i][j] = rand() % 10 + 1;
}
}
}
void sendToAll(double **A){
int i,j;
for(i =0; i < N+2 ; i++){
for(j =0; j < N+2 ; j++){
MPI_Bcast( &A[i][j], 1, MPI_DOUBLE, 0, MPI_COMM_WORLD);
}
}
}
void sendResultToAll(double **A, int start, int end,int sender){
int i = start;
int j;
for(i =start; i <= end; i++){
for(j =0; j < N+2 ; j++){
//if(sender == 0)
//printf("rank = %d,i= %d j=%d\n",sender,i,j );
MPI_Bcast( &A[i][j], 1, MPI_DOUBLE, sender, MPI_COMM_WORLD);
}
}
}
void showArray(double **A){
int i,j;
printf("\n");
for(i =0 ; i < N+2 ; i++){
for(j =0; j < N+2 ; j++){
printf("%f, ",A[i][j]);
}
printf("\n");
}
}
void stencil(double **A, int start, int end,int sender){
int i = start;
int j;
for(i; i <= end; i++){
for(j =1; j <= N ; j++){
A[i][j] = 0.3 *( A[i][j] + A[i-1][j] + A[i+1][j] + A[i][j-1] + A[i][j+1]);
MPI_Bcast( &A[i][j], 1, MPI_DOUBLE, sender, MPI_COMM_WORLD);
}
}
}
int main(int argc, char * argv[]){
int rank, size,tag=1;
char msg='A';
double row;
MPI_Status status;
//long t_start,t_end;
//double tmp,time;
//srand ( time(NULL) );
MPI_Init(&argc, &argv);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
MPI_Comm_size(MPI_COMM_WORLD, &size);
int n_per_proc = N/size;
printf("Process # %d started \n", rank);
MPI_Barrier(MPI_COMM_WORLD);
A = malloc((N+2) * sizeof(double *));
int i;
for (i=0; i<N+2; i++) {
A[i] = malloc((N+2) * sizeof(double));
}
if(rank == 0){
initialize(A);
}
sendToAll(A);
int start = n_per_proc * rank +1;
int end = n_per_proc * (rank+1);
if(rank == size-1)
end = N;
/*printf("rank = %d start = %d\n",rank, start );
printf("rank = %d end = %d\n",rank, end );
printf("%s\n");*/
int idx;
for(idx = 0; idx < ITERS; idx++){
stencil(A, start,end,rank);
//sendResultToAll(A,start,end,rank);
MPI_Barrier(MPI_COMM_WORLD);
}
showArray(A);
//time = ((double)(t_end-t_start))/1000000;
//printf("Computation time = %f\n", time);
printf("Finishing proc %d\n", rank);
MPI_Barrier(MPI_COMM_WORLD);
MPI_Finalize();
}