Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
DabLDL
0 / 0 / 0
Регистрация: 14.01.2014
Сообщений: 3
#1

Обмен между процессами в MPI - C++

02.07.2015, 13:26. Просмотров 204. Ответов 0
Метки нет (Все метки)

Здравствуйте. Стоит задача передать из главного процесса значение в побочные, и принять все значения из побочных в главный и разместить их в массив. Принципиально эту задачу надо решить без коллективной пересылки данных. Или это не возможно осуществить? Потому что мне кажется программа работает не корректно именно из-за цикла в главном процессе. Извиняюсь за кривой код, я только учусь =) Заранее спасибо всем кто откликнется. Вот код который у меня получился:
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
#include "stdafx.h"
#include "mpi.h"
 
 
int _tmain(int argc, char* argv[])
{
    int rank, size;
    MPI_Status status;
    MPI_Init(&argc, &argv);
    MPI_Comm_rank(MPI_COMM_WORLD, &rank);
    MPI_Comm_size(MPI_COMM_WORLD, &size);
 
    double a = rank;
    double *arr = new double(size-1);
    arr[0] = 111;
    
    if (rank == 0)
    {
        for (int i = 1; i < size; ++i)
        {
            MPI_Ssend(&arr[0], 1, MPI_DOUBLE, i, 10, MPI_COMM_WORLD);
            MPI_Recv(&arr[i - 1], 1, MPI_DOUBLE, i, 10, MPI_COMM_WORLD, &status);
        }
        for (int i = 0; i < size - 1; i++) printf("process %d = %d\n", rank, arr[i]);
    }
    else
    {
        double b;
        MPI_Recv(&b, 1, MPI_DOUBLE, 0, 10, MPI_COMM_WORLD, &status);
        printf("process %d = %d\n", rank, b);
        MPI_Ssend(&a, 1, MPI_DOUBLE, 0, 10, MPI_COMM_WORLD);
        
    }
 
    MPI_Finalize();
 
 
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.07.2015, 13:26
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Обмен между процессами в MPI (C++):

Обмен данными между процессами - C++
Уважаемое сообщество, подскажите, пожалуйста, с решением такой проблемы: у меня два процесса c# и с++, и мне необходимо передавать массив...

Обмен данными между процессами - C++
Добрый день! Нужно распараллелить программу. Суть в следующем: должны быть два процесса(разные функции), идущих параллельно, и второй...

Обмен данными между двумя процессами - C++
Добрый день/вечер. Усердно слушал преподавателя на паре, прошуршал много литературы дома, но так и не понял, как заюзать обмен данными...

Обмен данными между процессами в консольных приложениях - C++
Привет. Можно ли как - то обмениваться данными между двумя запущенными консольными приложениями без WinAPI и без использования файлов...

Обмен данными между процессами с помощью файлов, которые отображаются в память - C++
Классическая задача &quot;читатели-писатели&quot;, обмен информацией должен проходить с помощью файлов, отображаемых в память. Задание уже готово, но...

Канал между процессами - C++
Задача у программы такова. Имеется основная программа(main) и две дополнительных(prc1 и prc2). В prc1 и prc2 стоит прогресс бар, который...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.07.2015, 13:26
Привет! Вот еще темы с ответами:

Взаимодействие между процессами двух приложений - C++
В задании к лабораторной сказано, что нужно открыть файл в одном приложении, а считывать данные с помощью другого приложения. Не могу...

Переслать вектор N процессам, используя различные виды связи между процессами (MPI_Alltoall) - C++
Переслать вектор, размерности M, N процессам, используя различные виды связи между процессами. Элементы вектора задаются произвольно....

Обмен между приложениями - C++
Есть два приложения в ОС Windows , одно консольное которое ждет ввода трех чисел std::cin , второе диалоговое , диалоговое запускает...

Обмен данными между программами - C++
Здравствуйте Помогите сделать программу, чтобы при наборе все символов в сервере они сразу же отображались в клиенте, вот похожее, но...


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

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

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