Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лекции по параллельному программированию (MPI).doc
Скачиваний:
2
Добавлен:
01.07.2025
Размер:
781.31 Кб
Скачать

Передача сообщения «точка-точка»

Для передачи сообщения процесс-отправитель должен выполнить функцию:

Int mpi_Send(void *buf, int count, mpi_Datatype type, int dest, int tag, mpi_Comm comm)

Функция использует следующие параметры:

buf – адрес буфера памяти, в котором располагаются данные отправляемого сообщения;

count – количество элементов данных в сообщении;

type – тип элементов данных пересылаемого сообщения;

dest – ранг процесса, которому отправляется сообщение;

tag – значение-тег, используемое для идентификации сообщений;

comm – коммуникатор, в рамках которого выполняется передача данных.

Для указания типа пересылаемых данных в MPI имеется ряд базовых типов, список которых приведен в табл. 1.

Таблица 1. Соответствие типов в MPI и языке Cи

Тип MPI

Тип Cи

MPI_CHAR

char

MPI_BYTE

unsigned char

MPI_SHORT

short

MPI_INT

int

MPI_LONG

long

MPI_FLOAT

float

MPI_DOUBLE

double

MPI_UNSIGNED_CHAR

unsigned char

MPI_UNSIGNED_SHORT

unsigned short

MPI_UNSIGNED

unsigned int

MPI_UNSIGNED_LONG

unsigned long

MPI_LONG_DOUBLE

long double

Также в MPI имеются типы MPI_BYTE и MPI_PACKED, которые не имеют соответствия в языке Си. Значением типаMPI_BYTE является байт. Байт не интерпретируется и отличен от символа. Различные машины могут иметь различное представление для символов или могут использовать для представления символов более одного байта. При этом байт имеет то же самое двоичное значение на всех машинах.

Необходимо отметить следующее:

1. Отправляемое сообщение определяется через указание блока памяти (буфера), в котором это сообщение располагается. Используемые для указания буфера три параметра (buf, count, type) входят в состав параметров практически всех функций передачи данных.

2. Процессы, между которыми выполняется передача данных, в обязательном порядке должны принадлежать коммуникатору, указываемому в функции MPI_Send.

3. Параметр tag используется только при необходимости различения передаваемых сообщений, в противном случае в качестве значения параметра может быть использовано произвольное целое число (см. также описание функции MPI_Recv).

Сразу же после завершения функции MPI_Send процесс-отправитель может начать повторно использовать буфер памяти, в котором располагалось отправляемое сообщение. Вместе с этим, следует понимать, что в момент завершения функции MPI_Send состояние самого пересылаемого сообщения может быть совершенно различным – сообщение может располагаться в процессе-отправителе, может находиться в процессе передачи, может храниться в процессе-получателе или же может быть принято процессом-получателем при помощи функции MPI_Recv. Тем самым, завершение функции MPI_Send означает лишь, что операция передачи начала выполняться и пересылка сообщения будет рано или поздно будет выполнена.