12 QueryPerformanceFrequency(&freq_);
\r
13 QueryPerformanceCounter(&time_);
\r
19 QueryPerformanceCounter(&t);
\r
20 int ticks_passed = static_cast<int>(static_cast<__int64>(t.QuadPart) - static_cast<__int64>(time_.QuadPart));
\r
21 return static_cast<double>(ticks_passed)/static_cast<double>(freq_.QuadPart);
\r
26 QueryPerformanceCounter(&time_);
\r
29 // Author: Ryan M. Geiss
\r
30 // http://www.geisswerks.com/ryan/FAQS/timing.html
\r
31 void tick(double interval)
\r
34 QueryPerformanceCounter(&t);
\r
36 if (time_.QuadPart != 0)
\r
38 int ticks_to_wait = static_cast<int>(static_cast<double>(freq_.QuadPart) * interval);
\r
42 QueryPerformanceCounter(&t);
\r
44 int ticks_passed = static_cast<int>(static_cast<__int64>(t.QuadPart) - static_cast<__int64>(time_.QuadPart));
\r
45 int ticks_left = ticks_to_wait - ticks_passed;
\r
47 if (t.QuadPart < time_.QuadPart) // time wrap
\r
49 if (ticks_passed >= ticks_to_wait)
\r
54 // if > 0.002s left, do Sleep(1), which will actually sleep some
\r
55 // steady amount, probably 1-2 ms,
\r
56 // and do so in a nice way (cpu meter drops; laptop battery spared).
\r
57 // otherwise, do a few Sleep(0)'s, which just give up the timeslice,
\r
58 // but don't really save cpu or battery, but do pass a tiny
\r
60 if (ticks_left > static_cast<int>((freq_.QuadPart*2)/1000))
\r
63 for (int i = 0; i < 10; ++i)
\r
64 Sleep(0); // causes thread to give up its timeslice
\r
73 LARGE_INTEGER freq_;
\r
74 LARGE_INTEGER time_;
\r