Advertisement
Guest User

Untitled

a guest
Nov 13th, 2019
114
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.20 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,size,rozmiar;
  13. float najwieksza;
  14. float max;
  15.  
  16. MPI_Comm_rank(MPI_COMM_WORLD, &rank);
  17. MPI_Comm_size(MPI_COMM_WORLD, &size);
  18.  
  19. if(!rank)
  20. {
  21. int rozmiar;
  22. cout<<"Podaj rozmiar tablicy"<<endl;
  23. cin>>rozmiar;
  24. MPI_Bcast(&rozmiar,1,MPI_INT,102,MPI_COMM_WORLD);
  25. }
  26.  
  27. MPI_Recv(&rozmiar,1,MPI_INT,0,102,MPI_COMM_WORLD,MPI_STATUS_IGNORE);
  28.  
  29.  
  30. cout<<"Jestem procesem "<< rank<< " Czekam "<< rank<< " sekund "<<endl;
  31. sleep(rank);
  32. srand(time(NULL));
  33.  
  34. float *tablica=new float[rozmiar];
  35.  
  36. for(int i=0;i<rozmiar;i++)
  37. {
  38. tablica[i]=(rand()%1000)/100.0;
  39. }
  40.  
  41. cout<<"Tablica dla " <<rank<<" procesu"<<endl;
  42. for(int i=0;i<rozmiar;i++)
  43. {
  44. cout<<tablica[i]<<endl;
  45. }
  46.  
  47. max=tablica[0];
  48.  
  49. for(int i=0;i<rozmiar;i++)
  50. {
  51. if( max < tablica[i])
  52. max=tablica[i];
  53. }
  54.  
  55. MPI_Reduce(&max, &najwieksza, 1, MPI_FLOAT , MPI_MAX, 1, MPI_COMM_WORLD);
  56.  
  57.  
  58. if(rank==1)
  59. {
  60. cout<<"Najwieksza wylosowana liczba: "<<max<<endl;
  61. }
  62.  
  63. delete [] tablica;
  64.  
  65. MPI_Finalize();
  66. return 0;
  67. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement