Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
tupen_T_T
0 / 0 / 0
Регистрация: 12.04.2016
Сообщений: 59
24.11.2016, 01:21     MPI, ошибка исполнения #1
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)
потом считываю сообщение, но это не работает. Я не знаю почему, но он застревает, такое ощущение что не передается, или передается, но косячно
в чем проблема?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.11.2016, 01:21     MPI, ошибка исполнения
Посмотрите здесь:

C++ Вывод массива по спирали. Ошибка исполнения.
C++ Ошибка во время исполнения
Ошибка во время исполнения C++
Ошибка во время исполнения runtime-error C++
Ошибка этапа исполнения в классе Матрица C++
Ошибка этапа исполнения - переполнение стека C++
Ошибка исполнения при записи в vector C++
Ошибка этапа исполнения C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
gru74ik
24.11.2016, 08:50
  #2
 Комментарий модератора 
tupen_T_T, пожалуйста, прочитайте правила форума.
Особое внимание обратите на следующие пункты:
4.3 (порядок именования тем)
4.9 (порядок оформления кода).
AlexVRud
413 / 142 / 36
Регистрация: 04.07.2014
Сообщений: 413
24.11.2016, 09:03     MPI, ошибка исполнения #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;
}
tupen_T_T
0 / 0 / 0
Регистрация: 12.04.2016
Сообщений: 59
24.11.2016, 16:49  [ТС]     MPI, ошибка исполнения #4
AlexVRud, представьте я читала и пыталась разобраться. И сложилось впечатление, хоть и не верное, что MPI_Bcast() похожа на MPI_Send(), только разница в том, что всем процессам разом и так же как и с MPI_Send() необходима MPI_Recv() для получения и внесения в переменную полученной информации. Но вы показали что это не так, хотя конечно хотелось бы пару слов, но и на этом большое спасибо.
Yandex
Объявления
24.11.2016, 16:49     MPI, ошибка исполнения
Ответ Создать тему
Опции темы

Текущее время: 23:36. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru