【python】三帧差法实现运动目标检测

++++三帧差法++++ 是一种常用的运动目标检测方法,它通过比较连续三帧图像之间的差异来检测运动物体。这种方法尤其适用于背景变化较小的场景。

目录

[1 方案](#1 方案)

[2 实践](#2 实践)

[① 代码](#① 代码)

[② 效果图](#② 效果图)



1 方案

具体步骤如下:

① ++++读取视频流++++:使用cv2.VideoCapture()读取视频文件。

② ++++灰度++++ ++++化++++:将彩色图像转换为灰度图,简化后续计算。

③ ++++帧间差分++++:计算连续三帧之间的差分,absdiff函数计算两个灰度图像的绝对差值。然后,将两帧差相加。

④ ++++阈值处理++++:使用threshold函数将差分图像转换为二值图像,突出运动区域。

⑤ ++++形态学操作++++:应用闭运算(morphologyEx)去除小的噪声点。

⑥ ++++显示结果++++:使用imshow显示检测到的运动区域和当前帧。

⑦ ++++更新帧++++:将当前帧更新为下一帧,以便在循环中持续检测运动目标。

⑧ ++++退出循环++++:按'q'键退出程序。

需要注意的是,三帧差法仅适用于背景相对静止 的场景。如果背景的变化较大,则需要更复杂的方法(背景减除或自适应阈值技术)。

2 实践

① 代码

python 复制代码
import cv2
import numpy as np


def OD(video_path):
    # 初始化摄像头
    cap = cv2.VideoCapture(video_path)
    # 读取第一帧作为初始帧
    ret, frame1 = cap.read()
    frame1_gray = cv2.cvtColor(frame1, cv2.COLOR_BGR2GRAY)
    # 读取第二帧
    ret, frame2 = cap.read()
    frame2_gray = cv2.cvtColor(frame2, cv2.COLOR_BGR2GRAY)
    while True:
        # 读取第三帧
        ret, frame3 = cap.read()
        if not ret:
            break
        frame3_gray = cv2.cvtColor(frame3, cv2.COLOR_BGR2GRAY)
        # 计算帧间差
        diff1 = cv2.absdiff(frame1_gray, frame2_gray)
        diff2 = cv2.absdiff(frame2_gray, frame3_gray)
        # 将两帧差相加
        diff = cv2.add(diff1, diff2)
        # 应用阈值来提取运动区域
        _, thresh = cv2.threshold(diff, 30, 255, cv2.THRESH_BINARY)
        # 使用形态学操作去除噪声
        kernel = np.ones((5, 5), np.uint8)
        closing = cv2.morphologyEx(thresh, cv2.MORPH_CLOSE, kernel)
        # 显示结果
        cv2.imshow("video", frame3)
        cv2.imshow('Motion Detection', closing)
        # 更新帧
        frame1_gray = frame2_gray
        frame2_gray = frame3_gray
        # 按'q'退出循环
        if cv2.waitKey(1) & 0xFF == ord('q'):
            break
    # 释放资源
    cap.release()
    cv2.destroyAllWindows()


if __name__ == '__main__':
    OD("test.mp4")
    pass

② 效果图

至此,本文分享的内容就结束啦。

相关推荐
wyiyiyi4 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
mit6.8245 小时前
[1Prompt1Story] 滑动窗口机制 | 图像生成管线 | VAE变分自编码器 | UNet去噪神经网络
人工智能·python
没有bug.的程序员5 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
甄超锋5 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
AntBlack6 小时前
不当韭菜V1.1 :增强能力 ,辅助构建自己的交易规则
后端·python·pyqt
杜子不疼.8 小时前
《Python学习之字典(一):基础操作与核心用法》
开发语言·python·学习
myzzb9 小时前
基于uiautomation的自动化流程RPA开源开发演示
运维·python·学习·算法·自动化·rpa
TLuoQiu9 小时前
小电视视频内容获取GUI工具
爬虫·python
我叫黑大帅9 小时前
【CustomTkinter】 python可以写前端?😆
后端·python
胡耀超9 小时前
DataOceanAI Dolphin(ffmpeg音频转化教程) 多语言(中国方言)语音识别系统部署与应用指南
python·深度学习·ffmpeg·音视频·语音识别·多模态·asr