Форум программистов, компьютерный форум, киберфорум
MPI
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
1 / 1 / 0
Регистрация: 16.09.2019
Сообщений: 55
1

Отправка и прием сообщений в MS MPI

16.10.2020, 11:06. Показов 1128. Ответов 2
Метки mpi (Все метки)

Author24 — интернет-сервис помощи студентам
Программа должна делать следующее: процессы с рангом не равным 0 генерируют вектор размера 100000 (у каждого процесса свой вектор), вычисляют его норму и с помощью функции MPI_Send пересылают результат процессу с номером 0, а процесс с номером 0 принимает результаты с помощью функций MPI_Irecv/MPI_Test и выводит их на экран. Есть код, но работает неправильно, не могу понять, в чем ошибка:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#include "mpi.h"
#include "omp.h"
#include "iostream"
 
using namespace std;
 
double VectorNorm(double* a, int n)
{
   double x = 0;
#pragma omp parallel for reduction(+ : x)
   for (int i = 0; i < n; i++)
      x += a[i] * a[i];
   x = sqrt(x);
   return x;
}
 
 
int main(int argc, char **argv)
{
   int rank, size;
   int n = 100000;
   double norm_s, norm_r;
   int flag;
   MPI_Request rq;
   MPI_Status st;
 
 
   MPI_Init(&argc, &argv);
   MPI_Comm_rank(MPI_COMM_WORLD, &rank);
   MPI_Comm_size(MPI_COMM_WORLD, &size);
 
   if (rank != 0)
   {
      double* v = new double[n];
      for (int i = 0; i < n; i++)
         v[i] = rand();
      norm_s = VectorNorm(v, n);
      MPI_Send(&norm_s, 1, MPI_DOUBLE, 0, 0, MPI_COMM_WORLD);
   }
   else 
   {
      for (int i = 0; i < size; i++)
      {
         MPI_Irecv(&norm_r, 1, MPI_DOUBLE, i, 0, MPI_COMM_WORLD, &rq);
         MPI_Test(&rq, &flag, &st);
         cout << "Process # " << i << " sent norm of vector " << norm_r;
      }
   }
 
   MPI_Finalize();
   return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.10.2020, 11:06
Ответы с готовыми решениями:

MPI. Отправка/приём сообщений по тегам
Здравствуйте! Я написал простой код. Его суть заключается в следующем: Мастер выводит свой ранг...

Отправка и прием сообщений
Здравствуйте! Мне нужно написать приложение, которое позволяло бы общаться его пользователям. При...

WebSocket прием и отправка сообщений
Помогите сделать чатик, я уже долгое время мучаюсь, но не понимаю как сделать. :( Проблема в ...

Отправка\прием сообщений с применением Indy 10
Всем доброго времени суток. Помогите решить проблему. Пишу клиент-серверное приложение с...

2
693 / 303 / 99
Регистрация: 04.07.2014
Сообщений: 846
16.10.2020, 16:10 2
Lexangross51, Функция MPI_Test(&rq, &flag, &st); сохранит в переменную flag завершена или нет операция передачи данных. Вы не проверяете этот flag, и следовательно, в переменной norm_r ещё нет нужных данных и выводиться мусор.

Добавлено через 2 минуты
Кроме этого вы в процессе с rank=0 ждёте данные от самого себя, цикл чтения должен быть 1, а не с 0
0
1 / 1 / 0
Регистрация: 16.09.2019
Сообщений: 55
16.10.2020, 18:44  [ТС] 3
То есть нужно сначала вызвать функцию MPI_Test, затем проверить выполняется ли условие flag==true, а только после этого получать сообщения? Я правильно понимаю?
0
16.10.2020, 18:44
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
16.10.2020, 18:44
Помогаю со студенческими работами здесь

Прием и отправка сообщений с использование сокетов
Здравствуйте. Нашел в интернете образец кода сервера который оказался бы для меня весьма полезным....

WinAPI: отправка и прием сообщений окнам
1. Отсылаю окну программы сообщение WM_QUIT, программа не завершается. static...

Асинхронные сокеты: Как организовать разделение на прием сообщений и прием файлов
Изучив синхронные сокеты, перешел к изучению асинхронных. Столкнулся вот с чем, как, используя...

Прием сообщений от сервера
Здравствуйте, уважаемые форумчане! Такая проблема возникла. Пишу клиент-серверное приложение, в...

Прием почтовых сообщений
Нашел такой код сделал тестовый почтовый ящик и решил попробовать: procedure...

Прием сообщений IdIRC
Здравствуйте. Как сделать прием сообщений? IdIRC. Коннект идет по кнопке...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru