Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
maksimkalon
9 / 8 / 7
Регистрация: 03.03.2013
Сообщений: 71
1

Прием MPI_Bcast

30.04.2014, 11:51. Просмотров 1628. Ответов 6
Метки нет (Все метки)

При передаче сообщений с помощью функции MPI_Send, принять процессом-получателем можно с помощью функции MPI_Recv, а как принимать сообщения, отправленные MPI_Bcast?
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.04.2014, 11:51
Ответы с готовыми решениями:

Прием врача
Очень тяжелая задача(( я пробовал сам писать но ни чего не получилось((...

Задача Прием у директора
Здравствуйте, уважаемые пользователи этого замечательного форума! Написал...

UDP отправка и прием пакетов
Вообщем такая ситуация. Отправляю пакеты объемом по 1 кБайту, пачками по 32...

Server Socket и прием данных
Доброго времени суток. Никак не могу разобраться с компонентом ServerSocket....

Одновременный прием по двум портам
День добрый возник вопрос - можно ли сделать одновременный прием по двум портам...

6
nullpointer
46 / 46 / 14
Регистрация: 30.03.2009
Сообщений: 523
30.04.2014, 12:05 2
maksimkalon, посмотрите на MPI_Allgather, она позволяет осуществлять прием на всех процессах
0
gng
846 / 582 / 179
Регистрация: 08.09.2013
Сообщений: 1,567
30.04.2014, 13:26 3
Цитата Сообщение от maksimkalon Посмотреть сообщение
а как принимать сообщения, отправленные MPI_Bcast?
Один из процессов, вызывающих MPI_Bcast, передает сообщение, остальные - принимают.
0
maksimkalon
9 / 8 / 7
Регистрация: 03.03.2013
Сообщений: 71
30.04.2014, 14:15  [ТС] 4
Цитата Сообщение от nullpointer Посмотреть сообщение
maksimkalon, посмотрите на MPI_Allgather, она позволяет осуществлять прием на всех процессах
Делаю так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
    int flag;
    MPI_Initialized(&flag);
    if (flag == 0)
        return;
    int rank, size;
    MPI_Comm_size(MPI_COMM_WORLD, &size);
    MPI_Comm_rank(MPI_COMM_WORLD, &rank);
    
    MPI_Status s;
    int a;
 
    if(rank == 0)
    {
        *Ввод а*
        MPI_Bcast(&a,1,MPI_INT,0,MPI_COMM_WORLD);
    }
    else
    {
        int b;
        MPI_Allgather(&a,1,MPI_INT,&b,1,MPI_INT,MPI_COMM_WORLD);
        *Вывод b*
    }
Результат: все процессы зависают

Добавлено через 53 секунды
Цитата Сообщение от gng Посмотреть сообщение
Один из процессов, вызывающих MPI_Bcast, передает сообщение, остальные - принимают.
Это я понимаю Мне интересно как принять
0
gng
846 / 582 / 179
Регистрация: 08.09.2013
Сообщений: 1,567
30.04.2014, 14:49 5
Лучший ответ Сообщение было отмечено maksimkalon как решение

Решение

Цитата Сообщение от maksimkalon Посмотреть сообщение
Это я понимаю Мне интересно как принять
Все процессы вызывают MPI_Bcast. При этом один передает, остальные принимают.
Что тут непонятного?
0
maksimkalon
9 / 8 / 7
Регистрация: 03.03.2013
Сообщений: 71
30.04.2014, 14:57  [ТС] 6
Теперь понятно, спасибо
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
    int flag;
    MPI_Initialized(&flag);
    if (flag == 0)
        return;
    int rank, size;
    MPI_Comm_size(MPI_COMM_WORLD, &size);
    MPI_Comm_rank(MPI_COMM_WORLD, &rank);
    
    MPI_Status s;
    int a;
 
    if(rank == 0)
    {
        *Ввод а*
        MPI_Bcast(&a,1,MPI_INT,0,MPI_COMM_WORLD);
    }
    else
    {
        MPI_Bcast(&a,1,MPI_INT,0,MPI_COMM_WORLD);
        *Вывод а*
    }
Тема закрыта.
0
gng
846 / 582 / 179
Регистрация: 08.09.2013
Сообщений: 1,567
30.04.2014, 15:22 7
Обычно делают проще
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <stdio.h>
#include <mpi.h>
 
main (int ac, char *av[]) {
  MPI_Init(&ac, &av);
  int rank, size;
  MPI_Comm_size(MPI_COMM_WORLD, &size);
  MPI_Comm_rank(MPI_COMM_WORLD, &rank);
 
  int a= 17;
  MPI_Bcast(&a,1,MPI_INT,0,MPI_COMM_WORLD);
  printf ("%d: %d\n", rank, a);
 
  MPI_Finalize();
}
0
30.04.2014, 15:22
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
30.04.2014, 15:22

Подскажите, как называется этот прием?
Всем привет:) Допустим, имеется какой-либо класс, имеющий поля данных и два...

Прием, передача и сравнение последовательности Баркера
Подскажите пожалуйста.Пишу программу клиент-сервер. Клиент передает ...

Хранение информации о сотрудниках, прием и увольнение с работы
Разработать программу с помощью объектно ориентированного программирования,...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru