-
Data: 2011-05-09 10:24:19
Temat: Re: Skąd dokładny zegar w C pod Win XP/7 ?
Od: Paweł Kierski <n...@p...net> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2011-05-09 09:43, KrisB pisze:
> Użytkownik "Zbigniew Malec" <a...@i...invalid> napisał w wiadomości
> news:131qyujfagg1$.1vjfkt1ng7lwq$.dlg@40tude.net...
>
>> On Sun, 8 May 2011 23:22:07 +0200, KrisB wrote:
>>
>>> Funkcja C time( time_t) z rozdzielczością do milisekund mi nie
>>> wystarcza-potrzebuję rozdzielczości gdzieś do mikrosekund.
>>
>> Jeżeli potrzebujesz takiej dokładności, to znaczy, że masz złą metodykę
>> pomiaru*. Pomiar powinien opierać się na setkach/tysiącach prób i
>> uśrednionym czasie wykonania. Wtedy rozdzielczość do mikrosekund nie jest
>> potrzebna.
>>
>> *prawdopodobnie
>
> 1) Mam algorytm który będzie wykonywany dla danych rozmiaru max ~naście.
> Wykona się to w czasie max kilku msek.
> 2) Co do tych tysięcy prób: a jak "odfiltrować" koszty samej obsługi
> tych tysięcy prób ? Wywołanie / obsługa pętli / niemiarodajna zawartość
> cache tj. na ogół większość danych przy powtarzających się wywołaniach
> już będzie w cache ?
Pomiar można zrobić timerem o rozdzielczości (dużo) mniejszej niż czas
mierzony, trzeba tylko odpowiednio dużo powtórzeń i nie mieć bardzo
dużego pecha 8-)
Zakładam, że z początkiem pomiaru trafiamy losowo względem ticku
timera. Wtedy szansa, że wartość timera się zmieni podczas naszego
pomiaru jest taka, jak stosunek czasu operacji do okresu zegara. Czyli
wystarczy:
totalTime = 0;
for(1..N)
start = time(0);
operation();
end = time(0);
totalTime += end - start;
averageTime = totalTime / N;
Duży pech jest wtedy, gdy jakaś wielokrotność (K) czasu jednego obiegu
pętli jest bardzo bliska okresowi zegara. W przypadku dokładnej
równości dostajesz zawsze wynik równy 0 lub N/K cykli.
Dla pewności warto pętlę powtarzać nie określoną liczbę razy, ale do
czasu, aż uzbieramy pewne minimum zakumulowanego czasu.
Cache chyba da się "opróżnić" między wywołaniami (ktoś bardziej fachowy
się pewnie wypowie). Tyle, że to znacznie wydłuży czas pomiaru.
--
Paweł Kierski
n...@p...net
Następne wpisy z tego wątku
- 09.05.11 19:18 Zbigniew Malec
- 10.05.11 06:57 Bronek Kozicki
- 10.05.11 07:08 Bronek Kozicki
- 10.05.11 11:38 Mariusz Marszałkowski
- 10.05.11 11:48 Paweł Kierski
- 10.05.11 21:52 Zbigniew Malec
- 12.05.11 12:36 Mariusz Marszałkowski
- 12.05.11 12:37 Mariusz Marszałkowski
- 14.05.11 12:19 Sasquatch
Najnowsze wątki z tej grupy
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
Najnowsze wątki
- 2024-12-28 Antyradar
- 2024-12-28 Deweloper przegral w sadzie musi zwrócic pieniądze Posypia sie kolejne pozwy?
- 2024-12-28 Warszawa => Full Stack .Net Engineer <=
- 2024-12-28 Warszawa => Sales Assistant <=
- 2024-12-28 Warszawa => Programista Full Stack .Net <=
- 2024-12-28 Warszawa => Full Stack web developer (obszar .Net Core, Angular6+) <=
- 2024-12-28 Katowice => Head of Virtualization Platform Management and Operating S
- 2024-12-28 Błonie => Analityk Systemów Informatycznych (TMS SPEED) <=
- 2024-12-28 Warszawa => Senior Frontend Developer (React + React Native) <=
- 2024-12-28 Żerniki => Employer Branding Specialist <=
- 2024-12-28 ale zawziętość i cierpliwość
- 2024-12-27 most kilometrowy
- 2024-12-27 Dyplomaci a alkomaty
- 2024-12-27 Zmiana kary
- 2024-12-27 Chiński elektrolizer tester wody