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

Распараллеливание потоков для нахождения суммы матрицы <omp.h> - C++

Восстановить пароль Регистрация
 
nedsi
2 / 2 / 0
Регистрация: 18.09.2013
Сообщений: 65
28.10.2013, 17:27     Распараллеливание потоков для нахождения суммы матрицы <omp.h> #1
Доброго дня. Сегодня слушал занимательную лекцию об распараллеливание потоков и получил задание: есть матрица 10,10 инициализированная рандомными числами -> сделать параллельные потоки для нахождения сумы.
Пробовал так:
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
#include "stdafx.h"
#include <iostream>
#include <omp.h>
#include <stdlib.h>
 
using namespace std;
 
int main()
{   
    int i,j, thread1,thread2,sum = 0;
    int mas[10][10];
    double start_time, end_time, time;
 
    for (i = 0; i<10; i++)
        for (j = 0; j<10; j++)
            mas[i][j] = rand() % 10;    
    for (i = 0; i<10; i++)
    {
        for (j = 0; j<10; j++)
            cout<<mas[i][j]<<" ";
        cout<<"\n";
    }
    i = 0; j = 0;
    omp_set_num_threads(4);
    start_time = omp_get_wtime();
#pragma omp parallel
    {
        #pragma omp for schedule(static,2);
        
        for (i = 0; i<10; i++)
        {
                thread1 = omp_get_thread_num();
                if (i==j) sum+=mas[i][j];
                cout<<"\ni : "<<i<<" thread1 : "<<thread1;
        }
 
        for (j = 0; j<10; j++)
        {
                if (i==j) sum+=mas[i][j];
                thread2 = omp_get_thread_num();
                cout<<"\nj : "<<j<<" thread2 : "<<thread2;
        }
        
 
    }
    end_time = omp_get_wtime();
    time = end_time - start_time;
    cout<<"\nsum : "<<sum<<"\n";
    cout<<"time : "<<time<<"\n";
    system("pause");
    return 0;
}
Но видимо чего то не понял и не правильно сделал, как переделать тело #pragma omp parallel? По началу я думал, что после исполнения первой итерации в первом цикле, включится второй поток во втором и так по очереди, но не тут то было. Благодарю.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.10.2013, 17:27     Распараллеливание потоков для нахождения суммы матрицы <omp.h>
Посмотрите здесь:

C++ Класс "Матрица" для нахождения суммы, разности, умножения матриц и суммы элементов матрицы.
C++ Составить программу для нахождения суммы
C++ Функция для нахождения суммы факториалов
C++ Даны две матрицы. Определить функцию нахождения суммы двух матриц
C++ Распараллеливание метода нахождения обратной матрицы
Составить программу для нахождения суммы чисел от 1 до 100 C++
Использование рекурсивной функции для нахождения суммы C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16828 / 5249 / 321
Регистрация: 30.03.2009
Сообщений: 14,133
Записей в блоге: 26
16.11.2014, 23:27     Распараллеливание потоков для нахождения суммы матрицы <omp.h> #2
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
#include <omp.h>
#include <stdio.h>
 
int main (void)
{
  int arr[10][10];
  int i, j;
  int sum, lsum;
 
  for (i = 0; i < 10; i++)
    for (j = 0; j < 10; j++)
      arr[i][j] = (i+1) * (j+1);
 
  sum = 0;
#pragma omp parallel for num_threads(4) private(j, lsum) shared(sum, arr)
  for (i = 0; i < 10; i++)
    {
 
#pragma omp critical
      {
        printf ("i=%d, thread=%d\n", i, omp_get_thread_num());
      }
 
      /* В потоке вычисляем сумму i-го ряда и помещаем в локальную переменную lsum */
      lsum = 0;
      for (j = 0; j < 10; j++)
        lsum += arr[i][j];
 
      /* Далее сумму по каждому ряду складываем в общую переменную sum */
#pragma omp atomic
      sum += lsum;
    }
 
  printf ("sum=%d\n", sum);
 
  return 0;
}
Добавлено через 19 минут
Тут тоже на дату создания поста внимания не обратил
Yandex
Объявления
16.11.2014, 23:27     Распараллеливание потоков для нахождения суммы матрицы <omp.h>
Ответ Создать тему
Опции темы

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