OpenCV深入學習(3)--opencv中測量已耗用時間的函數
最開始的C介面中的是 cvGetTickCount()和 cvGetTickFrequency(),在程式段的開始和結束時兩次使用cvGetTickCount(),然後將兩次的差除以cvGetTickFrequency()後就可以獲得程式段的以微秒us為單位的已耗用時間,不是很精確但是一般足夠了。
到了2.x之後在命名空間cv中又多了幾個函數,getTickCount(),getTickFrequency(),getCPUTickCount(),此時仍然可以使用上面的C介面的函數,也可以使用這幾個namespace cv中的函數,兩次使用getTickCount(),然後再除以getTickFrequency(),不過需要注意的是這時計算出來的是以秒s為單位的時間,這個是與上面的帶cv首碼的函數的不同,而要使用更精確的計時,就需要使用getCPUTickCount(),不過現代電腦CPU的頻率會隨著負載而變化所以沒大有必要使用該函數,可以參看函數的介紹【Also,
since a modern CPU varies the CPU frequency depending on the load, the number of CPU clocks spent in some code cannot be directly converted to time units. Therefore,getTickCount is generally a preferable solution for measuring
execution time.】也就是使用getTickCount就足夠了。
同時C++介面中還將上面的函數封裝為了一個類TickMeter,方便使用,下面是關於TickMeter的聲明和實現的源碼:
http://blog.csdn.net/ljbsdu/article/details/7378392