• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

OMP zrównoleglenie pętli

Object Storage Arubacloud
0 głosów
629 wizyt
pytanie zadane 12 listopada 2017 w C i C++ przez niezalogowany
zmienione kategorie 12 listopada 2017 przez Eryk Andrzejewski

Witam, dlaczego poniższy program raz wykonuje się w ok. 200 ms a raz w ok. 2000ms? 

Ktoś ma jakieś sugestie?

 

int i;
	clock_t start = clock();

	#pragma omp parallel default(shared) private(i) num_threads(6)
	{
		#pragma omp for schedule(static, 100) nowait
		for (i = 0; i < count; i++) {
			array[i] = value;
			Sleep(1);
		}

	}
	cout << "Czas wykonywania pierwszej funkcji: " << (clock() - start) << "ms" << endl;

 

2 odpowiedzi

0 głosów
odpowiedź 12 listopada 2017 przez Tomasz90 Nałogowiec (25,140 p.)
wybrane 20 grudnia 2017
 
Najlepsza
W OpenMP nie powinno się używać funkcji clock() do pomiaru czasu. Należy wykorzystać funkcję omp_get_wtime() gdyż zwraca ona rzeczywisty czas. Ogólnie wykonując pomiary czasu należy wziąć pod uwagę, że pierwsze wykonanie pomiaru może być dłuższe niż kolejne. Dlatego należy wykonać kilka pomiarów i wyciągnąć z tego średnią.
komentarz 12 listopada 2017 przez niezalogowany
Dziękuje za pomoc. :)
0 głosów
odpowiedź 12 listopada 2017 przez mokrowski Mędrzec (155,460 p.)

Wiesz co, mierzyłem tak:

#include <iostream>
#include <chrono>
#include <thread>

int main() {

    constexpr int count = 10000;
    int array[count];
    auto value = 42;

    using namespace std::chrono;
    using namespace std;

    auto start = high_resolution_clock::now();

    int i;
    #pragma omp parallel default(shared) private(i) num_threads(6)
    {
        #pragma omp for schedule(static, 100) nowait
        for (i = 0; i < count; i++) {
            array[i] = value ;
            this_thread::sleep_for(milliseconds(1));
        }
    }
    auto stop = high_resolution_clock::now();
    cout << "Czas wykonywania pierwszej funkcji: "
        << duration_cast<milliseconds>(stop - start).count()
        << " ms." << std::endl;
}

.. i wyniki wychodzą powtarzalne. Skalowalność zbliżona do czynnika 6.

Chyba że źle odczytałem intencje Twojego fragmentu kodu?

A tak na marginesie, może warto popełnić do pomiarów takie coś:

#include <iostream>
#include <chrono>

using namespace std;

// Jakieś przykładowe funkcje... 
int fast_fun() {
    int sum{};
    for(size_t i = 0; i < 1000; ++i) {
        sum += i;
    }
    return sum;
}

long slow_fun() {
    long sum{};
    for(size_t i = 0; i < 10000000000; ++i) {
        sum += i;
    }
    return sum;
}

long other_fun(int z) {
    long sum{};
    for(int i = 0; i < z; ++i) {
        sum += i;
    }
    return sum;
}

template<typename Func, typename... TT>
void check_time(const string& message, Func func, TT&& ...tt) {
    using namespace chrono;
    cout << message << endl;
    auto start_time = high_resolution_clock::now();

    func(std::forward<TT>(tt)...);

    auto end_time = high_resolution_clock::now();
    cout << "Wykonanie zajęło: " 
        << duration_cast<microseconds>(end_time - start_time).count()
        << " us.\n";
}

int main() {
    cout << "Precyzja Twojego zegara to "
        << (static_cast<double>(chrono::high_resolution_clock::period::num)
         / chrono::high_resolution_clock::period::den) << " impulsów na sekundę.\n";
    check_time("Funkcja fast_fun()", fast_fun);
    check_time("Funkcja slow_fun()", slow_fun);
    check_time("Funkcja other_fun()", other_fun, 900);
}

 

komentarz 12 listopada 2017 przez niezalogowany
Dziękuje za pomoc. :)

Podobne pytania

+1 głos
2 odpowiedzi 305 wizyt
pytanie zadane 5 stycznia 2022 w JavaScript przez aaliskaa Nowicjusz (160 p.)
0 głosów
1 odpowiedź 112 wizyt
pytanie zadane 7 lutego 2021 w C i C++ przez Nabuchadonozor Gaduła (3,120 p.)

92,576 zapytań

141,426 odpowiedzi

319,652 komentarzy

61,961 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...