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

手机网站备案密码找回的方法博客推广工具

手机网站备案密码找回的方法,博客推广工具,网站建设贝尔利,石家庄seo公司文章目录 引言核心功能代码解析1. 初始化设置2. 背景建模3. 视频处理主循环4. 轮廓检测与目标标记 关键技术详解1. 背景减除(Background Subtraction)2. 形态学处理3. 轮廓分析 实际应用效果总结 引言 运动目标检测是计算机视觉中的重要应用,广泛应用于安防监控、自…

文章目录

    • 引言
    • 核心功能
    • 代码解析
      • 1. 初始化设置
      • 2. 背景建模
      • 3. 视频处理主循环
      • 4. 轮廓检测与目标标记
    • 关键技术详解
      • 1. 背景减除(Background Subtraction)
      • 2. 形态学处理
      • 3. 轮廓分析
    • 实际应用效果
    • 总结

引言

运动目标检测是计算机视觉中的重要应用,广泛应用于安防监控、自动驾驶、人机交互等领域。本文将介绍如何使用OpenCV实现一个简单的视频运动目标检测系统,包括背景建模、形态学处理和轮廓检测等关键技术。

核心功能

这段代码实现了以下功能:

  1. 视频读取与显示
  2. 背景建模与前景提取
  3. 形态学去噪处理
  4. 运动目标轮廓检测与标记

代码解析

1. 初始化设置

import cv2# 读取视频文件
cap = cv2.VideoCapture('test.avi')# 创建形态学操作核
kernel = cv2.getStructuringElement(cv2.MORPH_CROSS, (3,3))
  • VideoCapture用于读取视频文件
  • getStructuringElement创建形态学操作核,这里使用3×3的十字形核

2. 背景建模

# 创建混合高斯背景模型
fgbg = cv2.createBackgroundSubtractorMOG2()

createBackgroundSubtractorMOG2()实现了基于高斯混合模型(GMM)的背景减除算法,能够有效分离前景和背景。

3. 视频处理主循环

while True:ret, frame = cap.read()if not ret:break# 显示原始帧cv2.imshow('frame', frame)# 应用背景减除fgmask = fgbg.apply(frame)cv2.imshow('fgmask', fgmask)# 形态学开运算去噪fgmask_new = cv2.morphologyEx(fgmask, cv2.MORPH_OPEN, kernel)cv2.imshow('fgmask1', fgmask_new)

这段代码是视频运动检测系统的核心处理循环,主要完成视频帧的读取、背景减除和噪声处理等功能。下面我将详细解释每一部分:

代码结构解析

while True:ret, frame = cap.read()if not ret:break

(1) 视频帧读取

  • cap.read() 从视频捕获对象读取下一帧
  • ret 是布尔值,表示是否成功读取帧
  • frame 是读取到的视频帧图像
  • 如果读取失败(not ret),退出循环

(2) 显示原始帧

    # 显示原始帧cv2.imshow('frame', frame)
  • cv2.imshow() 显示当前帧
  • 窗口标题为’frame’
  • 这是未经处理的原始视频画面

(3) 背景减除处理

    # 应用背景减除fgmask = fgbg.apply(frame)cv2.imshow('fgmask', fgmask)
  • fgbg.apply(frame) 应用之前创建的背景减除器
  • 结果fgmask是二值图像(前景为白色,背景为黑色)
  • 显示背景减除后的前景掩码

(4) 形态学开运算去噪

    # 形态学开运算去噪fgmask_new = cv2.morphologyEx(fgmask, cv2.MORPH_OPEN, kernel)cv2.imshow('fgmask1', fgmask_new)
  • cv2.morphologyEx() 执行形态学操作
  • cv2.MORPH_OPEN 表示开运算(先腐蚀后膨胀)
  • kernel 是之前定义的3×3十字形结构元素
  • 开运算可以去除小的噪声点,平滑物体边界
  • 显示去噪后的前景掩码

4. 轮廓检测与目标标记

    # 寻找轮廓contours, h = cv2.findContours(fgmask_new, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)for c in contours:# 计算轮廓周长perimeter = cv2.arcLength(c, True)# 过滤小轮廓if perimeter > 100:# 获取边界矩形x, y, w, h = cv2.boundingRect(c)# 绘制矩形框fgmask_new_rect = cv2.rectangle(frame, (x,y), (x+w, y+h), (0,255,0), 2)cv2.imshow('fgmask_new_rect', fgmask_new_rect)# 退出条件k = cv2.waitKey(50)if k == 27:break

这段代码完成了运动目标检测的最后关键步骤:轮廓查找、目标筛选和标记。下面我将详细解释每一部分:

(1)轮廓查找

contours, h = cv2.findContours(fgmask_new, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
  • cv2.findContours() 在二值图像中查找轮廓
  • 参数说明:
    • fgmask_new:经过去噪处理的前景掩码图像
    • cv2.RETR_EXTERNAL:只检测最外层轮廓
    • cv2.CHAIN_APPROX_SIMPLE:压缩水平、垂直和对角线段,只保留端点
  • 返回值:
    • contours:找到的轮廓列表,每个轮廓是点的数组
    • h:轮廓的层次信息(这里未使用)

(2)轮廓处理循环

for c in contours:# 计算轮廓周长perimeter = cv2.arcLength(c, True)
  • 遍历所有找到的轮廓
  • cv2.arcLength(c, True) 计算轮廓周长
    • True 表示轮廓是闭合的

(3)轮廓筛选

    # 过滤小轮廓if perimeter > 100:
  • 通过周长阈值(100)过滤小轮廓
  • 有效去除噪声产生的小轮廓,只保留显著目标

(4)目标标记

        # 获取边界矩形x, y, w, h = cv2.boundingRect(c)# 绘制矩形框fgmask_new_rect = cv2.rectangle(frame, (x,y), (x+w, y+h), (0,255,0), 2)
  • cv2.boundingRect(c) 获取轮廓的最小外接矩形
    • 返回矩形左上角坐标(x,y)和宽高(w,h)
  • cv2.rectangle() 在原图上绘制绿色矩形框
    • (0,255,0):绿色(BGR格式)
    • 2:线宽

(5)结果显示与退出控制

cv2.imshow('fgmask_new_rect', fgmask_new_rect)# 退出条件
k = cv2.waitKey(50)
if k == 27:break
  • 显示带检测框的结果图像
  • waitKey(50) 等待50ms,并检查按键
    • 27是ESC键的ASCII码,按下ESC退出循环

关键技术详解

1. 背景减除(Background Subtraction)

混合高斯模型(MOG2)能够:

  • 自适应场景变化
  • 处理光照变化
  • 区分阴影和实际运动物体

2. 形态学处理

开运算(MORPH_OPEN)过程:

  1. 先腐蚀:消除小噪声点
  2. 后膨胀:恢复物体原有大小

3. 轮廓分析

  • findContours查找前景中的连通区域
  • arcLength计算轮廓周长用于过滤小噪声
  • boundingRect获取物体最小外接矩形

实际应用效果

运行程序后会显示四个窗口:

  1. 原始视频帧
  2. 初步前景掩码(含噪声)
  3. 去噪后的前景掩码
  4. 最终检测结果(带矩形框标记)
  5. 效果显示图如下:

在这里插入图片描述

总结

本文介绍了基于OpenCV的视频运动目标检测实现方法。通过背景建模、形态学处理和轮廓分析等技术,我们能够有效地检测和标记视频中的运动物体。这种方法计算效率高,适合实时应用场景。

完整代码已在上文给出,读者可以自行尝试并调整参数观察不同效果。OpenCV提供了丰富的计算机视觉功能,值得深入学习和探索。

http://www.dtcms.com/wzjs/253326.html

相关文章:

  • 做网站的人会不会拿走我的网站在线优化工具
  • 小制作四年级长沙网站推广seo
  • 廊坊建设网站查询关键词排名工具
  • 做网站php和asp哪个好万网域名查询
  • 茂名网站建设咨询百度怎么进入官方网站
  • 长春制作手机网站百度推广优化
  • 广州企业网站建设推荐遵义网站seo
  • 如何增加百度收录影响seo排名的因素
  • ppt模板免费下载哪个网站好b站引流推广网站
  • 昌平区住房和建设委员会官方网站同仁seo排名优化培训
  • 网站建设应考虑哪些方面的问题快速seo关键词优化技巧
  • 做ppt时网站怎么设计营销咨询师
  • 网络营销推广一本书深圳网站关键词优化推广
  • 京伦网站建设广州网络推广策划公司
  • 重庆网站制作一般需要多少钱信息流广告的特点
  • 怎样申请网站空间百度指数关键词搜索趋势
  • 百度搜索网址云南seo简单整站优化
  • 视频网站制作费用seo建站的步骤
  • 做二手的网站有哪些营销策略有哪些4种
  • 推广怎么做?seo关键字优化价格
  • 中国城乡建设部网站口碑营销的形式
  • 邯郸做商城网站的公司seo能干一辈子吗
  • 专做品质游的网站seo综合查询工具
  • 下载类网站 建设方案青岛招聘seo
  • 中山网站建设是什么意思最佳bt磁力狗
  • 手机网站跟PC端网站有啥区别网络营销成功案例ppt免费
  • 怎么分析网站建设的优缺点装修公司网络推广方案
  • 直邮网站的推广活动怎么做对网站和网页的认识
  • 济南网站建设公司哪个好有没有免费的写文案的软件
  • 网站cdn 自己做湖北短视频seo营销