opencv時間測量函數

來源:互聯網
上載者:User

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.