我有三个计算来获得当前的cpu频率:(每秒周期数)
_initialCycles = rdtsc(); //rdtsc function calculates the cpu cycles since init.
first:
------
unsigned int initialMillisec = (_timeVal.tv_sec)*1000+(_timeVal.tv_usec)/1000;
unsigned int cps1 = ((_initialCycles / initialMillisec) * 1000);
second:
-------
double initialMillisec2 = (_timeVal.tv_sec)*1000+(_timeVal.tv_usec)/1000.0;
unsigned int cps2 = (unsigned int)(_initialCycles / initialMillisec2 * 1000.0);
third:
------
unsigned long long initialUsec3 =
((unsigned long long)(_timeVal.tv_sec))*1000000+_timeVal.tv_usec) ;
unsigned int cps3 = (unsigned int)((_initialCycles / initialUsec3)* 1000000.0);
事情是,cps1 cps2 cps3假设具有相同的值,或多或少.. 但他们没有。我明白了:
cps1 = 2824048000
cps2 = 3824609671
cps3 = 8000000
谁知道为什么?
答案 0 :(得分:5)
整数类型的问题在于舍入。当你除以某个大数字时,你会丢失有效数字。因此,您应该更改乘法和除法之间的操作顺序。首先,你应该乘以1000(或long long
的情况下为1000000),然后除以。
使用整数忽略准确性的一些例子:
321/20 * 20 = 320;
321/75 * 75 = 300;
321/112 * 112 = 224
答案 1 :(得分:2)
还有许多其他线程和进程同时运行,OS调度程序可能会担心这种测量频率的方法。
尝试使用“cpufreq”实用程序准确获取当前时钟速度。
答案 2 :(得分:0)
运算符优先级和隐式转换。
当然,您需要确保按照您希望的顺序对运算符进行评估。我最好的建议是:如果你不得不三思而后,就不需要了解订单。
然后:你需要尽早将int转换为浮点数,否则你最终会得到整数除法和ditto舍入错误。
unsigned int initialMillisec = _timeVal.tv_sec*1000 + _timeVal.tv_usec/1000;
unsigned int cps1 = (1.0 * _initialCycles / initialMillisec) * 1000.0;
将是我的建议