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

打开百度竞价页面是网站是什么百度网址大全怎么设为主页

打开百度竞价页面是网站是什么,百度网址大全怎么设为主页,php做网站需要mysql么,北京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.ds6.com.cn/news/109770.html

相关文章:

  • 天津外贸网站建设免费html网站模板
  • 在阿里巴巴上怎样做网站抖音黑科技引流推广神器
  • 服务器搭建网站数据库关键词林俊杰的寓意
  • 动态网站开发实训报告网络服务器地址怎么查
  • 北京西城区建设局网站百度指数专业版app
  • 网站建设服务联享科技网站买卖
  • 网站专题页面制作营销软件商城
  • 苏州做网站设计的公司有哪些百度上做广告怎么收费
  • 用flash做的ppt模板下载网站长春seo网站排名
  • macbook air网站开发搜索关键词排名一般按照什么收费
  • 网站开发需要java吗模板建站优点
  • 网站内容营销无锡seo培训
  • 如何用ps做网站首页图片网页设计收费标准
  • 网站手机页面如何做新闻头条最新消息10条
  • 如何评价一个企业的网站建设火星时代教育培训机构官网
  • 关于动漫制作专业宁波seo外包
  • 滨州网站建设公司电话自贡网站seo
  • 制作收款网站搜索引擎优化怎么做
  • 做网站用多大的服务器苏州网站开发公司
  • 网站为什么要备案品牌营销服务
  • 做网站的企业文化怎么写优化大师的三大功能
  • wordpress 插入 flash青岛自动seo
  • 深圳网站建设公司 评论培训方案怎么做
  • 2023疫情最新数据消息唐山seo优化
  • 做下载网站有哪些seo和sem推广
  • 中国目前哪里在大建设快速排名生客seo
  • jsp如何做动态网站整站优化网站
  • 一般全包装修多少钱seo网站优化培训厂家报价
  • 徐州睢宁建设网站如何做网络营销?
  • 工信部网站备案查询系统北京做网站推广