OpenCV的TickMeter计时类
OpenCV的TickMeter计时类
- 1. TickMeter是一个计时的类
- 1.1 计算耗时
- 1.2 计算循环的平均耗时和FPS
- 1.3 function
- 2. 案例
1. TickMeter是一个计时的类
https://docs.opencv.org/4.x/d9/d6f/classcv_1_1TickMeter.html#details
1.1 计算耗时
TickMeter tm;tm.start();// do something ...tm.stop();cout << "Total time: " << tm.getTimeSec() << endl;
1.2 计算循环的平均耗时和FPS
TickMeter tm;for (int i = 0; i < COUNT; i++){tm.start();// do something ...tm.stop();cout << "Last iteration: " << tm.getLastTimeSec() << endl;}cout << "Average time per iteration in seconds: " << tm.getAvgTimeSec() << endl;cout << "Average FPS: " << tm.getFPS() << endl;
1.3 function
index | function |
---|---|
1 | getAvgTimeMilli |
2 | getAvgTimeSec |
3 | getCounter |
4 | getFPS |
5 | getTimeMicro |
6 | getTimeMilli |
7 | getTimeSec |
8 | getTimeTicks |
9 | reset |
10 | start |
11 | stop |
2. 案例
import timeimport cv2tm = cv2.TickMeter()
index = 0
print(f"|index|function|")
print(f"|:----:|:----:|")
for i, con in enumerate(dir(tm)):if con.startswith("__"):continueindex += 1print(f"|{index}|\t{con}|")def show():for _ in range(10):tm.start()time.sleep(0.1)tm.stop()print(f"总计数次数 Last iteration: {tm.getCounter()}")print(f"getTimeSec 总耗时(s): {tm.getTimeSec()} getTimeMilli 总耗时(ms): {tm.getTimeMilli()} "f"getTimeMicro 总耗时(us): {tm.getTimeMicro()} getTimeTicks 总tick(us): {tm.getTimeTicks()}")print(f"Average time per iteration in seconds: {tm.getAvgTimeSec()} Millis: {tm.getAvgTimeMilli()}")print(f"Average FPS: {tm.getFPS()}")show()
tm.reset()
print("after tm.reset()" + "------------------------")
show()
|index|function|
|:----:|:----:|
|1| getAvgTimeMilli|
|2| getAvgTimeSec|
|3| getCounter|
|4| getFPS|
|5| getTimeMicro|
|6| getTimeMilli|
|7| getTimeSec|
|8| getTimeTicks|
|9| reset|
|10| start|
|11| stop|
总计数次数 Last iteration: 1
getTimeSec 总耗时(s): 0.105019959 getTimeMilli 总耗时(ms): 105.019959 getTimeMicro 总耗时(us): 105019.959 getTimeTicks 总tick(us): 105019959
总计数次数 Last iteration: 2
getTimeSec 总耗时(s): 0.209122084 getTimeMilli 总耗时(ms): 209.122084 getTimeMicro 总耗时(us): 209122.084 getTimeTicks 总tick(us): 209122084
总计数次数 Last iteration: 3
getTimeSec 总耗时(s): 0.311539417 getTimeMilli 总耗时(ms): 311.53941699999996 getTimeMicro 总耗时(us): 311539.41699999996 getTimeTicks 总tick(us): 311539417
总计数次数 Last iteration: 4
getTimeSec 总耗时(s): 0.412974 getTimeMilli 总耗时(ms): 412.974 getTimeMicro 总耗时(us): 412974.0 getTimeTicks 总tick(us): 412974000
总计数次数 Last iteration: 5
getTimeSec 总耗时(s): 0.51804475 getTimeMilli 总耗时(ms): 518.04475 getTimeMicro 总耗时(us): 518044.75 getTimeTicks 总tick(us): 518044750
总计数次数 Last iteration: 6
getTimeSec 总耗时(s): 0.623065542 getTimeMilli 总耗时(ms): 623.0655419999999 getTimeMicro 总耗时(us): 623065.5419999999 getTimeTicks 总tick(us): 623065542
总计数次数 Last iteration: 7
getTimeSec 总耗时(s): 0.727750709 getTimeMilli 总耗时(ms): 727.750709 getTimeMicro 总耗时(us): 727750.709 getTimeTicks 总tick(us): 727750709
总计数次数 Last iteration: 8
getTimeSec 总耗时(s): 0.831228417 getTimeMilli 总耗时(ms): 831.228417 getTimeMicro 总耗时(us): 831228.417 getTimeTicks 总tick(us): 831228417
总计数次数 Last iteration: 9
getTimeSec 总耗时(s): 0.933850459 getTimeMilli 总耗时(ms): 933.850459 getTimeMicro 总耗时(us): 933850.459 getTimeTicks 总tick(us): 933850459
总计数次数 Last iteration: 10
getTimeSec 总耗时(s): 1.038880917 getTimeMilli 总耗时(ms): 1038.880917 getTimeMicro 总耗时(us): 1038880.9169999999 getTimeTicks 总tick(us): 1038880917
Average time per iteration in seconds: 0.10388809169999999 Millis: 103.88809169999999
Average FPS: 9.625742312099858
after tm.reset()------------------------
总计数次数 Last iteration: 1
getTimeSec 总耗时(s): 0.10503875 getTimeMilli 总耗时(ms): 105.03875 getTimeMicro 总耗时(us): 105038.75 getTimeTicks 总tick(us): 105038750
总计数次数 Last iteration: 2
getTimeSec 总耗时(s): 0.210075042 getTimeMilli 总耗时(ms): 210.075042 getTimeMicro 总耗时(us): 210075.042 getTimeTicks 总tick(us): 210075042
总计数次数 Last iteration: 3
getTimeSec 总耗时(s): 0.315131042 getTimeMilli 总耗时(ms): 315.131042 getTimeMicro 总耗时(us): 315131.04199999996 getTimeTicks 总tick(us): 315131042
总计数次数 Last iteration: 4
getTimeSec 总耗时(s): 0.416519501 getTimeMilli 总耗时(ms): 416.519501 getTimeMicro 总耗时(us): 416519.501 getTimeTicks 总tick(us): 416519501
总计数次数 Last iteration: 5
getTimeSec 总耗时(s): 0.521595918 getTimeMilli 总耗时(ms): 521.5959180000001 getTimeMicro 总耗时(us): 521595.9180000001 getTimeTicks 总tick(us): 521595918
总计数次数 Last iteration: 6
getTimeSec 总耗时(s): 0.626131752 getTimeMilli 总耗时(ms): 626.131752 getTimeMicro 总耗时(us): 626131.752 getTimeTicks 总tick(us): 626131752
总计数次数 Last iteration: 7
getTimeSec 总耗时(s): 0.727543668 getTimeMilli 总耗时(ms): 727.543668 getTimeMicro 总耗时(us): 727543.6680000001 getTimeTicks 总tick(us): 727543668
总计数次数 Last iteration: 8
getTimeSec 总耗时(s): 0.832573168 getTimeMilli 总耗时(ms): 832.573168 getTimeMicro 总耗时(us): 832573.1680000001 getTimeTicks 总tick(us): 832573168
总计数次数 Last iteration: 9
getTimeSec 总耗时(s): 0.937604126 getTimeMilli 总耗时(ms): 937.604126 getTimeMicro 总耗时(us): 937604.1259999999 getTimeTicks 总tick(us): 937604126
总计数次数 Last iteration: 10
getTimeSec 总耗时(s): 1.04264996 getTimeMilli 总耗时(ms): 1042.6499600000002 getTimeMicro 总耗时(us): 1042649.9600000002 getTimeTicks 总tick(us): 1042649960
Average time per iteration in seconds: 0.10426499600000001 Millis: 104.26499600000001
Average FPS: 9.590946514782392Process finished with exit code 0
相关文章:

OpenCV的TickMeter计时类
OpenCV的TickMeter计时类 1. TickMeter是一个计时的类1.1 计算耗时1.2 计算循环的平均耗时和FPS1.3 function 2. 案例 1. TickMeter是一个计时的类 https://docs.opencv.org/4.x/d9/d6f/classcv_1_1TickMeter.html#details 1.1 计算耗时 TickMeter tm;tm.start();// do some…...

蓝桥杯JAVA刷题--001
文章目录 题目需求2.代码3.总结 题目需求 2.代码 class Solution {public String convertDateToBinary(String date) {if (date null || date.length() ! 10 || date.charAt(4) ! - || date.charAt(7) ! -) {throw new IllegalArgumentException("输入的日期格式不正确&…...
免费又开源:企业级物联网平台的新选择 ThingsPanel
在开源领域,选择合适的开源协议是开发者和企业能否充分利用平台的关键。ThingsPanel,作为一个专注于物联网的开源平台,近日将协议从 AGPLv3 改为更开放的 Apache 2.0。这一改变对开发者和用户意味着什么? 为什么协议要从 AGPLv3 转…...
鸿蒙开发:文本合成语音
前言 Android开发的同学都知道,在Android当中,实现一段文字合成语音播放,可以使用系统提供的对象TextToSpeech来很快的实现,如果不用系统自带的,也可以使用三方提供的,比如讯飞的语音合成等等,总…...
雷军:科技传奇的逐梦之旅
亲爱的小伙伴们😘,在求知的漫漫旅途中,若你对深度学习的奥秘、Java 与 Python 的奇妙世界,亦或是读研论文的撰写攻略有所探寻🧐,那不妨给我一个小小的关注吧🥰。我会精心筹备,在未来…...

LeetCode - 初级算法 数组(删除排序数组中的重复项)
免责声明:本文来源于个人知识与公开资料,仅用于学术交流。 删除排序数组中的重复项 这篇文章讨论如何从一个非严格递增的数组 nums 中删除重复的元素,使每个元素只出现一次,并返回新数组的长度。因为数组是排序的,只要是相同的肯定是挨着的,所以我们需要遍历所有数组,然…...

2024年度培训运维总结
目前带的弟子跟我实战训练运维的总就业率基本可以稳定在 100% 左右(因为我不带小白和没学历和大龄,悟性低都筛掉了还能找我说明条件够了) 以下是弟子私教训练营的最新就业数据(2024年12月25日): 面试辅导…...

java重装小结
一、Java安装 安装路径 https://www.oracle.com/java/technologies/javase/javas e8-archive-downloads.html 具体类型可参考: Java安装配置-CSDN博客 我在这一步主要碰到的问题就是访问官网报404错误,可参考: 在oracle官网下载资源显示…...
ubuntu20.04 中文输入法安装
中文输入法安装指南 在 Ubuntu 20.04 上安装中文输入法,您可以按照以下步骤操作: 打开终端。安装 fcitx 输入法框架和中文输入法模块:sudo apt update sudo apt install fcitx fcitx-pinyin安装中文语言支持:sudo apt install l…...
SQL常用语句(基础)大全
SQL语句的类型 1.DDL 1.库2.表 2.DML 1.插入数据 insert inot2.删除数据 delete / truncate3.修改数据 update set 3.DQL 1.无条件查询2.查询 什么开始 到什么结束3.指定条件查询 1.单个条件 ro in2.多个条件 and4.查询不为NULL值 is not null ,为NULL值 is null5.模糊查询 li…...

计算和可视化相对湿度结果
了解如何确定 CFD 模型中的相对湿度。 了解相对湿度 大气是干燥空气和水蒸气的混合物,每一种的压力之和等于蒸气压。相对湿度是指空气中的水分量与空气在特定温度下可以容纳的最大水分量之比。它通常以百分比表示。它的范围从 0(干燥空气)到…...

uniapp-vue3(下)
关联链接:uniapp-vue3(上) 文章目录 七、咸虾米壁纸项目实战7.1.咸虾米壁纸项目概述7.2.项目初始化公共目录和设计稿尺寸测量工具7.3.banner海报swiper轮播器7.4.使用swiper的纵向轮播做公告区域7.5.每日推荐滑动scroll-view布局7.6.组件具名…...

一起学习Firtran: Fortran中的流程控制与操作符
流程控制语句 在计算机编程中,控制程序流程是算法设计中的一个核心概念,它使得程序能够根据特定条件执行不同的操作或重复执行某段代码。这显著增强了计算机算法相对于简单数学公式的功能和灵活性。 if语句 在单个 if 语句中只有当测试表达式࿰…...

Sonic:开源Go语言开发的高性能博客平台
Sonic:一个用Go语言开发的高性能博客平台 简介 Sonic,一个以其速度如声速般快速而命名的博客平台,是一个用Go语言开发的高性能博客系统。正如其名字所暗示的,Sonic旨在提供一个简单而强大的博客解决方案。这个项目受到了Halo项目…...

SpringBoot教程(十四) SpringBoot之集成Redis
SpringBoot教程(十四) | SpringBoot之集成Redis 一、Redis集成简介二、集成步骤 2.1 添加依赖2.2 添加配置2.3 项目中使用之简单使用 (举例讲解)2.4 项目中使用之工具类封装 (正式用这个)2.5 序列化 &…...

RSI和CCI指标组合:如何评估需求供应区?昂首资本实战指南
在市场分析中,分笔成交点数量提供了一个有价值的视角,帮助我们识别需求和供应区。通过这些数据,我们可以假设供需区域的参数与主要振荡器中的区域参数类似。以RSI和CCI为例,这些指标不仅能够反映市场的超买和超卖情况,…...

PTPVT 插值说明
文章目录 PTPVT 插值说明 PTPVT 插值说明PVT Hermite插值PVT 三次多项式插值PT 插值Sin轨迹测试结果PVT Hermite插值结果PVT 三次多项式插值结果PT 插值结果 用户轨迹测试结果PVT Hermite插值结果PT 插值结果 PTPVT 插值说明 PT模式: 位置-时间路径插值算法。 PVT模…...

Spring MVC和servlet
1.Spring MVC是Spring框架的一个扩展 2.Spring MVC工作流程 1、用户发送请求至前端控制器DispatcherServlet。 2、DispatcherServlet收到请求调用HandlerMapping处理器映射器。 3、处理器映射器找到具体的处理器(可以根据xml配置、注解进行查找),生成处理器对象及…...
java下载文件流,不生成中间文件。
java下载文件流,不生成中间文件。 代码设计:代码实现 代码设计: 从前端获取的数据经过后端加工后,生成文件流,并返回前端,(不生成中间文件,注意内存,记得关闭流…...
计算机专业考研 408 学科学习方法
计算机专业考研 408 学科涵盖数据结构、计算机组成原理、操作系统和计算机网络四门核心课程,内容多且难度大。但只要掌握科学的学习方法,便能化繁为简,稳步提升。以下为大家详细介绍 408 学科的学习方法。 一、基础夯实阶段:全面…...
MySQL 隔离级别:脏读、幻读及不可重复读的原理与示例
一、MySQL 隔离级别 MySQL 提供了四种隔离级别,用于控制事务之间的并发访问以及数据的可见性,不同隔离级别对脏读、幻读、不可重复读这几种并发数据问题有着不同的处理方式,具体如下: 隔离级别脏读不可重复读幻读性能特点及锁机制读未提交(READ UNCOMMITTED)允许出现允许…...

Redis相关知识总结(缓存雪崩,缓存穿透,缓存击穿,Redis实现分布式锁,如何保持数据库和缓存一致)
文章目录 1.什么是Redis?2.为什么要使用redis作为mysql的缓存?3.什么是缓存雪崩、缓存穿透、缓存击穿?3.1缓存雪崩3.1.1 大量缓存同时过期3.1.2 Redis宕机 3.2 缓存击穿3.3 缓存穿透3.4 总结 4. 数据库和缓存如何保持一致性5. Redis实现分布式…...
Auto-Coder使用GPT-4o完成:在用TabPFN这个模型构建一个预测未来3天涨跌的分类任务
通过akshare库,获取股票数据,并生成TabPFN这个模型 可以识别、处理的格式,写一个完整的预处理示例,并构建一个预测未来 3 天股价涨跌的分类任务 用TabPFN这个模型构建一个预测未来 3 天股价涨跌的分类任务,进行预测并输…...
相机Camera日志分析之三十一:高通Camx HAL十种流程基础分析关键字汇总(后续持续更新中)
【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:有对最普通的场景进行各个日志注释讲解,但相机场景太多,日志差异也巨大。后面将展示各种场景下的日志。 通过notepad++打开场景下的日志,通过下列分类关键字搜索,即可清晰的分析不同场景的相机运行流程差异…...

JUC笔记(上)-复习 涉及死锁 volatile synchronized CAS 原子操作
一、上下文切换 即使单核CPU也可以进行多线程执行代码,CPU会给每个线程分配CPU时间片来实现这个机制。时间片非常短,所以CPU会不断地切换线程执行,从而让我们感觉多个线程是同时执行的。时间片一般是十几毫秒(ms)。通过时间片分配算法执行。…...
Android Bitmap治理全解析:从加载优化到泄漏防控的全生命周期管理
引言 Bitmap(位图)是Android应用内存占用的“头号杀手”。一张1080P(1920x1080)的图片以ARGB_8888格式加载时,内存占用高达8MB(192010804字节)。据统计,超过60%的应用OOM崩溃与Bitm…...

九天毕昇深度学习平台 | 如何安装库?
pip install 库名 -i https://pypi.tuna.tsinghua.edu.cn/simple --user 举个例子: 报错 ModuleNotFoundError: No module named torch 那么我需要安装 torch pip install torch -i https://pypi.tuna.tsinghua.edu.cn/simple --user pip install 库名&#x…...
JavaScript基础-API 和 Web API
在学习JavaScript的过程中,理解API(应用程序接口)和Web API的概念及其应用是非常重要的。这些工具极大地扩展了JavaScript的功能,使得开发者能够创建出功能丰富、交互性强的Web应用程序。本文将深入探讨JavaScript中的API与Web AP…...
Webpack性能优化:构建速度与体积优化策略
一、构建速度优化 1、升级Webpack和Node.js 优化效果:Webpack 4比Webpack 3构建时间降低60%-98%。原因: V8引擎优化(for of替代forEach、Map/Set替代Object)。默认使用更快的md4哈希算法。AST直接从Loa…...
日常一水C
多态 言简意赅:就是一个对象面对同一事件时做出的不同反应 而之前的继承中说过,当子类和父类的函数名相同时,会隐藏父类的同名函数转而调用子类的同名函数,如果要调用父类的同名函数,那么就需要对父类进行引用&#…...