OpenCV-计时函数cv::getTickCount&cv::getTickFrequency

OpenCV-计时函数cv::getTickCount&cv::getTickFrequency本文介绍了一种便于记忆的 OpenCV 计时函数 方便大家使用

场景需求

       使用OpenCV时,如果有计时的需求,就记住两个函数cv::getTickCount和cv::getTickFrequency,应用非常简单也方便记忆,C++中有多种多样的计时方法,选择自己最常用最便于记忆的使用就可以了~

       下面简单分享下cv::getTickCount和cv::getTickFrequency这两个函数的使用。

C++实现代码

/ * @brief getTickCount() 该函数返回CPU自某个事件以来走过的时钟周期数 * @brief getTickFrequency() 该函数返回CPU一秒钟所走的时钟周期数。便于以秒为单位进行计时。 */ // 计时开始 double timex = static_cast<double>(getTickCount()); // 需要计时的函数或代码 .............. // 计时结束 timex = ((double)getTickCount() - timex) / getTickFrequency(); // 时间输出 cout << "运行时间为:" << timex << "秒" << endl ;

测试代码

#include<iostream> #include<opencv2/opencv.hpp> #include<ctime> using namespace std; using namespace cv; int main(void) { Mat A = Mat::zeros(10000, 10000, CV_32FC1); // 随意创建一个A矩阵 for (int i = 0; i < A.rows; i++) { for (int j = 0; j < A.cols; j++) { A.at<float>(i, j) = rand() % 100 / 100.f; } } Mat B = A.clone(); // 计时开始 double time0 = static_cast<double>(getTickCount()); for (int i = 0; i < A.rows; i++) { for (int j = 0; j < A.cols; j++) { B.at<float>(i, j) *= 2; } } // 计时结束 time0 = ((double)getTickCount() - time0) / getTickFrequency(); // 时间输出 cout << " 运行时间为:" << time0 << "秒" << endl << endl; system("pause"); return 0; }

测试效果

OpenCV-计时函数cv::getTickCount&cv::getTickFrequency
图1 计时输出

       本文介绍了一种便于记忆的OpenCV计时函数,方便大家使用。

       如果文章帮助到你了,可以点个赞让我知道,我会很快乐~加油!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233208.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号