news 2026/6/10 12:34:48

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/6/10 11:57:26

彻底解决haxm is not installed 的五大关键步骤(实战经验)

彻底解决 haxm is not installed:从 BIOS 到 AVD 的实战全解析 你有没有在启动 Android 模拟器时,突然弹出那句熟悉的红字警告——“ HAXM is not installed ”? 那一刻,模拟器要么根本打不开,要么像老式录像机一样…

作者头像 李华
网站建设 2026/6/9 21:33:36

快速理解频率响应验证原理:扫频与阶跃激励对比

频率响应怎么测?扫频和阶跃激励到底该用哪个?你有没有遇到过这种情况:调试一个电源环路,Bode图怎么看都不对劲;或者测试扬声器时发现高频失真严重,却说不清是系统本身的问题还是测量方法出了偏差&#xff1…

作者头像 李华
网站建设 2026/6/10 11:56:51

吐血整理,常见性能测试缺陷+基准测试分析,一篇通透...

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 1、常见性能测试缺…

作者头像 李华
网站建设 2026/6/10 11:57:58

Multisim14.3从零实现:创建简单直流电路仿真

用 Multisim14.3 搭一个最简单的直流电路:从零开始的仿真实战你有没有过这样的经历?想验证一个电阻分压电路,但手头没电源、没万用表,连面包板都找不到。或者刚学电路分析,对欧姆定律和基尔霍夫电压定律(KV…

作者头像 李华
网站建设 2026/6/10 11:52:58

AI Agent 架构核心:如何构建多意图路由与动态查询分发引擎

在构建智能体或 RAG 系统时,一个关键瓶颈始终存在:用户用自然语言表达的需求,与系统底层的执行逻辑之间,往往隔着一道难以跨越的沟壑。 当用户脱口而出:“我电脑连不上网了。” 若系统仅做字面匹配,检索“…

作者头像 李华