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

Написать программу сложения двух матриц одинакового размера - C++

Восстановить пароль Регистрация
 
upstrocker
0 / 0 / 0
Регистрация: 31.05.2013
Сообщений: 7
16.05.2014, 00:15     Написать программу сложения двух матриц одинакового размера #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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#include <stdio.h>
#include <mpi.h>
#define M 110
#define N 110
    int A[M][N], B[M][N], C[M][N];
int main(int argc, char* argv[])
{
    int i,j,ProcRank,ProcSize, sum=0, s=0;
    double t1, t2;
    MPI_Init(&argc, &argv);
    MPI_Comm_rank(MPI_COMM_WORLD, &ProcRank);
    MPI_Comm_size(MPI_COMM_WORLD, &ProcSize);
    if (ProcRank==0)
    {
    t1=MPI_Wtime();
    for (i=0; i<M; i++) 
    {
        for (j=0; j<N; j++)
        {
            A[i][j] = 5;
            B[i][j] = 6;
            C[i][j] = 0;
        }
    }
 
    }
    MPI_Bcast(A, M*N, MPI_INT, 0, MPI_COMM_WORLD);
    MPI_Bcast(B, M*N, MPI_INT, 0, MPI_COMM_WORLD);
    MPI_Bcast(C, M*N, MPI_INT, 0, MPI_COMM_WORLD);
MPI_Barrier(MPI_COMM_WORLD);
 
 
 
 
 
    for (i=0; i<M; i++) 
    {
        for (j=0; j<N; j++)
        {
            C[i][j] += A[i][j] + B[i][j];
            sum += C[i][j];
        }
    }
 
    //MPI_Reduce(&sum, &s, 1, MPI_INT, MPI_SUM, 0, MPI_COMM_WORLD);
 
    if (ProcRank==0)
    {
    t2=MPI_Wtime();
    printf("sec: %lf\n",t2-t1);
    printf("s: %d\n", sum);
    } 
    MPI_Finalize();
 
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.05.2014, 00:15     Написать программу сложения двух матриц одинакового размера
Посмотрите здесь:

C++ Написать программу сложения двух матриц А и В размерами 4 на 5
C++ Написать программу, которая позволяет осуществить ввод 2-х матриц одинакового размера
C++ Матрицы: сложения двух матриц (двумерных массивов)
Написать процедуру сложения матриц. C++
C++ Заданные две квадратные матрицы одинакового размера - А и В. Переписать в одномерный массив R те элементы матриц А и В, имеющие одинаковые индексы и
Разработать алгоритм и написать по нему программу сложения матриц А и В размера m × n C++
Произвести сложение двух массивов 5х3 по правилам сложения матриц C++
Написать программу нахождения суммы диагональных элементов двух матриц C++

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

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

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