MPI: Message Passing Interface

Σχετικά έγγραφα
Αρχιτεκτονική κοινής μνήμης

Συστήµατα Παράλληλης Επεξεργασίας. Message Passing Interface (MPI)

Message Passing Interface (MPI)

Message Passing Interface (MPI)

Message Passing Interface (MPI)

MPI: Message Passing Interface

Message Passing Interface (MPI)

Το Message Passing Interface (MPI) και η υποστήριξή του στο EGEE Grid

MPI: Message Passing Interface

Παράλληλος προγραµµατισµός

Το Message Passing Interface (MPI) και η υποστήριξή του στο EGEE Grid. Vangelis Koukis 01-GRNET and HG EKT admin team

Το Message Passing Interface (MPI) και η υποστήριξή του στο EGEE Grid


Συστήματα Παράλληλης & Κατανεμημένης Επεξεργασίας

Συστήματα Παράλληλης & Κατανεμημένης Επεξεργασίας

Συστήματα Παράλληλης & Κατανεμημένης Επεξεργασίας

Συστήματα Παράλληλης & Κατανεμημένης Επεξεργασίας

ύο μηχανισμοί απαιτούνται: 1. Μία μέθοδος για τη δημιουργία διεργασιών

Συστήματα Παράλληλης & Κατανεμημένης Επεξεργασίας

Συστήματα Παράλληλης & Κατανεμημένης Επεξεργασίας

Υπολογισμοί Μεταβίβασης Μηνυμάτων

Ε-85: Ειδικά Θέµατα Λογισµικού

Επικοινωνία. Message-Passing Interface (MPI) Βασικές Κλήσεις για Sockets. Μοντέλο Μεταβίβασης Μηνυµάτων. Μοντέλα Παράλληλου Υπολογισµού

ΠΤΥΧΙΑΚΗ ΕΡΓΑΣΙΑ. Της φοιτήτριας Αριστέας Χρονοπούλου Αρ. Μητρώου: 01 / Επιβλέπων Καθηγητής Αθανάσιος Μάργαρης

Κατανεμημένος και Παράλληλος Προγραμματισμός MPI. MPI Απλές εντολές 03/13/2016. Οδηγίες αποστολής / παραλαβής μηνυμάτων, Υπολογισμός του π (

Επιστημονικοί Υπολογισμοί - Μέρος ΙΙΙ: Παράλληλοι Υπολογισμοί

Non-blocking Επικοινωνίεσ και Buffering. Κώςτασ Διαμαντάρασ ΤΕΙ Θεςςαλονίκθσ 2011

Εισαγωγή. E-03: Λειτουργικά Συστήµατα ΙΙ 6. Εαρινό Εξάµηνο SUN RPC. Κλήση Αποµακρυσµένων ιαδικασιών (RPC) Σύνδεση: Port Mapper.

Παράλληλα και Κατανεµηµένα Συστήµατα. Εισαγωγή

Συστήματα Παράλληλης και Κατανεμημένης Επεξεργασίας

EM 361: Παράλληλοι Υπολογισμοί

Προγραµµατισµός µε ανταλλαγή µηνυµάτων Ι. Εισαγωγή στο MPI. Εφαρµογές Ανεξάρτητου Παραλληλισµού.

Συστήματα Παράλληλης & Κατανεμημένης Επεξεργασίας

Probleme de transmitere în modul standard. MPI - Message Passing Interface. Comunicarea punct la punct

ΕΚΔΟΣΗ 1.0 ΟΚΤΩΒΡΙΟΣ, 2017 ΕΙΣΑΓΩΓΗ ΣΤΑ ΚΑΤΑΝΕΜΗΜΕΝΑ ΣΥΣΤΗΜΑΤΑ ΕΙΣΑΓΩΓΗ ΣΤO MESSAGE PASSING INTERFACE - MPI ΕΠΙΜΕΛΕΙΑ: Β. ΤΣΑΚΑΝΙΚΑΣ, Β.

MPI: Βαςικζσ Εντολζσ Επικοινωνίασ. Κώςτασ Διαμαντάρασ Τμιμα Πλθροφορικισ ΤΕΙ Θεςςαλονίκθσ 2011

Διπλωματική Εργασία του φοιτητή του Τμήματος Ηλεκτρολόγων Μηχανικών και Τεχνολογίας Υπολογιστών της Πολυτεχνικής Σχολής του Πανεπιστημίου Πατρών

Συστήματα Παράλληλης και Κατανεμημένης Επεξεργασίας

Κεφάλαιο VIΙΙ Β. Δημακόπουλος

Τφποι δεδομζνων MPI. Κώςτασ Διαμαντάρασ Τμιμα Πλθροφορικισ ΤΕΙ Θεςςαλονίκθσ

Συστήματα Παράλληλης & Κατανεμημένης Επεξεργασίας

Κατανεμημένος και Παράλληλος Προγραμματισμός. Εισαγωγή στο MPI. Εγκατάσταση MPICH σε ένα ΗΥ 10/3/2017

ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Μεταβίβαση μηνυμάτων. Κεφάλαιο 5 (νέο βιβλίο) Κεφάλαιο 8 (παλιές σημειώσεις)

Κατανεμημένος και Παράλληλος Προγραμματισμός MPI. Γρήγορος οδηγός αναφοράς 1/4/2017

ΕΚΔΟΣΗ 1.1 ΑΠΡΙΛΙΟΣ, 2018 ΕΙΣΑΓΩΓΗ ΣΤΑ ΚΑΤΑΝΕΜΗΜΕΝΑ ΣΥΣΤΗΜΑΤΑ ΤΟ ΠΡΩΤΟΚΟΛΛΟ ECHO ΕΠΙΜΕΛΕΙΑ: Β. ΤΣΑΚΑΝΙΚΑΣ, Β. ΤΑΜΠΑΚΑΣ

Συστήματα Παράλληλης & Κατανεμημένης Επεξεργασίας

ΕΚΔΟΣΗ 1.0 ΟΚΤΩΒΡΙΟΣ, 2017 ΕΙΣΑΓΩΓΗ ΣΤΑ ΚΑΤΑΝΕΜΗΜΕΝΑ ΣΥΣΤΗΜΑΤΑ ΤΟ ΠΡΩΤΟΚΟΛΛΟ TARRY ΕΠΙΜΕΛΕΙΑ: Β. ΤΣΑΚΑΝΙΚΑΣ, Β. ΤΑΜΠΑΚΑΣ

ΕΚΔΟΣΗ 1.1 ΜΑΙΟΣ, 2018 ΕΙΣΑΓΩΓΗ ΣΤΑ ΚΑΤΑΝΕΜΗΜΕΝΑ ΣΥΣΤΗΜΑΤΑ ΑΛΓΟΡΙΘΜΟΣ POLLING ΚΥΜΑΤΙΚΟΣ ΑΛΓΟΡΙΘΜΟΣ ΕΠΙΜΕΛΕΙΑ: Β. ΤΣΑΚΑΝΙΚΑΣ, Β.

Προγραμματισμός με Μεταβίβαση Μηνυμάτων

Παράλληλος προγραμματισμός: παράλληλες λ υπολογιστικές πλατφόρμες και ανάλυση προγραμμάτων

30/4/2012 Συστήματα κατανεμημένης μνήμης και ο προγραμματισμός τους (Ι) Β. Δημακόπουλος

ΑΝΟΧΗ ΣΦΑΛΜΑΤΩΝ ΣΕ ΕΦΑΡΜΟΓΕΣ MPI ΠΟΥ ΑΚΟΛΟΥΘΟΥΝ ΤΟ ΜΟΝΤΕΛΟ MASTER-WORKER Η ΜΕΤΑΠΤΥΧΙΑΚΗ ΕΡΓΑΣΙΑ ΕΞΕΙΔΙΚΕΥΣΗΣ. Υποβάλλεται στην

Παράλληλος προγραμματισμός: Σχεδίαση και υλοποίηση παράλληλων προγραμμάτων

ΕΚΔΟΣΗ 1.1 ΜΑΙΟΣ, 2018 ΕΙΣΑΓΩΓΗ ΣΤΑ ΚΑΤΑΝΕΜΗΜΕΝΑ ΣΥΣΤΗΜΑΤΑ ΕΚΛΟΓΗ ΑΡΧΗΓΟΥ ΕΠΙΜΕΛΕΙΑ: Β. ΤΣΑΚΑΝΙΚΑΣ, Β. ΤΑΜΠΑΚΑΣ

Παράλληλος προγραμματισμός: Σχεδίαση και υλοποίηση παράλληλων προγραμμάτων

Mονόπλευρες επικοινωνίες στο MPI-2

2. Στοιχεία Αρχιτεκτονικής Παράλληλων Υπολογιστών... 45

ΕΚΔΟΣΗ 1.0 ΟΚΤΩΒΡΙΟΣ, 2017 ΕΙΣΑΓΩΓΗ ΣΤΑ ΚΑΤΑΝΕΜΗΜΕΝΑ ΣΥΣΤΗΜΑΤΑ ΚΑΤΑΝΕΜΗΜΕΝΑ ΡΟΛΟΓΙΑ ΕΠΙΜΕΛΕΙΑ: Β. ΤΣΑΚΑΝΙΚΑΣ, Β. ΤΑΜΠΑΚΑΣ

Παράλληλος προγραμματισμός: Σχεδίαση και υλοποίηση παράλληλων προγραμμάτων

Περίληψη. Υπερυπολογιστές. Υπολογιστικά προβλήµατα. TOP 500 (Ιούνιος 2007) TOP 500 (Ιούνιος 2009) Ε-85: Ειδικά Θέµατα Λογισµικού

Συστήματα Παράλληλης και Κατανεμημένης Επεξεργασίας

Minimum Spanning Tree: Prim's Algorithm

Ανταλλαγι Μθνυμάτων. Κϊςτασ Διαμαντάρασ Τμιμα Πλθροφορικισ ΤΕΙ Θεςςαλονίκθσ

Κατανεμημένος και Παράλληλος Προγραμματισμός

Εθνικό Μετσόβιο Πολυτεχνείο Σχολή Ηλεκτρολόγων Μηχ. και Μηχανικών Υπολογιστών. Οδηγίες εργαστηρίου. Συστήματα Παράλληλης Επεξεργασίας 9 ο Εξάμηνο

Παράλληλη Επεξεργασία

Κατανεμημένος και. Ηλίας Κ. Σάββας Αναπληρωτής Καθηγητής Τμήμα Μηχανικών Πληροφορικής ΤΕ, ΤΕΙ Θεσσαλίας

Αρχιτεκτονική Υπολογιστών

Ε-85: Ειδικά Θέµατα Λογισµικού

Προγραμματισμός Ι (ΗΥ120)

Network Algorithms and Complexity Παραλληλοποίηση του αλγορίθμου του Prim. Αικατερίνη Κούκιου

EM 361: Παξάιιεινη Υπνινγηζκνί

3/5/2012 Συστήματα κατανεμημένης μνήμης και ο προγραμματισμός τους (ΙI) Β. Δημακόπουλος

Σχεδίαση και Υλοποίηση Μηχανισμού Μεταφοράς Δεδομένων από Συσκευές Αποθήκευσης σε Δίκτυο Myrinet, Χωρίς τη Μεσολάβηση της Ιεραρχίας Μνήμης

Λειτουργικά Συστήματα 7ο εξάμηνο, Ακαδημαϊκή περίοδος

Βιβλιοθήκες Αφηρημένοι τύποι δεδομένων. Προγραμματισμός II 1

Εργαστήριο Λειτουργικών Συστημάτων 8o εξάμηνο, Ροή Υ, ΗΜΜΥ

ΕΚΔΟΣΗ 1.0 ΟΚΤΩΒΡΙΟΣ, 2017 ΕΙΣΑΓΩΓΗ ΣΤΑ ΚΑΤΑΝΕΜΗΜΕΝΑ ΣΥΣΤΗΜΑΤΑ ΓΕΝΙΚΟΙ ΓΡΑΦΟΙ ΣΤΟ MPI ΕΠΙΜΕΛΕΙΑ: Β. ΤΣΑΚΑΝΙΚΑΣ, Β. ΤΑΜΠΑΚΑΣ

Λύβας Χρήστος Αρχική επιµέλεια Πιτροπάκης Νικόλαος και Υφαντόπουλος Νικόλαος

Εργαστήριο ΔΙΕΡΓΑΣΙΕΣ - ΔΙΑΧΕΙΡΙΣΗ

Παράλληλη Επεξεργασία

Κατανεμημένος και Παράλληλος Προγραμματισμός. Εισαγωγή στο MPI. Εγκατάσταση MPICH σε ένα ΗΥ 6/3/2016

Δημιουργία & Τερματισμός Διεργασιών. Προγραμματισμός II 1

Τξ Message Passing Interface (MPI) και η σπξρςήοινή ςξσ ρςξ EGEE Grid. Vasileios Karakasis GRNET S.A., ICCS

Επιστημονικοί Υπολογισμοί - Μέρος ΙΙΙ: Παράλληλοι Υπολογισμοί

Αρχιτεκτονική Υπολογιστών

Μεταγλώττιση και σύνδεση πολλαπλών αρχείων κώδικα. Προγραμματισμός II 1

Διαφορές single-processor αρχιτεκτονικών και SoCs

Υ07 Παράλληλα Συστήματα /5/2016 Προγραμματισμός με μεταβίβαση μηνυμάτων

HY-486 Αρχές Κατανεμημένου Υπολογισμού Εαρινό Εξάμηνο

EM 361: Παράλληλοι Υπολογισμοί

13.2 Παράλληλος Προγραµµατισµός Γλωσσάρι, Σελ. 1

Λειτουργικά Συστήματα (Λ/Σ)

Επιμερισμός δεδομένων

Περίληψη Φροντιστηρίου. Κατανεμημένα Συστήματα Ι. Το περιβάλλον DAP - Χαρακτηριστικά. Το περιβάλλον DAP Τι είναι.

Μνήμη Διευθύνσεις Δείκτες. Προγραμματισμός II 1

Διάλεξη 2η: Αλγόριθμοι και Προγράμματα

Ανάπτυξη και Σχεδίαση Λογισμικού

ΗΥ486 - Αρχές Κατανεμημένου Υπολογισμού Εαρινό Εξάμηνο Δεύτερη Προγραμματιστική Εργασία

Προγραμματισμός και Χρήση Ηλεκτρονικών Υπολογιστών - Βασικά Εργαλεία Λογισμικού

Transcript:

Εθνικό Μετσόβιο Πολυτεχνείο Σχολή Ηλεκτρολόγων Μηχ. και Μηχανικών Υπολογιστών Εργαστήριο Υπολογιστικών Συστημάτων MPI: Message Passing Interface 9 ο Εξάμηνο

Αρχιτεκτονική κοινής μνήμης Οι επεξεργαστές έχουν κοινή μνήμη Κάθε επεξεργαστής διαθέτει τοπική ιεραρχία κρυφών μνημών Συνήθως η διασύνδεση γίνεται μέσω διαδρόμου μνήμης (memory bus) Αλλά και πιο εξελιγμένα δίκτυα διασύνδεσης Ομοιόμορφη ή μη ομοιόμορφη προσπέλαση στη μνήμη (Uniform Memory Access UMA, Non uniform Memory Access NUMA) Η κοινή μνήμη διευκολύνει τον παράλληλο προγραμματισμό Δύσκολα κλιμακώσιμη αρχιτεκτονική τυπικά μέχρι λίγες δεκάδες κόμβους (δεν κλιμακώνει το δίκτυο διασύνδεσης) $ $ $ CPU CPU CPU Διάδρομος Μνήμης (memory bus) M 2

Αρχιτεκτονική κατανεμημένης μνήμης Κάθε επεξεργαστής έχει τη δική του τοπική μνήμη και ιεραρχία τοπικών μνημών Διασυνδέεται με τους υπόλοιπους επεξεργαστές μέσω δικτύου διασύνδεσης Η κατανεμημένη μνήμη δυσκολεύει τον προγραμματισμό Η αρχιτεκτονική κλιμακώνει σε χιλιάδες υπολογιστικούς κόμβους Κόμβος 1 Κόμβος 2 Κόμβος Ν $ $ $ CPU CPU CPU M M M Δίκτυο Διασύνδεσης (π.χ. Ethernet, Myrinet, SCI) 3

Υβριδική αρχιτεκτονική Συνδυάζει τις δύο παραπάνω αρχιτεκτονικές: κόμβοι με αρχιτεκτονική κοινής μνήμης διασυνδέονται με ένα δίκτυο διασύνδεσης σε αρχιτεκτονική κατανεμημένης μνήμης Τυπική αρχιτεκτονική των σύγχρονων συστοιχιών υπερυπολογιστών 4

Κοινός χώρος διευθύνσεων (shared address space) Παραδοσιακά προγραμματιστικά μοντέλα Οι διεργασίες έχουν πρόσβαση σε κοινό χώρο διευθύνσεων Χρησιμοποιούνται κανονικές εντολές ανάγνωσης / εγγραφής Πιθανόν απαιτείται κάποια αρχικοποίηση του κοινού χώρου διευθύνσεων Οι διευθύνσεις μπορεί να αφορούν: Φυσικά κοινή μνήμη Φυσικά κατανεμημένη μνήμη (απαιτείται στρώμα υλικού ή λογισμικού) Ανταλλαγή μηνυμάτων (message passing) Δεν υπάρχουν κοινά δεδομένα Πρόσβαση σε δεδομένα δ που κατέχει άλλη διεργασία γίνεται με ρητές κλήσεις σε συναρτήσεις αποστολής / λήψης 5

Ανταλλαγή μηνυμάτων 6

Αρχιτεκτονικές και Προγραμματιστικά Μοντέλα από την οπτική του προγραμματιστή Αρχιτεκτονική Κοινής μνήμης (shared memory) Κατανεμημένης μνήμης (distributed memory) Προ ογραμματισ στικό μοντέ έλο Κοινός χώρος διευθύνσεων (shared address space) Ανταλλαγή μηνυμάτων (message-passing) + Ευκολία υλοποίησης + Προγραμματιστική ευκολία + Υψηλή επίδοση + Προγραμματιστική ευκολία - Δυσκολία υλοποίησης Χαμηλή επίδοση + Υψηλή επίδοση - Χαμηλή επίδοση + Ευκολία υλοποίησης + Υψηλή επίδοση - Προγραμματιστική δυσκολία + Ευκολία υλοποίησης + Υψηλή επίδοση - Προγραμματιστική δυσκολία 7

Είναι πρότυπο, όχι συγκεκριμένη υλοποίηση Βιβλιοθήκη ανταλλαγής μηνυμάτων Σχεδίαση σε στρώματα (layers) Τι είναι το MPI; Σε υψηλό επίπεδο, παρέχει διεπαφή (interface) σε προγραμματιστή Σε χαμηλό επίπεδο, επικοινωνεί με το δίκτυο διασύνδεσης Υποστηρίζει C, C++, Fortran 77 και F90 8

Υλοποιήσεις MPI MPICH: http://www unix.mcs.anl.gov/mpi/mpich/ MPICH2: http://www unix.mcs.anl.gov/mpi/mpich2/ MPICH GM: http://www.myri.com/scs/ LAM/MPI: http://www.lam mpi.org/ / LA MPI: http://public.lanl.gov/lampi/ Open MPI: http://www.open mpi.org/ SCI MPICH: http://www.lfbs.rwth aachen.de/users/joachim/sci MPICH/ MPI/Pro: http://www.mpi softtech.com/ 9

Single Program Multiple Data (SPMD) Όλες οι διεργασίες εκτελούν το ίδιο πρόγραμμα Κάθε διεργασία επεξεργάζεται υποσύνολο των δεδομένων ή διαφοροποιεί τη ροή εκτέλεσης της με βάση το βαθμό (rank) που της αποδίδει το MPI Επιδίωξη παράλληλου προγραμματισμού: Μεγιστοποίηση η παραλληλίας Αποδοτική αξιοποίηση πόρων συστήματος (π.χ. μνήμη) Ελαχιστοποίηση όγκου δεδομένων επικοινωνίας Ελαχιστοποίηση αριθμού μηνυμάτων Ελαχιστοποίηση συγχρονισμού 10

Διεργασίες και communicators Σε κάθε διεργασία αποδίδεται ένα μοναδικό rank στο εύρος 0...P 1, όπου P το συνολικό πλήθος διεργασιών στον συγκεκριμένο communicator Σε γενικές ςγραμμές, o communicator ορίζει ρζ ένα σύνολο από διεργασίες που μπορούν να επικοινωνούν μεταξύ τους (π.χ. MPI_COMM_WORLD) Προσοχή: Αναφερόμαστε πάντα σε διεργασίες, όχι σε επεξεργαστές 11

Τυπική δομή κώδικα MPI #include <mpi.h> main(int argc, char **argv){... /* Πρώτη κλήση MPI */ MPI_Init(&argc, &argv); MPI_Comm_rank(MPI_COMM_WORLD, &rank); MPI_Comm_size(MPI_COMM_WORLD, &size);... /* Τελευταία κλήση MPI */ MPI_Finalize(); } 12

Βασικές συναρτήσεις στο MPI MPI_Init(argc,argv) Αρχικοποίηση η MPI_Comm_rank(comm,rank) Αντιστοίχιση rank διεργασίας σε communicator comm MPI_Comm_size(comm,size) Εύρεση πλήθους διεργασιών size σε comm MPI_Send(sndbuf,count,datatype,dest,tag,comm) Αποστολή μηνύματος σε διεργασία dest MPI_Recv(rcvbuf,count,datatype,source,tag, comm,status) Λήψη μηνύματος από διεργασία source MPI_Finalize() Τερματισμός 13

int MPI_Init(int* argc, char*** argv) MPI_Init Αρχικοποίηση περιβάλλοντος MPI Παράδειγμα: int main(int argc,char** argv){ } MPI_Init(&argc,&argv); Init(&argc,&argv); 14

MPI_Comm_rank int MPI_Comm_rank (MPI_Comm comm, int* rank) Καθορισμός rank καλούσας διεργασίας που ανήκει στον communicator comm Παράδειγμα: int rank; MPI_Comm_rank(MPI_COMM_WORLD,&rank); COMM 15

MPI_Comm_size int MPI_Comm_size (MPI_Comm comm, int* size) Καθορισμός πλήθους διεργασιών size που ανήκουν στον communicator comm Παράδειγμα: int size; MPI_Comm_size(MPI_COMM_WORLD,&size); COMM 16

MPI_Send int MPI_Send(void *buf, int count, int dest, int tag, MPI_Datatype datatype, MPI_Comm comm) Αποστολή μηνύματος buf από καλούσα διεργασία σε διεργασία με rank dest Ο πίνακας buf έχει count στοιχεία τύπου datatype Παράδειγμα: int message[20],dest=1,tag=55; MPI_Send(message, 20, dest, tag, MPI_INT, MPI_COMM_WORLD); 17

MPI_Recv int MPI_Recv(void *buf, int count, int source, int tag, MPI_Datatype datatype, MPI_Comm comm, MPI_Status *status) Λήψη μηνύματος από διεργασία με rank source και αποθήκευση σε buf Λαμβάνονται το πολύ count δεδομένα τύπου datatype (ακριβής αριθμός με MPI_Get_count) Wildcards: MPI_ANY_SOURCE, MPI_ANY_TAG Παράδειγμα: int message[50],source=0,tag=55; MPI_Status status; MPI_Recv(message, 50, source, tag, MPI_INT, MPI_COMM_WORLD,&status); 18

Αποστολή λήψη στο MPI 19

MPI_Sendrecv int MPI_Sendrecv( void *sendbuf, int sendcount, MPI_Datatype sendtype, int dest, int sendtag, void *recvbuf, int recvcount, MPI_Datatype recvtype, int source, int recvtag, MPI_Comm comm, MPI_Status *status ) Λήψη και αποστολή μηνύματος με μία κλήση Για «συμμετρικό» κώδικα χρήση του MPI_NULL_PROC 20

MPI_Finalize int MPI_Finalize() Τερματισμός περιβάλλοντος MPI Πρέπει να αποτελεί την τελευταία κλήση MPI του προγράμματος 21

Παράδειγμα προγράμματος MPI /* Παράλληλος υπολογισμός της παράστασης f(0)+f(1)*/ #include <mpi.h> int main(int argc,char** argv){ int v0,v1,sum,rank;,, MPI_Status stat; MPI_Init(&argc,&argv); MPI_ Comm_ rank(mpi _ COMM_ WORLD,&rank); if(rank==1) Διεργασία 1 MPI_Send(&f(1),1,0,50,MPI_INT,MPI_COMM_WORLD); else if(rank==0){ v0=f(0); MPI_Recv(&v1,1,1,50,MPI_INT,MPI_COMM_WORLD,&stat); sum=v0+v1; v1; } MPI_Finalize(); Διεργασία 0 } 22

Μπορεί να είναι point to point ή συλλογική (collective) Επικοινωνία Μπορείναείναι είναι synchronous, buffered ή ready (ανάλογαμε το τι θεωρείται ως συνθήκη επιτυχίας) Μπορείναείναι είναι blocking ή non blocking (ανάλογαμετοπότε επιστρέφει η συνάρτηση επικοινωνίας) 23

Συλλογική επικοινωνία Παράδειγμα: Αποστολή του msg στις διεργασίες 1-7 από τη 0 if(rank==0) for(dest=1;dest<size;dest++) MPI_Send(msg,count,dest,tag,MPI_FLOAT,MPI_COMM_WORLD); Γενικά: Για p διεργασίες έχουμε p-1 βήματα επικοινωνίας 24

Συλλογική επικοινωνία Παράδειγμα: Αποστολή του msg στις διεργασίες 1-7 από τη 0 MPI_Bcast(msg,count,MPI_FLOAT,0,MPI_COMM_WORLD); Γενικά: Για p διεργασίες έχουμε log 2 p βήματα επικοινωνίας 25

MPI_Bcast int MPI_Bcast(void* message, int count, MPI_Datatype datatype, int root, MPI_Comm comm) Αποστολή του message από τη διεργασία με rank root προς όλες της διεργασίες του communicator comm To message περιέχει count δεδομένα τύπου datatype Καλείται από όλες τις διεργασίες του comm 26

MPI_Reduce int MPI_Reduce(void* operand, void* result, int count, MPI_Datatype datatype, MPI_Op op, int root, MPI_Comm comm) Τα δεδομένα operand συνδυάζονται με εφαρμογή του τελεστή op, και το αποτέλεσμα αποθηκεύεται στη διεργασία root στο result Πρέπει να κληθεί από όλες τις διεργασίες του comm MPI_Op: MPI_MAX, MPI_MIN, MPI_SUM, MPI_PROD κλπ. Αντίστοιχα και MPI_Allreduce 27

Παράδειγμα συλλογικής επικοινωνίας /* Παράλληλος υπολογισμός της παράστασης f(0)+f(1)*/ #include <mpi.h> int main(int argc,char** argv){ int sum,rank; MPI_Status stat; MPI_Init(&argc,&argv); MPI_Comm_rank(MPI_COMM_WORLD,&rank); MPI_Reduce(&f(rank),&sum,1,MPI_INT,MPI_SUM,0, MPI_COMM_WORLD); MPI_Finalize(); } 28

MPI_Barrier int MPI_Barrier(MPI_Comm comm) Συγχρονίζονται όλες οι διεργασίες στον communicator comm Περιορίζει την παραλληλία 29

MPI_Gather int MPI_Gather(void* sendbuf, int sendcnt, MPI_Datatype sendtype, void* recvbuf, int recvcount, MPI_Datatype recvtype, int root, MPI_Comm comm) Συνενώνονται στη διεργασία root οι πίνακες sendbuf των υπολοιπών (κατά αύξουσα σειρά rank) Το αποτέλεσμα αποθηκεύεται στον πίνακα recvbuf, ο οποίος έχει νόημα μόνο στη διεργασία root Αντίστοιχα και MPI_Allgather Αντίστροφη: MPI_Scatter 30

Synchronous Buffered Ready Αναφέρονται σε λειτουργία αποστολής, διαφοροποιούνται ως προς λειτουργία λήψης Υπάρχουν τόσο σε blocking, όσο και σε non blocking μορφή Το απλό MPI_Send μπορεί να είναι είτε synchronous είτε buffered: εξαρτάται από υλοποίηση 31

Synchronous Buffered Ready int MPI_Ssend(void *buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) Επιτυγχάνει μόνο όταν πάρει επιβεβαίωση λήψης από δέκτη ασφαλές int MPI_Bsend(void *buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) Επιτυγχάνει όταν αντιγραφεί το μήνυμα σε system buffer για μελλοντική μετάδοση σφάλμα σε έλλειψη πόρων int MPI_Rsend(void *buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) Επιτυγχάνει μόνο αν έχει προηγηθεί αντίστοιχο receive από το δέκτη αβέβαιο 32

Synchronous Buffered Ready MPI_ Bsend MPI_ Ssend MPI_ Rsend Τοπικό Μη τοπικό Τοπικό 2 αντιγραφές στη 1 αντιγραφή στη 1 αντιγραφή στη μνήμη μνήμη μνήμη Αποτυγχάνει ελλείψει πόρων Δεν αποτυγχάνει αν δεν έχει προηγηθεί λήψη Δεν αποτυγχάνει ελλείψει πόρων Δεν αποτυγχάνει αν δεν έχει προηγηθεί λήψη Δεν αποτυγχάνει ελλείψει πόρων Αποτυγχάνει αν δεν έχει προηγηθεί λήψη 33

Άμεση επιστροφή Non blocking communication Δεν είναι ασφαλές να επαναχρησιμοποιηθούν οι buffers επικοινωνίας πριν ελεγχθεί η επιτυχία Δύο δυνατότητες για έλεγχο επιτυχίας της επικοινωνίας: int MPI_Test (MPI_Request* request,int* flag, MPI_Status* status) int MPI_Wait (MPI_Request* request,mpi_status* status) 34

Non blocking communication Κάθε blocking συνάρτηση έχει την αντίστοιχη non blocking: MPI_Isend Isend (για MPI_Send) MPI_Issend (για MPI_Ssend) MPI_ Ibsend (για MPI_ Bsend) MPI_Irsend (για MPI_Rsend) MPI_Irecv (για MPI_Recv) 35

Επικάλυψη υπολογισμών επικοινωνίας Blocking MPI_ Recv(); MPI_Send(); Compute(); Non-blocking MPI_ Irecv(); MPI_Isend(); Compute(); Waitall(); 36

Αποφυγή deadlocks Blocking (deadlock!) MPI_ Send(); MPI_Send(); MPI_Recv(); MPI_Recv(); Compute(); Non-blocking (no deadlock) MPI_ Isend(); MPI_Isend(); MPI_Irecv(); MPI_Irecv(); Waitall(); Compute(); 37

Τύποι δεδομένων MPI MPI_CHAR: 8 bit χαρακτήρας MPI_DOUBLE: 64 bit κινητής υποδιαστολής MPI_FLOAT: 32 bit κινητής υποδιαστολής MPI_INT: 32 bit ακέραιος MPI_LONG: 32 bit ακέραιος MPI_LONG_DOUBLE: 64 bit κινητής υποδιαστολής MPI_LONG_LONG: 64 bit ακέραιος MPI_LONG_LONG_INT: INT 64 bit ακέραιος MPI_SHORT: 16 bit ακέραιος MPI_SIGNED_CHAR: 8 bit προσημασμένος χαρακτήρας MPI_UNSIGNED: 32 bit απρόσημος ακέραιος MPI_UNSIGNED_CHAR: 8 bit απρόσημος χαρακτήρας MPI_UNSIGNED_LONG: 32 bit απρόσημος ακέραιος MPI_UNSIGNED_LONG_LONG: 64 bit απρόσημος ακέραιος MPI_UNSIGNED_SHORT: 16 bit απρόσημος ακέραιος MPI_WCHAR: 16 bit απρόσημος χαρακτήρας 38

Ομαδοποίηση δεδομένων επικοινωνίας: Τύποι δεδομένων MPI Παράμετρος count (για ομοιογενή δεδομένα σε συνεχόμενες θέσεις μνήμης) MPI_Type_struct (derived datatype) MPI_Pack(), MPI_Unpack() (για ετερογενή δεδομένα) 39

MPI 2 Παράλληλη είσοδος έξοδος (Parallel I/O) Δυναμική διαχείριση διεργασιών (dynamic process management) Απομακρυσμένες λειτουργίες μνήμης (remote memory operations) 40

Εκτέλεση προγράμματος MPI Linux cluster 12 Core 2 Duo @ 2.6 MHz κόμβων (twin1 twin12) Παράδειγμα 1 #mpicc test.c o test O3 #mpirun np 16 machinefile machinestest 41

Παράδειγμα 2 #cat <<EOF >machines kid5 kid7 kid8 kid10 EOF #mpicc test.c o test O3 static Wall #mpirun np 4 machinefile machines test Εκτέλεση προγράμματος MPI 42

Βιβλιογραφία Πηγές Writing Message Passing Parallel Programs with MPI (Course Notes Edinburgh Parallel Computing Center) Using MPI 2: Advanced Features of the Message Passing Interface (Gropp, Lusk, Thakur) http://www.mpi forum.org (MPI standards 1.1 και 2.0) http://www.mcs.anl.gov/mpi (MPICH υλοποίηση) comp.parallel.mpi (newsgroup) 43