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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти предыдущую перестановку http://www.cyberforum.ru/cpp-beginners/thread1491744.html
Собственно, есть перестановка, нужно найти N предыдущих и M следующих. Например для 132 предыдущей будет 123, а следующей 132. Мой код находит следующие. Помогите найти предыдущие :) ...
C++ Сбиваются указатели при переходе между функциями #include <iostream> #include <Windows.h> using namespace std; class Polynom { public: Polynom(int power_ = 0, float *koef_ = NULL); Polynom(Polynom &right); ~Polynom(); http://www.cyberforum.ru/cpp-beginners/thread1491743.html
Перевести дробное число, заданного в двоичной системе счисления, в шестнадцатеричную C++
Дано дробное число в двоичной системе счисления, т.е. последовательность цифр 0 и 1, разделенных точкой. Составить программу перевода этого числа в шестнадцатеричную систему счисления.
Как убрать округление? C++
Доброго времени суток. Компилятор Dev-c++ выдает при делении целое вместо дробного. Пробовал setf, usetf, precision. Чёта не получается блин. Помогите набраться опыта неофиту! Заранее спасибо....
C++ Как вывести элементы вектора, являющиеся членами класса? http://www.cyberforum.ru/cpp-beginners/thread1491713.html
#include <iostream> #include <vector> #include <cstdio> using namespace std; typedef struct moment{ int h,m,s; }moment; int main()
C++ Файл, данные из столбца в строку суть есть файл, в нем записи о людях, нужно перевести записи из столбца в строку и наверное убрать лишние символы, считать началом строки "(((" концом ")))" вдруг есть у кого что нить подобное или... подробнее

Показать сообщение отдельно
DabLDL
0 / 0 / 0
Регистрация: 14.01.2014
Сообщений: 3

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

02.07.2015, 13:26. Просмотров 195. Ответов 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru