MPI.tex 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. %!TEX root = Programmierparadigmen.tex
  2. \chapter{MPI}
  3. \index{MPI|(}
  4. Message Passing Interface (kurz: MPI) ist ein Standard,
  5. der den Nachrichtenaustausch bei parallelen Berechnungen auf
  6. verteilten Computersystemen beschreibt.
  7. \section{Erste Schritte}
  8. \inputminted[numbersep=5pt, tabsize=4, frame=lines, label=hello-world.c]{c}{scripts/mpi/hello-world.c}
  9. Das wird \texttt{mpicc hello-world.c} kompiliert.\\
  10. Mit \texttt{mpirun -np 14 scripts/mpi/a.out} werden 14 Kopien des Programms
  11. gestartet.
  12. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  13. \section{Funktionen}
  14. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/comm-size.c}\xindex{MPI\_Comm\_size}
  15. Liefert die Größe des angegebenen Kommunikators; dh. die Anzahl der Prozesse in der Gruppe.
  16. \textbf{Parameter}
  17. \begin{itemize}
  18. \item \textbf{comm}: Kommunikator (handle)
  19. \item \textbf{size}: Anzahl der Prozesse in der Gruppe von \texttt{comm}
  20. \end{itemize}
  21. \textbf{Beispiel}
  22. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/comm-size-example.c}
  23. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  24. \rule{\textwidth}{0.4pt}\xindex{MPI\_Comm\_rank}
  25. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/comm-rank.c}
  26. Bestimmt den Rang des rufenden Prozesses innerhalb des Kommunikators.
  27. Der Rang wird von MPI zum Identifizieren eines Prozesses verwendet. Die Rangnummer ist innerhalb eines Kommunikators eindeutig. Dabei wird stets von Null beginnend durchnumeriert. Sender und Empfänger bei Sendeoperationen oder die Wurzel bei kollektiven Operationen werden immer mittels Rang angegeben.
  28. \textbf{Parameter}
  29. \begin{itemize}
  30. \item \textbf{comm}: Kommunikator (handle)
  31. \item \textbf{rank}: Rang des rufenden Prozesses innerhalb von \texttt{comm}
  32. \end{itemize}
  33. \textbf{Beispiel}
  34. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/comm-rank-example.c}
  35. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  36. \rule{\textwidth}{0.4pt}\xindex{MPI\_Send}
  37. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/mpi-send.c}
  38. Senden einer Nachricht an einen anderen Prozeß innerhalb eines Kommunikators. (Standard-Send)
  39. \textbf{Parameter}
  40. \begin{itemize}
  41. \item \textbf{buf}: Anfangsadresse des Sendepuffers
  42. \item \textbf{count}: Anzahl der Elemente des Sendepuffers (nichtnegativ)
  43. \item \textbf{datatype}: Typ der Elemente des Sendepuffers (handle)
  44. \item \textbf{dest}: Rang des Empfängerprozesses in comm (integer)
  45. \item \textbf{tag}: message tag zur Unterscheidung verschiedener Nachrichten;
  46. Ein Kommunikationsvorgang wird durch ein Tripel (Sender, Empfänger, tag) eindeutig beschrieben.
  47. \item \textbf{comm}: Kommunikator (handle)
  48. \end{itemize}
  49. \textbf{Beispiel}
  50. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/mpi-send-example.c}
  51. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  52. \rule{\textwidth}{0.4pt}\xindex{MPI\_Recv}
  53. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/mpi-receive.c}
  54. Empfangen einer Nachricht (blockierend)
  55. \textbf{Parameter}
  56. \begin{itemize}
  57. \item \textbf{buf}: Anfangsadresse des Empfangspuffers
  58. \item \textbf{status}: Status, welcher source und tag angibt (\texttt{MPI\_Status})
  59. \item \textbf{count}: Anzahl der Elemente im Empfangspuffer (nichtnegativ)
  60. \item \textbf{datatype}: Typ der zu empfangenden Elemente (handle)
  61. \item \textbf{source}: Rang des Senderprozesses in comm oder \texttt{MPI\_ANY\_SOURCE}
  62. \item \textbf{tag}: message tag zur Unterscheidung verschiedener Nachrichten
  63. Ein Kommunikationsvorgang wird durch ein Tripel (Sender, Empfänger, tag) eindeutig beschrieben. Um Nachrichten mit beliebigen tags zu empfangen, benutzt man die Konstante \texttt{MPI\_ANY\_TAG}.
  64. \item \textbf{comm}: Kommunikator (handle)
  65. \end{itemize}
  66. \textbf{Beispiel}
  67. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/mpi-receive-example.c}
  68. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  69. \rule{\textwidth}{0.4pt}\xindex{MPI\_Reduce}
  70. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/mpi-reduce.c}
  71. Führt eine globale Operation \textbf{op} aus; der Prozeß \enquote{root} erhält das Resultat.
  72. \textbf{Parameter}
  73. \begin{itemize}
  74. \item \textbf{sendbuf}: Startadresse des Sendepuffers
  75. \item \textbf{count}: Anzahl der Elemente im Sendepuffer
  76. \item \textbf{datatype}: Datentyp der Elemente von \texttt{sendbuf}
  77. \item \textbf{op}: auszuführende Operation (handle)
  78. \item \textbf{root}: Rang des Root-Prozesses in comm, der das Ergebnis haben soll
  79. \item \textbf{comm}: Kommunikator (handle)
  80. \end{itemize}
  81. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  82. \rule{\textwidth}{0.4pt}\xindex{MPI\_Bcast}
  83. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/mpi-bcast.c}
  84. Sendet eine Nachricht vom Prozess \texttt{root} an alle anderen Prozesse des
  85. angegebenen Kommunikators.
  86. \textbf{Parameter}
  87. \begin{itemize}
  88. \item \textbf{buffer}: Startadresse des Datenpuffers
  89. \item \textbf{count}: Anzahl der Elemente im Puffer
  90. \item \textbf{datatype}: Datentyp der Pufferelemente (handle)
  91. \item \textbf{root}: Wurzelprozeß; der, welcher sendet
  92. \item \textbf{comm}: Kommunikator (handle)
  93. \end{itemize}
  94. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  95. \rule{\textwidth}{0.4pt}\xindex{MPI\_Scatter}
  96. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/mpi-scatter.c}
  97. Verteilt Daten vom Prozess \texttt{root} unter alle anderen Prozesse in der Gruppe, so daß, soweit möglich, alle Prozesse gleich große Anteile erhalten.
  98. \textbf{Parameter}
  99. \begin{itemize}
  100. \item \textbf{sendbuf}: Anfangsadresse des Sendepuffers (Wert ist lediglich für 'root' signifikant)
  101. \item \textbf{sendcount}: Anzahl der Elemente, die jeder Prozeß geschickt bekommen soll (integer)
  102. \item \textbf{sendtype}: Datentyp der Elemente in sendbuf (handle)
  103. \item \textbf{recvcount}: Anzahl der Elemente im Empfangspuffer. Meist ist es günstig, recvcount = sendcount zu wählen.
  104. \item \textbf{recvtype}: Datentyp der Elemente des Empfangspuffers (handle)
  105. \item \textbf{root}: Rang des Prozesses in comm, der die Daten versendet
  106. \item \textbf{comm}: Kommunikator (handle)
  107. \end{itemize}
  108. \textbf{Beispiel}
  109. \inputminted[numbersep=5pt, tabsize=4]{c}{scripts/mpi/mpi-reduce-example.c}
  110. \section{Beispiele}
  111. \section{Weitere Informationen}
  112. \begin{itemize}
  113. \item \url{http://mpitutorial.com/}
  114. \item \url{http://www.open-mpi.org/}
  115. \item \url{http://www.tu-chemnitz.de/informatik/RA/projects/mpihelp/}
  116. \end{itemize}
  117. \index{MPI|)}