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

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

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

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

02.07.2015, 13:26. Просмотров 172. Ответов 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;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.07.2015, 13:26     Обмен между процессами в MPI
Посмотрите здесь:

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

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

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

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

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

Обмен значений между двумя вещественными переменными. - C++
Помогите пожалуйста, решить задачи =))) Разработайте процедуру, которая получает через параметры две вещественные переменные х, у и...

Функция, которая выполняет обмен значений между двумя целочисленными переменными - C++
Задание такое: написать функцию, которая выполняет обмен между двумя целочисленными переменными. Тип аргумента - int*. #include&lt;iostream&gt;...

Функция interchange(), которая выполняет обмен значений между двумя переменными - C++
Нужно написать программу с функцией interchange(), которая выполняет обмен значений между двумя переменными типа int вот то что я...

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

Операции с процессами - C++
Решил написать маленький нубо анти-чит :tomatos: . но тут возникла проблема, я не могу найти подходящей литературы. Задача такова: нужно,...


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

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

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