news 2026/3/10 7:28:21

OpenCV视频实时跟踪目标,多种算法,python版

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
OpenCV视频实时跟踪目标,多种算法,python版
  • 测试结果

同等条件下对比:

'csrt', # 261.0ms, lost 0 'kcf', # 51.0ms, lost 157 'boosting', # 23.7ms, lost 0 'mil', # 273.1ms, lost 0 'tld', # 100.7ms, lost 0 'medianflow', # 6.6ms, lost 37 'mosse' # 10.7ms, lost 158
  • 具体代码
import cv2 import time def init_tracker(frame): # 创建跟踪器 if tracker_index == 0: tracker = cv2.legacy.TrackerCSRT_create() elif tracker_index == 1: tracker = cv2.legacy.TrackerKCF_create() elif tracker_index == 2: tracker = cv2.legacy.TrackerBoosting_create() elif tracker_index == 3: tracker = cv2.legacy.TrackerMIL_create() elif tracker_index == 4: tracker = cv2.legacy.TrackerTLD_create() elif tracker_index == 5: tracker = cv2.legacy.TrackerMedianFlow_create() elif tracker_index == 6: tracker = cv2.legacy.TrackerMOSSE_create() height, width = frame.shape[:2] bbox = [int(width*(1-check_ratio)/2), int(height*(1-check_ratio)/2), width*check_ratio, height*check_ratio] # 初始化跟踪器 ok = tracker.init(frame, bbox) return tracker, bbox def track_action(tracker, frame): current_time = time.time() result = frame.copy() # 更新跟踪器,获取新边界框 ok, bbox = tracker.update(result) lost = 0 if ok: # 跟踪成功:绘制边界框 (x, y, w, h) = [int(v) for v in bbox] cv2.rectangle(result, (x, y), (x+w, y+h), (0, 255, 0), 2) else: # 跟踪失败 lost = 1 cv2.putText(result, "Tracking failure", (50, 80), cv2.FONT_HERSHEY_SIMPLEX, 2, (0,0,255), 2) cost_time = (time.time()-current_time) return result, cost_time, lost def track_video(input_video, output_video): # 读取视频 input = cv2.VideoCapture(input_video) ok, frame = input.read() if not ok: print("Cannot read video") return fps = int(input.get(cv2.CAP_PROP_FPS)) width = int(input.get(cv2.CAP_PROP_FRAME_WIDTH)) height = int(input.get(cv2.CAP_PROP_FRAME_HEIGHT)) tracker, bbox = init_tracker(frame) fourcc = cv2.VideoWriter_fourcc(*'mp4v') output = cv2.VideoWriter(output_video, fourcc, fps, (width*2, height)) frame_counter = 0 track_lost = 0 work_cost = 0 while True: ok, frame = input.read() if not ok: break frame_counter += 1 track_frame, cost, lost = track_action(tracker, frame) work_cost += cost track_lost += lost if (merge_video): track = cv2.hconcat([frame, track_frame]) output.write(track) if (frame_counter % 100 == 0): print(frame_counter) print('tracker(%s): cost per frame(ms)=%.2f' % (tracker_names[tracker_index], (work_cost/frame_counter*1000))) print('tracker(%s): track(lost/total)=%d/%d' % (tracker_names[tracker_index], track_lost, frame_counter)) output.release() input.release() # 跟踪器类型, total 527 frames # tracker name, cost per frame(ms), lost tracker_names = [ 'csrt', # 261.0ms, lost 0 'kcf', # 51.0ms, lost 157 'boosting', # 23.7ms, lost 0 'mil', # 273.1ms, lost 0 'tld', # 100.7ms, lost 0 'medianflow', # 6.6ms, lost 37 'mosse' # 10.7ms, lost 158 ] merge_video = True check_ratio = 1/10 tracker_index = 0 input_video = 'test.mp4' output_video = 'track.mp4' for index in range(7): tracker_index = index output_video = ("track%d.mp4" % tracker_index) track_video(input_video, output_video)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/9 19:58:08

CANFD与CAN的区别:收发器设计对比图解说明

CAN FD 与传统 CAN 的本质差异:从协议到收发器的深度剖析你有没有遇到过这样的情况——在调试一个车载ECU时,明明代码逻辑没问题,但通信就是不稳定?尤其是当你试图通过CAN总线进行OTA升级或接收雷达数据流时,传输慢得像…

作者头像 李华
网站建设 2026/3/8 10:41:06

Keil添加文件高效管理技巧:提升项目组织效率

Keil文件管理实战:如何科学组织你的嵌入式项目工程在嵌入式开发的世界里,一个整洁、高效的项目结构往往决定了你是在“写代码”还是在“修工程”。尤其当你使用Keil MDK(uVision)进行ARM Cortex-M系列微控制器开发时,随…

作者头像 李华
网站建设 2026/3/7 13:59:14

轮胎材质对循迹性能影响:系统学习笔记

轮胎材质如何“悄悄”决定你的循迹小车跑得多稳?你有没有遇到过这种情况:PID参数调了整整三天,传感器布局反复优化,代码逻辑也检查无数遍,结果小车一进弯道还是“原地转圈”或者“蛇形走位”?别急着怪算法—…

作者头像 李华
网站建设 2026/3/9 22:14:11

架构之最终一致性

架构之最终一致性 概述 在分布式系统中,AP、CP是不能同时满足的,这是铁律。根据CAP定理,当网络分区发生时,系统必须在一致性(Consistency)和可用性(Availability)之间做出选择。为了…

作者头像 李华
网站建设 2026/2/28 12:29:57

Batocera游戏整合包图解说明:适合全家人的怀旧游戏中心

用一个U盘,把老电视变成全家人的游戏厅:Batocera整合包实战指南 你有没有试过在某个周末的晚上,翻出尘封多年的红白机卡带,想和孩子一起玩一局《超级马里奥》?结果发现主机接口氧化、画面闪烁,折腾半小时也…

作者头像 李华
网站建设 2026/3/3 11:09:16

Excel/CSV转GIS:一键WKT转gdf、Shapefile等图层

Python数据处理:如何将Excel/CSV中的WKT文本转换为Shapefile/GeoJSON——tablegis库df_to_gdf详解 前言 在地理数据处理中,我们经常遇到一种尴尬的情况: 从数据库(PostGIS, MySQL, ClickHouse)导出的数据,或…

作者头像 李华