-
Path: news-archive.icm.edu.pl!news.rmf.pl!agh.edu.pl!news.agh.edu.pl!news.onet.pl!.PO
STED!not-for-mail
From: Paweł Kierski <n...@p...net>
Newsgroups: pl.comp.programming
Subject: Re: Skąd dokładny zegar w C pod Win XP/7 ?
Date: Mon, 09 May 2011 12:24:19 +0200
Organization: http://onet.pl
Lines: 53
Message-ID: <iq8fct$gk8$1@news.onet.pl>
References: <iq71ht$q84$2@inews.gazeta.pl>
<131qyujfagg1$.1vjfkt1ng7lwq$.dlg@40tude.net>
<iq85vc$qp5$1@inews.gazeta.pl>
NNTP-Posting-Host: 195.182.34.201
Mime-Version: 1.0
Content-Type: text/plain; charset=ISO-8859-2; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: news.onet.pl 1304936669 17032 195.182.34.201 (9 May 2011 10:24:29 GMT)
X-Complaints-To: n...@o...pl
NNTP-Posting-Date: Mon, 9 May 2011 10:24:29 +0000 (UTC)
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.1; pl; rv:1.9.2.17) Gecko/20110414
Thunderbird/3.1.10
In-Reply-To: <iq85vc$qp5$1@inews.gazeta.pl>
Xref: news-archive.icm.edu.pl pl.comp.programming:190220
[ ukryj 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
- A Szwajcarzy kombinują tak: FinalSpark grows human neurons from stem cells and connects them to electrode arrays
- Re: Najgorszy język programowania
- NOWY: 2025-09-29 Alg., Strukt. Danych i Tech. Prog. - komentarz.pdf
- Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML
- Błąd w Sofcie Powodem Wymiany 3 Duńskich Fregat Typu Iver Huitfeldt
- Grok zaczął nadużywać wulgaryzmów i wprost obrażać niektóre znane osoby
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
Najnowsze wątki
- 2025-12-11 To już efekt Żurka czy coś jeszcze GORSZEGO?
- 2025-12-11 Policjanci w mieście Łodzi zmierzą ci prędkość z błędem mniejszym niż producent w laboratorium :-)
- 2025-12-11 Warszawa => Senior Java Developer <=
- 2025-12-11 Kolejny prezent
- 2025-12-10 hameryka
- 2025-12-10 Tak im zależy na wlasnym kraju. :-(
- 2025-12-10 Czy "hipoteka przymusowa" podpada (powinna podpadać) pod ochronę immunitetem poselskim? [Ziobro]
- 2025-12-10 Żurek po raz kolejny wykazał jaki poziom reprezentuje
- 2025-12-10 Gdańsk => Microsoft Dynamics AX/365 SCM Consultant - Service & Suppor
- 2025-12-10 Rzeszów => Konsultant ERP Microsoft Dynamics 365 Commerce <=
- 2025-12-10 Chrzanów => Spedytor Międzynarodowy (handel ładunkami/prowadzenie f
- 2025-12-10 Chiny => Koordynator Produkcji / Przedstawiciel ds. rozwoju produktu <
- 2025-12-10 Przekroczenie uprawnien
- 2025-12-10 China => Production Coordinator / Representant Product Dev <=
- 2025-12-10 Gdynia => Przedstawiciel handlowy / KAM (branża TSL) <=




2035 rok coraz mniej realny? Europa traci tempo w wyścigu o elektromobilność