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

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

Восстановить пароль Регистрация
 
DabLDL
0 / 0 / 0
Регистрация: 14.01.2014
Сообщений: 3
02.07.2015, 13:26     Обмен между процессами в MPI #1
Здравствуйте. Стоит задача передать из главного процесса значение в побочные, и принять все значения из побочных в главный и разместить их в массив. Принципиально эту задачу надо решить без коллективной пересылки данных. Или это не возможно осуществить? Потому что мне кажется программа работает не корректно именно из-за цикла в главном процессе. Извиняюсь за кривой код, я только учусь =) Заранее спасибо всем кто откликнется. Вот код который у меня получился:
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;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.07.2015, 13:26     Обмен между процессами в MPI
Посмотрите здесь:

C++ Канал между процессами
Обмен данными между двумя процессами C++
Обмен данными между процессами с помощью файлов, которые отображаются в память C++
C++ Взаимодействие между процессами двух приложений
Обмен данными между процессами в консольных приложениях C++
Обмен данными между процессами C++
Переслать вектор N процессам, используя различные виды связи между процессами (MPI_Alltoall) C++
C++ Обмен данными между процессами

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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