| 
						
						
							
								
							
						
						
					 | 
				
				 | 
				
					@ -49,7 +49,7 @@ void array_destroy(long **arr) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					
 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					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; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						char *endptr; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						TTiming tt; | 
				
			
			
		
	
	
		
			
				
					| 
						
							
								
							
						
						
							
								
							
						
						
					 | 
				
				 | 
				
					@ -91,8 +91,11 @@ int main(int argc, char *argv[]) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
							array_alloc(B, rozmiar); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
							vect_alloc(B_rot, rozmiar*rozmiar); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						} | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					
 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						int porcja = (rozmiar*rozmiar)/ntasks + (rozmiar*rozmiar)%ntasks; | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						array_alloc(C, rozmiar); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						vect_alloc(vect, rozmiar); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						vect_alloc(vect, porcja); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						vect_alloc(vect_c, porcja); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						if (taskid == 0) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						{ | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
							//wypelnienie macierzy A liczbami "losowymi"
 | 
				
			
			
		
	
	
		
			
				
					| 
						
						
						
							
								
							
						
					 | 
				
				 | 
				
					@ -113,10 +116,37 @@ int main(int argc, char *argv[]) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						//wysyłanie macierzy A do wszystkich
 | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						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(); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						for (i=0; i<rozmiar; ++i)  | 
				
			
			
		
	
	
		
			
				
					| 
						
						
						
							
								
							
						
					 | 
				
				 | 
				
					@ -137,8 +167,13 @@ int main(int argc, char *argv[]) | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
						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); | 
				
			
			
		
	
		
			
				
					 | 
					 | 
				
				 | 
				
					} |