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

OpenCV中的光流估计方法详解

文章目录

    • 一、引言
    • 二、核心算法原理
      • 1. 光流法基本概念
      • 2. 算法实现步骤
    • 三、代码实现详解
      • 1. 初始化设置
      • 2. 特征点检测
      • 3. 光流计算与轨迹绘制
    • 四、实际应用效果
    • 五、优化方向
    • 六、结语

一、引言

在计算机视觉领域,运动目标跟踪是一个重要的研究方向,广泛应用于视频监控、自动驾驶、人机交互等场景。本文将介绍如何使用OpenCV中的Lucas-Kanade光流法实现简单的运动目标轨迹跟踪,并详细解析代码实现。

二、核心算法原理

1. 光流法基本概念

光流(Optical Flow)是图像中物体运动造成的视觉"流动",描述了像素点在连续帧之间的运动模式。Lucas-Kanade算法是一种经典的稀疏光流算法,它基于以下三个假设:

  • 亮度恒定(同一特征点的亮度不随时间变化)
  • 时间持续性(运动随时间缓慢变化)
  • 空间一致性(邻近点有相似运动)

2. 算法实现步骤

  1. 特征点检测:使用Shi-Tomasi角点检测
  2. 光流计算:金字塔Lucas-Kanade方法
  3. 轨迹绘制:连接连续帧中的特征点

三、代码实现详解

1. 初始化设置

import numpy as np
import cv2# 视频读取和参数初始化
cap = cv2.VideoCapture('test.avi')
color = np.random.randint(0,255,(100,3))  # 随机颜色用于轨迹绘制

2. 特征点检测

# 读取第一帧并转换为灰度图
ret, old_frame = cap.read()
old_gray = cv2.cvtColor(old_frame, cv2.COLOR_BGR2GRAY)# Shi-Tomasi角点检测参数
feature_params = dict(maxCorners=100, qualityLevel=0.3, minDistance=7)
p0 = cv2.goodFeaturesToTrack(old_gray, mask=None, **feature_params)
  • 使用角点检测方法找到特征点
goodFeaturesToTrack(image,maxCorners,qualityLevel,minDistance,corners=None,mask=None,blockSize=None)
  • image:输入单通道图像。用灰度图
  • maxCorners:设定最大的角点个数,是最有可能的角点数,如果这个参数不大于0,那么表示没有角点数的限制。
  • qualityLevel:图像角点的最小可接受参数,质量测量值乘以这个参数就是最小特征值,小于这个数的会被抛弃。
  • minDistance:角点之间最小的欧氏距离
  • mask:检测区域,如果图像不是空的,它指定检测角的区域。
  • 返回所有角点坐标位置:corners

3. 光流计算与轨迹绘制

# LK光流参数
lk_params = dict(winSize=(15,15), maxLevel=2)while True:ret, frame = cap.read()if not ret:breakframe_gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)# 计算光流p1, st, err = cv2.calcOpticalFlowPyrLK(old_gray, frame_gray, p0, None, **lk_params)# 筛选成功跟踪的点good_new = p1[st==1]good_old = p0[st==1]# 绘制轨迹for i, (new, old) in enumerate(zip(good_new, good_old)):a, b = new.ravel().astype(int)c, d = old.ravel().astype(int)mask = cv2.line(mask, (a,b), (c,d), color[i].tolist(), 2)img = cv2.add(frame, mask)cv2.imshow('frame', img)# 更新前一帧数据old_gray = frame_gray.copy()p0 = good_new.reshape(-1,1,2)

计算光流,获取新的特征点位置和状态

calcOpticalFlowPyrLK(prevImg,nextImg,prevPts,nextPts,status=None,err=None,winSize=None,maxLevel=None,criteria=None,flags=None,minEigThreshold=None)
  • prevImg:前一帧图像
  • nextImg:当前帧图像
  • prevPts:前一帧图像中特征点坐标位置
  • nextPts:当前帧图像中特征点坐标,可以为None
  • winSize:搜索窗口的大小
  • maxLevel:金字塔层数
  • criteria:停止迭代的准则
  • 返回值
  • nextPts:在当前帧中估计出的特征点坐标
  • status:一个与prevPts一样大小的状态向量,用于表示特征点是否被成功跟踪到。
  • err:一个与prevPts一样大小的误差向量,用于表示估计误差

四、实际应用效果

运行程序后,可以看到视频中检测到的特征点及其运动轨迹。不同颜色的线条代表不同特征点的运动路径,直观展示了物体的运动情况。

显示效果如下:左边是一段有很多人在走动的视频,右边就是根据人物运动的轨迹画出的轨迹图。
在这里插入图片描述

五、优化方向

  1. 特征点选择优化:可以尝试其他特征检测算法如SIFT、SURF等
  2. 运动模型改进:引入卡尔曼滤波等预测算法提高跟踪稳定性
  3. 遮挡处理:添加特征点重新检测机制应对遮挡情况
  4. 性能优化:使用多线程处理提高实时性

六、结语

本文实现了一个基于OpenCV的简单运动目标跟踪系统,展示了光流法的基本应用。虽然实现相对简单,但包含了目标跟踪的核心思想。读者可以在此基础上进行扩展,开发更复杂的跟踪系统。

我们定能不负所托 不负所望!!!🚀🚀🚀

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

相关文章:

  • OpenCL C++ 常见属性与函数
  • Android核心系统服务:AMS、WMS、PMS 与 system_server 进程解析
  • 18.自动化生成知识图谱的多维度质量评估方法论
  • 【行为型之命令模式】游戏开发实战——Unity可撤销系统与高级输入管理的架构秘钥
  • 图论模板(部分)
  • LeetCode 热题 100_寻找重复数(100_287_中等_C++)(技巧)(暴力解法;哈希集合;二分查找)
  • NBA足球赛事直播源码体育直播M33模板赛事源码
  • 【QT 项目部署指南】使用 Inno Setup 打包 QT 程序为安装包(超详细图文教程)
  • 电子电器架构 --- 整车造车阶段四个重要节点
  • 黑马点评-用户登录
  • ecmascript 第6版特性 ECMA-262 ES6
  • 十二、Hive 函数
  • No More Adam: 新型优化器SGD_SaI
  • 数据结构【AVL树】
  • C#将1GB大图裁剪为8张图片
  • 数据库——SQL约束窗口函数介绍
  • Linux系统启动相关:vmlinux、vmlinuz、zImage,和initrd 、 initramfs,以及SystemV 和 SystemD
  • JSP链接MySQL8.0(Eclipse+Tomcat9.0+MySQL8.0)
  • Python爬虫-爬取百度指数之人群兴趣分布数据,进行数据分析
  • SEO长尾词与关键词优化实战
  • 机器学习-人与机器生数据的区分模型测试-数据处理1
  • HelloWorld
  • 令牌桶和漏桶算法使用场景解析
  • 轻量、优雅、高扩展的事件驱动框架——Hibiscus-Signal
  • SEO 优化实战:ZKmall模板商城的 B2C商城的 URL 重构与结构化数据
  • 2020CCPC河南省赛题解
  • 数字万用表与指针万用表使用方法及注意事项
  • 虚拟主播肖像权保护,数字时代的法律博弈
  • 【读代码】端到端多模态语言模型Ultravox深度解析
  • RabbitMQ工作流程及使用方法