接上回:http://blog.csdn.net/pennyliang/archive/2010/10/21/5956302.aspx
有时候我们希望在x86平台下获得更加高的精度。如果我们想准确的知道一段程序,一个函数的执行时间,可以连续执行2次rdtsc,之间没有一行代码,来计算这两段指令执行过程会有的cycle数,不同机器可能都会有不同,和机器的性能有关系,但和负载没关系,也就是多进程,多线程情况下,连续两个rdtsc之间不会插入很多cycle,这一点大家可以做实验来验证。
start = rdtsc();
end = rdtsc();
在获得这个数据后,我们对一段代码的执行时间就可以做一个更加精确的估计。我的测试机比较一般大约是100个cycle,
用100/(3000.164*1000*1000)=0.033微秒,约合33纳秒,这个时间段几乎是不会发生什么进程切换的,因此可以认为计算的精度是可接受的。
RDTSC只在X86下有效,其余平台会有类似指令来做准确计数,RDTSC指令的精度是可以接受的,里面能插得cycle是很有限的。如果对计数要求没那么高,可以采用一些通用库函数,当然你也可以用类似的方法来考察这些库函数的精度,连续执行2次就行。
例如下面的代码得到两次rdtsc指令之间的cycle数。
#include <stdlib.h>
#include <stdio.h>
#if defined(__i386__)
static __inline__ unsigned long long rdtsc(void)
{
unsigned long long int x;
__asm__ volatile ("rdtsc" : "=A" (x));
return x;
}
#elif defined(__x86_64__)
static __inline__ unsigned long long rdtsc(void)
{
unsigned hi, lo;
__asm__ __volatile__ ("rdtsc" : "=a"(lo), "=d"(hi));
return ( (unsigned long long)lo)|( ((unsigned long long)hi)<<32 );
}
#endif
int main(void)
{
register int start = 0;
register int end = 0;
const int MAX_COUNT = 10000000;
volatile int sum = 0;
const float CPU_MHZ = 3000.164; //use cat /proc/cpuinfo get the value
const float CPU_tick_count_per_second = CPU_MHZ*1000*1000;
start = rdtsc();
end = rdtsc();
printf("sum:%d,run tick count:%d,run time:%f\n",sum,end - start,(end -start)/CPU_tick_count_per_second);
return 0;
}
分享到:
相关推荐
小学数学数学故事小女儿巧计救父
800个有趣句子帮你记忆7000个单词(完整修正版).doc )
个省级行政区的名称和位置巧计PPT教案.pptx
艾宾浩斯记忆曲线背单词2010 免分下载了。 大家帮帮忙,从下面的地址进入论坛,也帮我挣点学习币。 http://bbs.ebenglish.org/?fromuid=2558
试听巧计10000单词,杨金明 往年的参考资料,仅共参考
2020考研数学阅卷人概念·公式·定理速查巧计手册。2020考研数学阅卷人概念·公式·定理速查巧计手册。2020考研数学阅卷人概念·公式·定理速查巧计手册。
项目管理44个过程输入输出工具技术忆巧计法--项管考试通关秘笈---中高级需要学习
初中语文文摘历史苏军巧计“忽悠”希特勒
个省级行政区的名称和位置巧计.pptx
个省级行政区的名称和位置巧计学习教案.pptx
句子难度较大,但顺下来很便于记忆,能有所提高。
考研英语词汇巧计。20天内记住考研词汇,拥有去的故事记住考研英语单词
自己复习托福 才知道但背单词有多艰难 无论是词根式还是其他方法 这是我见到的最好的方法了 共享给大家
软考是作为一个项目经理重要的考试,他为项目经理在实际工作提供有效的指导思想。本资料主要针对软件的44个过程输入输出工具借助图形做了归纳总结,方便大家复习使用。
31.下一个排列----巧计 32.(hard)最长有效括号----栈 33.搜索旋转排序数组----二分查找 34.在排序数组中查找元素的第一个和最后一个位置----二分查找 39.组合总和----回溯 42.(hard)接雨水----双指针或栈 46....
山东省泰安市岱岳区徂徕镇第一中学2015年中考化学巧计元素符号复习素材
不规则动词巧计 巧计可记得更牢固,好好看看怎样记的,背背吧
仅仅是数学概念公式定理的参考手册,仅供参考。这个就不能免费下载吗?
态巧计巧多円标贝叶斯理论框架下可1^^描述成一个集巧估计问题。但基于随机巧限集 的多円标贝叶斯滤波并不能由传统的单口标贝叶斯滤波巧接推广获得。这是由于单口 标贝叶斯滤波所估计的变量是单目标的...