【Opencv】视频跟踪算法KCF

目录

  • KCF算法简介
  • opencv实现代码c++
  • opencv实现代码python

KCF算法简介

KCF(Kernelized Correlation Filter)是一种基于核相关滤波器的目标跟踪算法。它通过学习目标的外观特征和使用核相关滤波器进行目标定位。KCF属于传统算法的单目标跟踪器。下面是对KCF跟踪算法的介绍:

目标特征提取:KCF算法使用HOG(Histogram of Oriented Gradients)特征来表示目标的外观。HOG特征是一种局部纹理特征,通过计算图像中每个像素点周围的梯度方向直方图来描述目标的纹理信息。

核相关滤波器:KCF算法使用核相关滤波器来进行目标定位。核相关滤波器是一种利用滤波器和目标响应之间的相关性进行目标定位的方法。它通过学习目标的外观特征和目标响应之间的关系,来预测目标在下一帧中的位置。

学习过程:KCF算法通过最小化滤波器与目标响应之间的误差来学习滤波器的参数。它使用离散傅里叶变换来加速滤波器的计算,并通过循环更新滤波器的参数,以适应目标外观的变化。

目标跟踪:在目标跟踪阶段,KCF算法使用学习到的滤波器对目标的外观进行预测。它将当前帧的图像块与滤波器进行相关运算,得到目标响应图。然后,根据目标响应图找到最大响应的位置,即为目标的位置。
KCF算法具有以下优点:

速度快:KCF算法使用离散傅里叶变换来加速滤波器的计算,因此具有较快的运行速度。

鲁棒性强:KCF算法对目标的姿态、尺度变化具有较好的适应性。

准确性高:KCF算法通过学习目标的外观特征和目标响应之间的关系,能够准确地定位目标。
KCF算法在实时应用和大规模目标跟踪中得到广泛应用,例如视频监控、行人跟踪等。它在OpenCV中有相应的实现,可以方便地进行目标跟踪的开发和应用。

相关是衡量两个信号相似值的度量,如果两个信号越相似,那么其相关值就越高,而在tracking的应用里,就是需要设计一个滤波模板,使得当它作用在跟踪目标上时,得到的响应最大,最大响应值的位置就是目标的位置。

opencv实现代码c++

#include <opencv2/opencv.hpp>
int main()
{cv::VideoCapture capture(0); // 打开摄像头,如果是视频文件,可以指定文件路径if (!capture.isOpened()){std::cout << "无法打开摄像头或视频文件" << std::endl;return -1;}cv::Mat frame;capture.read(frame); // 读取第一帧图像
#v::selectROI函数会显示给定图像,并允许用户通过鼠标交互来选择一个矩形区域。用户可以拖动鼠标来选择矩形的位置和大小。选择完成后,cv::selectROI函数会返回一个cv::Rect2d类型的矩形对象,表示用户选择的感兴趣区域的位置和大小。在给定的代码中,bbox是用来存储用户选择的感兴趣区域的矩形对象。它可以用于后续的操作,比如目标跟踪算法中的初始化,将该矩形作为跟踪目标的初始位置。第二个参数false表示不使用自动调整矩形的大小,用户可以手动拖动鼠标来选择任意大小的矩形区域。cv::Rect2d bbox = cv::selectROI(frame, false); // 选择目标对象的初始位置cv::Ptr<cv::Tracker> tracker = cv::TrackerKCF::create(); // 创建KCF跟踪器tracker->init(frame, bbox); // 初始化跟踪器while (capture.read(frame)){bool ok = tracker->update(frame, bbox); // 更新跟踪器if (ok){cv::rectangle(frame, bbox, cv::Scalar(255, 0, 0), 2, 1); // 绘制跟踪框}else{cv::putText(frame, "跟踪失败", cv::Point(100, 80), cv::FONT_HERSHEY_SIMPLEX, 0.75, cv::Scalar(0, 0, 255), 2);}cv::imshow("跟踪", frame);if (cv::waitKey(1) == 27) // 按下ESC键退出{break;}}capture.release();cv::destroyAllWindows();return 0;
}

这个示例程序使用了cv::TrackerKCF算法进行目标跟踪。它打开摄像头或视频文件,读取第一帧图像,并通过cv::selectROI函数选择目标对象的初始位置。然后,创建一个cv::Tracker跟踪器,并使用init函数初始化跟踪器。在循环中,不断读取新的帧图像,通过update函数更新跟踪器,并在图像中绘制跟踪框。按下ESC键退出程序。
请注意,要编译和运行此代码,你需要安装OpenCV库,并将其链接到你的项目中。编译命令可以参考OpenCV的文档或使用CMake进行配置。

opencv实现代码python

TrackerKCF_create是属于OpenCV集成的跟踪器,使用前 必须安装 opencv-contrib-python 包才行。

 pip3 install opencv-contrib-python --index-url http://pypi.douban.com/simple/ requests --trusted-host pypi.douban.com
import cv2
# 读取视频帧
cap = cv2.VideoCapture('video.mp4')
ret, frame = cap.read()
# 选择感兴趣区域
bbox = cv2.selectROI(frame, False)
# 初始化跟踪器
tracker = cv2.TrackerKCF_create()
tracker.init(frame, bbox)
# 循环处理视频帧
while True:ret, frame = cap.read()if not ret:break# 更新跟踪器success, bbox = tracker.update(frame)if success:# 目标仍然被成功跟踪x, y, w, h = [int(v) for v in bbox]cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)else:# 目标丢失cv2.putText(frame, "Tracking failure detected", (100, 80), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (0, 0, 255), 2)# 显示当前帧cv2.imshow('Frame', frame)if cv2.waitKey(1) & 0xFF == ord('q'):break
# 释放资源
cap.release()
cv2.destroyAllWindows()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/12579.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java】Java多线程编程基础

文章目录 1. 进程与线程1.1 进程与线程的基本认识1.1.1 进程&#xff08;Process&#xff09;1.1.2 线程&#xff08;Thread&#xff09; 1.2 为什么会有线程1.2.1 以看视频为例 2. 多线程实现2.1 Thread类实现多线程2.2 Runnable接口实现多线程2.3 Callable接口实现多线程2.3 …

CTF线下赛AWD知识点【持续完善ing】

文章目录 CTF线下赛AWD知识点AWD规则前期准备SSH登录口令登录密钥登录 改密码SSH密码修改mysql密码修改 备份数据备份目录备份数据库 查找后门 自动提交flag防御思路基础查杀寻找最近20分钟修改过的文件寻找行数最短的文件关键字查杀查找命令执行函数 文件监控杀不死马0x01.杀进…

Grafana - TDEngine搭建数据监测报警系统

TDengine 与开源数据可视化系统 Grafana 快速集成搭建数据监测报警系统 一、介绍二、前置条件三、Grafana 安装及配置3.1 下载3.2 安装3.2.1 windows安装 - 图形界面3.2.2 linux安装 - 安装脚本 四、Grafana的TDEngine配置及使用4.1 登录4.2 安装 Grafana Plugin 并配置数据源4…

学习笔记|大模型优质Prompt开发与应用课(二)|第一节:大模型应用密码—Prompt的一千种打开方式

文章目录 第一节:大模型应用密码—Prompt的一千种打开方式01你可能听过一个小故事1910华盛顿纺织厂罢工事件 02 小问题:哪些场景会被提效类目一︰减少重复性工作的成本&#xff08;降本)例如∶做策划初稿、写JD、润色文案prompt生成结果prompt生成结果prompt生成结果promptprom…

NodeJs后端项目使用docker打包部署

docker安装看之前的文章 默认已经安装好docker并且配置没有问题 拉取项目 https://gitee.com/coder-msc/docker-node 本地跑一个看看 pnpm install pnpm start 本地访问 http://localhost:1301/getname?name%E5%93%88%E5%88%A9%E6%B3%A2%E7%89%B9项目整个上传服务器 查看…

简化Java单元测试数据

用EasyModeling简化Java单元测试 EasyModeling 是我在2021年圣诞假期期间开发的一个 Java 注解处理器&#xff0c;采用 Apache-2.0 开源协议。它可以帮助 Java 单元测试的编写者快速构造用于测试的数据模型实例&#xff0c;简化 Java 项目在单元测试中准备测试数据的工作&…

C# 委托

一&#xff1a;委托&#xff08;delegate&#xff09;&#xff1a;执行方法时&#xff0c;将方法当作参数传递到委托中进行执行&#xff1b; Action表示没有返回值的委托&#xff1b; Func表示有返回值的委托 《1》使用 需要先实例化一个委托 将方法当作参数传到委托中 注意&a…

工作纪实36-ES查询条件过长

问题 es中使用bool查询时查询内容长度太长导致报错&#xff1a; caused by: org.elasticsearch.common.io.stream.NotSerializableExceptionWrapper: too_many_clauses: maxClauseCount is set to 1024 错误信息提示&#xff1a;最大子句数量限制为1024 解决方案 1.设置es配…

老胡的周刊(第101期)

老胡的信息周刊[1]&#xff0c;记录这周我看到的有价值的信息&#xff0c;主要针对计算机领域&#xff0c;内容主题极大程度被我个人喜好主导。这个项目核心目的在于记录让自己有印象的信息做一个留存以及共享。 &#x1f3af; 项目 ollama[2] 你可以下载 Ollama 在本地运行 Ll…

链表基础知识

一、什么是链表 链表是一种物理存储结构上非连续&#xff0c;非顺序的存储结构&#xff0c;数据元素的逻辑顺序是通过链表中的指针链接次序实现的。 链表的结构是多式多样的&#xff0c;当时通常用的也就是两种&#xff1a; &#xff08;1&#xff09;第一种是无头非循环单向…

live-server本地起node服务解决跨域问题

一、初始化node,构建package.json NPM 全局安装live-server npm install -g live-server在当前项目文件夹下cmd运行&#xff1a; npm init -y此时会在根目录下生成一个package.json文件。 二.生成代理脚本 在根文件夹新建一个build.js文件&#xff08;名字可以自定义) var …

ubuntu 16.04 安装mujoco mujoco_py gym stable_baselines版本问题

ubuntu 16.04系统 Python 3.7.16 mujoco200 (py37mujoco) abc123:~/github/spinningup$ pip list Package Version Editable project location ----------------------------- --------- --------------------------- absl-py …

Linux中的pause函数

2023年7月29日&#xff0c;周六上午 函数原型 在Linux中&#xff0c;pause()函数用于使当前进程暂停执行&#xff0c;直到接收到一个信号。 #include <unistd.h>int pause(void);pause()函数不接受任何参数。 通常&#xff0c;pause()函数用于编写简单的信号处理程序&…

并发编程可能出现的核心问题

2.1非可见性 如果主内存里有个静态变量flagfalse&#xff0c;然后线程A和B在工作内存都需要操作flag&#xff0c;线程A是while(!false){}&#xff0c;而线程B将flag改为true&#xff0c;但是由于线程A和线程B之间工作内存互相不可见&#xff0c;线程A就会陷入死循环。 2.2指令…

idea如何解决导入的项目不是Maven工程(文件下面没有蓝色的方格)二

简介&#xff1a; Maven项目导入&#xff0c;idea不识别项目 解决方法&#xff1a; 选中pom.xml -- 右键 -- Add as Maven Project

Axios-post请求下载文件

场景背景 1.一般来说&#xff0c;都是使用get请求后台接口&#xff0c;如此后台返回文件流于浏览器&#xff0c;则可直接下载。 2.那么除一般情况&#xff0c;就有特殊情况&#xff0c;比如你的请求接口参数特别长&#xff0c;此时便不可使用get请求&#xff0c;get请求的参数…

二分查找-Java

二分查找-Java 概念 二分查找也称折半查找&#xff08;Binary Search&#xff09;&#xff0c;它是一种效率较高的查找方法。但是&#xff0c;折半查找要求线性表必须采用顺序存储结构&#xff0c;而且表中元素按关键字有序排列。 代码 查找目标数据是否存在数组中&#xff…

devops(后端)

1.前言 该devpos架构为gitlabjenkinsharbork8s&#xff0c;项目是java项目&#xff0c;流程为从gitlab拉取项目代码到jenkins&#xff0c;jenkins通过maven将项目代码打成jar包&#xff0c;通过dockerfile构建jdk环境的镜像并把jar包放到镜像中启动&#xff0c;构建好的镜像通…

【Quartus FPGA】EMIF DDR3 读写带宽测试

在通信原理中&#xff0c;通信系统的有效性用带宽来衡量&#xff0c;带宽定义为每秒传输的比特数&#xff0c;单位 b/s&#xff0c;或 bps。在 DDR3 接口的产品设计中&#xff0c;DDR3 读/写带宽是设计者必须考虑的指标。本文主要介绍了 Quartus FPGA 平台 EMIF 参数配置&#…

SK5代理与socks5代理

第一部分&#xff1a;SK5代理与socks5代理的原理与功能 SK5代理 SK5代理是一种加密代理技术&#xff0c;其工作原理主要包括以下几个关键步骤&#xff1a; 代理服务器接收客户端请求&#xff1b;客户端与代理服务器之间建立加密连接&#xff1b;代理服务器将客户端的请求转发…