nie dziala wysylanie pelnych wektorow - bedzie zaimplementowana wersja tymczasowa

This commit is contained in:
2016-10-31 20:41:05 +01:00
parent 516768a97a
commit c41697a808

View File

@@ -49,7 +49,7 @@ void array_destroy(long **arr)
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
long **A=NULL, **B=NULL, **C=NULL, *B_rot=NULL, *vect=NULL; long **A=NULL, **B=NULL, **C=NULL, *B_rot=NULL, *vect=NULL, *vect_c=NULL;
long rozmiar=0; long rozmiar=0;
char *endptr; char *endptr;
TTiming tt; TTiming tt;
@@ -91,8 +91,11 @@ int main(int argc, char *argv[])
array_alloc(B, rozmiar); array_alloc(B, rozmiar);
vect_alloc(B_rot, rozmiar*rozmiar); vect_alloc(B_rot, rozmiar*rozmiar);
} }
int porcja = (rozmiar*rozmiar)/ntasks + (rozmiar*rozmiar)%ntasks;
array_alloc(C, rozmiar); array_alloc(C, rozmiar);
vect_alloc(vect, rozmiar); vect_alloc(vect, porcja);
vect_alloc(vect_c, porcja);
if (taskid == 0) if (taskid == 0)
{ {
//wypelnienie macierzy A liczbami "losowymi" //wypelnienie macierzy A liczbami "losowymi"
@@ -113,10 +116,37 @@ int main(int argc, char *argv[])
//wysyłanie macierzy A do wszystkich //wysyłanie macierzy A do wszystkich
MPI::COMM_WORLD.Bcast(&A[0][0], rozmiar*rozmiar, MPI::LONG, 0); MPI::COMM_WORLD.Bcast(&A[0][0], rozmiar*rozmiar, MPI::LONG, 0);
if (taskid == 0)
{
cout << endl << "WEKTOR DANYCH: " << endl;
for (i=0; i<rozmiar*rozmiar; ++i)
cout << B_rot[i] << " ";
cout << endl;
}
MPI::COMM_WORLD.Barrier();
//MPI::COMM_WORLD.Scatter(&B_rot[0], porcja, MPI::LONG, &vect[0], porcja, MPI::LONG, 0);
// każdy proces ma policzyć łącznie "porcja" pól,
// dlatego dostaje wektory kolumn, w których leżą porcje
long pos, pocz, kon;
for (i=0; i<ntasks; ++i)
{
porcja = (i == ntasks - 1) ? rozmiar*rozmiar%porcja : porcja;
pos = i*porcja;
pocz = pos - (pos%rozmiar);
kon = pos+porcja - ((pos+porcja)%rozmiar) - 1;
MPI::COMM_WORLD.Isend(&B_rot[pocz], kon-pocz, MPI::LONG, i, 0);
}
// w przypadku gdy iloraz wielkości macierzy i ilości programów daje resztę
// wszystkie porcje zostają zwiększone, a ostatnia porcja w ostatnim programie
// jest mniejsza - należy policzyć tą porcję zawczasu...
MPI::COMM_WORLD.Scatter(&B_rot[0], rozmiar, MPI::LONG, &vect[0], rozmiar, MPI::LONG, 0);
/* /*
tt.Begin(); tt.Begin();
for (i=0; i<rozmiar; ++i) for (i=0; i<rozmiar; ++i)
@@ -137,8 +167,13 @@ int main(int argc, char *argv[])
array_destroy(C); array_destroy(C);
*/ */
cout << taskid << ": " << vect[2] << endl; /*
MPI::Finalize(); cout << taskid << ": " ;
for (i=0; i<porcja; ++i)
cout << vect[i] << " ";
cout << endl;
*/MPI::Finalize();
exit(0); exit(0);
} }