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

MPI, ошибка исполнения

24.11.2016, 01:21. Показов 1114. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
int size, rank;
MPI_Init(&argc, &argv);
MPI_Comm_size(MPI_COMM_WORLD, &size);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
MPI_Status status;
if (rank == 0)
{
    cout << "vvedi N: ";
    cin >> N;
    MPI_Bcast(&N, 1, MPI_INT, 0, MPI_COMM_WORLD);   
}
if (rank != 0)
{
    MPI_Recv(&N, 1, MPI_INT, 0, MPI_ANY_TAG, MPI_COMM_WORLD, &status);
}
я не знаю почему, но код стопорится на этом моменте
суть кода: я ввожу в нулевом процессе значение переменной N, и через MPI_Bcas передаю всем кроме нулевого процесса, так?(ну про то, что кроме 0)
потом считываю сообщение, но это не работает. Я не знаю почему, но он застревает, такое ощущение что не передается, или передается, но косячно
в чем проблема?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
24.11.2016, 01:21
Ответы с готовыми решениями:

Ошибка во время исполнения
При попытке запустить программу Visual Studio пишет: Unhandled exception at 0x011027ce in...

Ошибка во время исполнения
Здравствуйте, вылазит ошибка: Debug Assertion Failed! Expression: string subscript out of range ...

Ошибка этапа исполнения
Всем доброго времени суток! Пытаюсь решить вот эту задачу: В ряд выложены N кучек камней, в i-ой...

Ошибка исполнения С3861
#include &lt;iostream&gt; #include &lt;Windows.h&gt; using namespace std; struct Node { char *firstname;...

3
sourcerer
24.11.2016, 08:50
  #2
 Комментарий модератора 
tupen_T_T, пожалуйста, прочитайте правила форума.
Особое внимание обратите на следующие пункты:
4.3 (порядок именования тем)
4.9 (порядок оформления кода).
0
693 / 303 / 99
Регистрация: 04.07.2014
Сообщений: 846
24.11.2016, 09:03 3
Цитата Сообщение от tupen_T_T Посмотреть сообщение
но код стопорится на этом моменте
А почитать как работает MPI_Bcast?

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
#include <iostream>
#include <mpi.h>
 
int main(int argc, char **argv)
{
  int size, rank;
  int N;
 
  MPI_Init(&argc, &argv);
  MPI_Comm_size(MPI_COMM_WORLD, &size);
  MPI_Comm_rank(MPI_COMM_WORLD, &rank);
 
  if (rank == 0) {
    std::cout << "vvedi N: ";
    std::cin >> N;
  }
 
  MPI_Bcast(&N, 1, MPI_INT, 0, MPI_COMM_WORLD);
 
  std::cout << rank << ": " << N << std::endl;
 
  MPI_Finalize();
  return 0;
}
1
0 / 0 / 0
Регистрация: 12.04.2016
Сообщений: 75
24.11.2016, 16:49  [ТС] 4
AlexVRud, представьте я читала и пыталась разобраться. И сложилось впечатление, хоть и не верное, что MPI_Bcast() похожа на MPI_Send(), только разница в том, что всем процессам разом и так же как и с MPI_Send() необходима MPI_Recv() для получения и внесения в переменную полученной информации. Но вы показали что это не так, хотя конечно хотелось бы пару слов, но и на этом большое спасибо.
0
24.11.2016, 16:49
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
24.11.2016, 16:49
Помогаю со студенческими работами здесь

Ошибка этапа исполнения
Доброго времени суток! Хочу разобраться с ошибкой, буду благодарна за помощь) Вот код функции: ...

Ошибка исполнения Stack overflow
Решил написать что-то вроде стратегии в консоле, но в итоге застрял в самом начале ( не могу найти...

Ошибка исполнения std::bad_array_new_length
Здравствуйте. Сделал программу по заданию (в приложении), пробую скомпилировать - в Visual Studio...

Вывод массива по спирали. Ошибка исполнения.
Дан квадратный массив задаваемой размерности, нужно вывести в ряд его элементы змейкой начиная с...


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

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