opencv和matlab计时

来源:互联网 发布:php xss攻击过滤处理 编辑:程序博客网 时间:2024/05/28 15:03

 一、opencv

给程序计时对于程序员来说实在是太重要了,在windows上的那个clock()实在是不够精确,精度只有10ms,真让人难过。研究了下windows下使用C、C++计时的函数,给大家分享下。

主要就是两个函数的使用。我先把一段可以运行的代码贴出来,然后讲讲这两个函数。

[cpp] view plaincopy
  1. #include <windows.h>  
  2. #include <stdio.h>  
  3. int main(int argc, char **argv)  
  4. {  
  5.     LARGE_INTEGER freq;  
  6.     LARGE_INTEGER start_t, stop_t;  
  7.     double exe_time;  
  8.     QueryPerformanceFrequency(&freq);  
  9.     fprintf(stdout, "The frequency of your pc is %d.\n", freq.QuadPart);  
  10.     QueryPerformanceCounter(&start_t);  
  11.     Sleep(1000);  
  12.     QueryPerformanceCounter(&stop_t);  
  13.     exe_time = 1e3*(stop_t.QuadPart-start_t.QuadPart)/freq.QuadPart;  
  14.     fprintf(stdout, "Your program executed time is %fms.\n", exe_time);   
  15.     getchar();  
  16.     return 0;  
  17. }  


1、LARGE_INTEGER在微软的编译器中实际上是一个union,它的定义如下:

 

[cpp] view plaincopy
  1. typedef union _LARGE_INTEGER  
  2. {    
  3.     struct   
  4.     {      
  5.         DWORD LowPart;     
  6.         LONG HighPart;    
  7.     };   
  8.     struct   
  9.     {     
  10.         DWORD LowPart;      
  11.         LONG HighPart;    
  12.     } u;    
  13.     LONGLONG QuadPart;  
  14. } LARGE_INTEGER,  *PLARGE_INTEGER;  

如果你使用的编译器支持64位整数,那么可以使用QuadPart来引用变量的值。如果你的编译器不支持64位整数,那么可以使用LowPart和HighPart来引用64位整数的低32位和高32位。

2、QueryPerformanceFrequncy(LARGE_INTEGER *freq)

它用于获得你的机器一秒钟执行多少次,就是你的时钟周期。

3、QueryPerformanceCounter(LARGE_INTEGER *lpPerformanceCount)

它获得的是CPU从开机以来执行的时钟周期数。

二、matlab计时

tstart=tic;
%想要计时的程序

tend=toc(tstart);