当前位置: 首页 > news >正文

OpenCV视觉分析之目标跟踪(5)目标跟踪类TrackerMIL的使用

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

MIL 算法以在线方式训练分类器,以将目标从背景中分离出来。多重实例学习(Multiple Instance Learning)通过在线学习避免了跟踪中的漂移问题,从而实现了更稳健的跟踪效果。该实现基于文献 [14]。原始代码可以在以下网址找到:http://vision.ucsd.edu/~bbabenko/project_miltrack.shtml。

cv::TrackerMIL 是 OpenCV 中用于目标跟踪的一个类,它实现了 MIL(Multiple Instance Learning)算法。MIL 跟踪器是一种基于在线学习的目标跟踪方法,可以在视频序列中动态地调整其模型以适应目标的变化。

MIL 跟踪器的特点

  • 在线学习:能够在跟踪过程中不断调整和优化模型。
  • 鲁棒性强:对遮挡、光照变化等有一定的鲁棒性。
  • 适应性强:能够适应目标外观的变化。

如何使用 cv::TrackerMIL

  • 创建 cv::TrackerMIL 对象:

    • 使用 cv::TrackerMIL::create() 创建一个 cv::Tracker 指针对象。
  • 加载模型(可选):

    • 如果有预训练模型文件,可以使用 loadModel 方法加载模型。
  • 初始化跟踪器:

    • 使用 init 方法初始化跟踪器,并提供初始帧和目标区域。
  • 更新跟踪器:

    • 使用 update 方法在后续帧中更新跟踪结果。

    代码示例


#include <iostream>
#include <opencv2/opencv.hpp>int main()
{// 读取视频文件cv::VideoCapture cap( 0 );if ( !cap.isOpened() ){std::cout << "Error opening video file" << std::endl;return -1;}// 读取第一帧cv::Mat frame;cap >> frame;if ( frame.empty() ){std::cout << "Error reading first frame" << std::endl;return -1;}// 选择目标区域cv::Rect2d bbox = cv::selectROI( "Select ROI", frame, false, false );if ( bbox.width <= 0 || bbox.height <= 0 ){std::cout << "No ROI selected" << std::endl;return -1;}// 创建 TrackerMIL 对象cv::Ptr< cv::Tracker > tracker = cv::TrackerMIL::create();// 加载模型(如果有的话)// std::string modelPath = "path/to/mil_model.dat";// if (!tracker->loadModel(modelPath)) {//     std::cout << "Failed to load model: " << modelPath << std::endl;//     return -1;// }// 初始化跟踪器tracker->init( frame, bbox );// 跟踪目标while ( true ){cap >> frame;if ( frame.empty() ){break;}// 更新跟踪结果cv::Rect newBox;bool ok = tracker->update( frame, newBox );// 绘制边界框if ( ok ){cv::rectangle( frame, newBox, cv::Scalar( 0, 255, 0 ), 2, 1 );}else{cv::rectangle( frame, newBox, cv::Scalar( 0, 0, 255 ), 2, 1 );}// 显示结果cv::imshow( "Tracking", frame );if ( cv::waitKey( 1 ) >= 0 ){break;}}return 0;
}

运行结果

跟踪一个笔帽
在这里插入图片描述

http://www.lryc.cn/news/475615.html

相关文章:

  • 二级列表联动
  • 「C/C++」C++ 标准库 之 #include<sstream> 字符串流库
  • 深入理解跨域资源共享(CORS)安全问题原理及解决思路
  • 【汽车租聘管理与推荐】Python+Django网页界面+推荐算法+管理系统网站
  • Linux常见指令大全(必要+知识点)
  • iOS用rime且导入自制输入方案
  • Linux 进程终止 进程等待
  • VBA 64位API声明语句第003讲
  • 【问题记录】解决VMware虚拟机中鼠标侧键无法使用的问题
  • Naive UI 级联选择器 Cascader的:render-lable怎么使用(Vue3 + TS)(鼠标悬停该条数据的时候展示全部内容)
  • vue元素里面的 js对象中,:style后面里属性名不支持这种带-的写法(background-color)
  • Git 常用命令与开发流程总结
  • 链表中插入新的节点
  • AUTOSAR从入门到精通-BswM模块(二)
  • Spring DispatcherServlet详解
  • JS | 软件制作的流程是什么?
  • 简单工厂模式
  • 【django】Django REST Framework 序列化与反序列化详解
  • 【Golang】Golang的Map的线程安全问题
  • 指向指针的指针+ 值传递的理解
  • CSS常用定位
  • 【Linux】从零开始使用多路转接IO --- select
  • ArcGIS Pro SDK (二十一)渲染
  • FPGA在物联网边缘计算中的应用!!!
  • 【解决】Linux环境中mysqlclient安装失败问题
  • ✨ Midjourney中文版:创意启航,绘梦无界 ✨
  • 软件(1)
  • linux perf 环境部署和基本测试(基于Ubuntu20.04)
  • 【网络面试篇】HTTP(1)(笔记)——状态码、字段、GET、POST、缓存
  • HTML 基础标签——分组标签 <div>、<span> 和基础语义容器