Advertisement
Guest User

Untitled

a guest
Nov 13th, 2019
81
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.05 KB | None | 0 0
  1. #include <iostream>
  2. #include <mpi.h>
  3. #include <unistd.h>
  4. #include <ctime>
  5. #include <cstdlib>
  6.  
  7. using namespace std;
  8.  
  9. int main(int argc, char * argv[])
  10. {
  11. MPI_Init(&argc, &argv);
  12. int rank,rozmiar;
  13. float najwieksza;
  14. float max;
  15.  
  16. MPI_Comm_rank(MPI_COMM_WORLD, &rank);
  17.  
  18. if(!rank)
  19. {
  20. cout<<"Podaj rozmiar tablicy"<<endl;
  21. cin>>rozmiar;
  22. }
  23.  
  24. MPI_Bcast(&rozmiar,1,MPI_INT,0,MPI_COMM_WORLD);
  25.  
  26. cout<<"Jestem procesem "<< rank<< " Czekam "<< rank<< " sekund "<<endl;
  27. sleep(rank);
  28. srand(time(NULL));
  29.  
  30. float tablica[rozmiar];
  31.  
  32. for(int i=0;i<rozmiar;i++)
  33. {
  34. tablica[i]=(rand()%1000)/100.0;
  35. }
  36.  
  37. cout<<"Tablica dla " <<rank<<" procesu"<<endl;
  38. for(int i=0;i<rozmiar;i++)
  39. {
  40. cout<<tablica[i]<<endl;
  41. }
  42.  
  43. max=tablica[0];
  44.  
  45. for(int i=0;i<rozmiar;i++)
  46. {
  47. if( max < tablica[i])
  48. max=tablica[i];
  49. }
  50.  
  51. MPI_Reduce(&max, &najwieksza, 1, MPI_FLOAT , MPI_MAX, 1, MPI_COMM_WORLD);
  52.  
  53.  
  54. if(rank==1)
  55. {
  56. cout<<"Najwieksza wylosowana liczba: "<<max<<endl;
  57. }
  58. //delete [] tablica;
  59.  
  60. MPI_Finalize();
  61. return 0;
  62. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement