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

OpenMP. Время выполнения программы увеличивается с количеством потоков - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Вывод массива в много файлов в цикле http://www.cyberforum.ru/cpp-beginners/thread1101256.html
Доброго времени суток. Ситуация следующая: есть большой массив его надо поделить в файлы для чтение в excel в ниже приведенном случае утрировал ситуацию: создаём файл "3200 2200 .txt" в него в цикле пишем ""asdf"<<j++" по сути текст и порядковый номер строки в файле, когда в файл записано "(j>=40)" строк создаётся новый файл, но в него я могу писать только внутри текущего IF (outfile << "tyt...
C++ Интернет радио, как осуществить работу с буфером? по заданию, мне нужно реализовать работу интернет радио. собираю информацию как хочу сделать: есть сервер (windows), на нем запущена программа, которая берет mp3 файлы и как-то их расшаривает. к примеру записывает в какой-нибудь буфер (небольшой), а клиент читает этот буфер. клиент - это браузер. пока не могу понять, как осуществить работу с буфером? В роли буфера использовать файл или... http://www.cyberforum.ru/cpp-beginners/thread1101244.html
C++ Аргументы функции main
Здравствуйте! Очень нужна Ваша помощь... Дано натуральное n. Для n, вводимого с клавиатуры получите действительную квадратную матрицу порядка n, вычислив ее элементы по формуле: a(i,j)=cos((i^2)+n). Выполните сортировку элементов каждого столбца матрицы по убыванию или возрастанию. Критерий сортировки передавайте в качестве аргумента функции main.
Счётчик нажатия на кнопку C++
Здравствуйте, совсем замучился вроде бы плёвое дело, но не могу написать. На форме кнопка при нажатие на неё например Lable ну или в Edit вписывалось 1 после повторного нажатия вписывалось 2 при 3 соответственно 3 и т.д. Сколько раз клацнул на кнопку столько раз счётчик +1 и сделал.
C++ Ошибка в сортировке слияния http://www.cyberforum.ru/cpp-beginners/thread1101184.html
Добрый день, Написал сортировку слиянием в небольшой программке. Компелирует, но при запуске программы зависает на моменте, когда доходит до процедуры сливания массивов(как мне кажется). не подскажите в чем дело? Заранее спасибо // ConsoleApplication1.cpp: определяет точку входа для консольного приложения. // #include "stdafx.h" #include <iostream>
C++ Наследование и полиморфизм. Задача с классом Ellipsoid Добрый день) Подскажите, поджалуйста, что по заданию корректно изменить в задаче нужно: На основе класса Shape (фигура) образовать класс Ellipsoid (эллипсоид). Эллипсоид будет характеризоваться данными x, y, z (наследуются от Shape) и a,b,c – полуоси. В классе Ellipsoid переопределить функцию для расчета объема ob(). Объем эллипсоида вычисляется по формуле V = 4πabc/3. #include <iostream>... подробнее

Показать сообщение отдельно
Engmor
 Аватар для Engmor
0 / 0 / 0
Регистрация: 09.02.2014
Сообщений: 7
20.02.2014, 14:49     OpenMP. Время выполнения программы увеличивается с количеством потоков
Задача: найти сумму максимальных элементов строк матрицы. Я составил код программы и распараллелил циклы. На компьютере вроде работает как и должно: с увеличением количества потоков, время выполнения программы уменьшается. Но при проверке той же программы на кластере ситуация становится абсолютно противоположной: чем больше потоков, тем дольше работает программа.
Код программы
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
#include <iostream>
#include <stdio.h>
#include <time.h>
#include <omp.h>
 
using namespace std;
 
const long int mW = 10000, mH = 10000;
int i, j, tempMax = 0, stringMax = 0;;
long double clockStart, clockStop, tick;
int matrix[mW][mH];
 
int main() {
 
    clockStart = omp_get_wtime();
    srand(time(NULL));
 
#pragma omp parallel private(i) shared(j) //ещё set_num_threads(n) для десктопа
    {
#pragma omp for
        for (j = 0; j < mH; j++) {
            for (i = 0; i < mW; i++) {
                matrix[i][j] = rand() % 1000000;
            }
        }
    }
 
#pragma omp parallel private(i,tempMax) shared(j,stringMax) //ещё set_num_threads(n) для десктопа
    {
#pragma omp for
        for (j = 0; j < mH; j++) {
            tempMax = 0;
            for (i = 0; i < mW; i++) {
                if (matrix[i][j] > tempMax) {
                    tempMax = matrix[i][j];
                }
            }
#pragma omp critical
            stringMax += tempMax;
        }
    }
 
    cout << stringMax << endl;
    clockStop = omp_get_wtime();
    tick = omp_get_wtick();
    cout << "Seconds: " << (clockStop - clockStart) << endl;
    cout << "Timer accuracy: " << tick << endl << endl;
 
    return 0;
}

Так же к теме прикрепляю скриншоты результатов выполнения программы
Миниатюры
OpenMP. Время выполнения программы увеличивается с количеством потоков  
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 22:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru