python+opencv实现移动侦测(帧差法)

yizhihongxing

下面是详细讲解“Python+OpenCV实现移动侦测(帧差法)”的完整攻略。

1. 什么是移动侦测

移动侦测是指通过对视频或图像序列进行分析,检测出其中的运动目标。在视频监控、智能交通等领域中,移动侦测是一项重要的技术。

2. 帧差法原理

帧差法是一种简单有效的移动侦测算法,其原理是通过比较相邻帧之间的像素值差异,来检测出运动目标。具体实现过程如下:

  1. 读取视频帧。
  2. 将当前帧与前一帧进行差分,得到差分图像。
  3. 对差分图像进行二值化处理,得到前景掩模。
  4. 对前景掩模进行形态学操作,去除噪声和小的区域。
  5. 在前景掩模中检测出运动目标的轮廓。

3. 实现移动侦测

以下是用Python+OpenCV实现移动侦测的步骤。

3.1 导入库

import cv2
import numpy as np

3.2 读取视频

cap = cv2.VideoCapture('test.mp4')

3.3 初始化变量

ret, frame = cap.read()
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
gray = cv2.GaussianBlur(gray, (21, 21), 0)
background = gray

3.4 实现帧差法

while True:
    ret, frame = cap.read()
    if not ret:
        break
    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    gray = cv2.GaussianBlur(gray, (21, 21), 0)
    diff = cv2.absdiff(background, gray)
    thresh = cv2.threshold(diff, 25, 255, cv2.THRESH_BINARY)[1]
    thresh = cv2.dilate(thresh, None, iterations=2)
    contours, hierarchy = cv2.findContours(thresh.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
    for contour in contours:
        if cv2.contourArea(contour) < 1000:
            continue
        (x, y, w, h) = cv2.boundingRect(contour)
        cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
    cv2.imshow('frame', frame)
    key = cv2.waitKey(1) & 0xFF
    if key == ord('q'):
        break
    if key == ord('r'):
        background = gray
cap.release()
cv2.destroyAllWindows()

4. 示例说明

以下是两个示例说明,分别是使用帧差法实现移动侦测和使用帧差法实现移动侦测保存检测结果。

4.1 使用帧差法实现移动侦测

以下是一个使用帧差法实现移动侦测的示例。

import cv2
import numpy as np

cap = cv2.VideoCapture('test.mp4')

ret, frame = cap.read()
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
gray = cv2.GaussianBlur(gray, (21, 21), 0)
background = gray

while True:
    ret, frame = cap.read()
    if not ret:
        break
    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    gray = cv2.GaussianBlur(gray, (21, 21), 0)
    diff = cv2.absdiff(background, gray)
    thresh = cv2.threshold(diff, 25, 255, cv2.THRESH_BINARY)[1]
    thresh = cv2.dilate(thresh, None, iterations=2)
    contours, hierarchy = cv2.findContours(thresh.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
    for contour in contours:
        if cv2.contourArea(contour) < 1000:
            continue
        (x, y, w, h) = cv2.boundingRect(contour)
        cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
    cv2.imshow('frame', frame)
    key = cv2.waitKey(1) & 0xFF
    if key == ord('q'):
        break
    if key == ord('r'):
        background = gray

cap.release()
cv2.destroyAllWindows()

4.2 使用帧差法实现移动侦测并保存检测结果

以下是一个使用帧差法实现移动侦测并保存检测结果的示例。

import cv2
import numpy as np

cap = cv2.VideoCapture('test.mp4')

ret, frame = cap.read()
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
gray = cv2.GaussianBlur(gray, (21, 21), 0)
background = gray

cc = cv2.VideoWriter_fourcc(*'XVID')
out = cv2.VideoWriter('output.avi', fourcc, 20.0, (640, 480))

while True:
    ret, frame = cap.read()
    if not ret:
        break
    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    gray = cv2.GaussianBlur(gray, (21, 21), 0)
    diff = cv2.absdiff(background, gray)
    thresh = cv2.threshold(diff, 25, 255, cv2.THRESH_BINARY)[1]
    thresh = cv2.dilate(thresh, None, iterations=2)
    contours, hierarchy = cv2.findContours(thresh.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
    for contour in contours:
        if cv2.contourArea(contour) < 1000:
            continue
        (x, y, w, h) = cv2.boundingRect(contour)
        cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
    out.write(frame)
    cv2.imshow('frame', frame)
    key = cv2.waitKey(1) & 0xFF
    if key == ord('q'):
        break
    if key == ord('r'):
        background = gray

cap.release()
out.release()
cv2.destroyAllWindows()

5. 总结

帧差法是一种简单有效的移动侦测算法,可以用Python+OpenCV实现。本教程介绍了帧差法的原理和实现步骤,并提供了相应的示例。其中,示例一是使用帧差法实现移动侦测,示例二是使用帧差法实现移动侦测并保存检测结果。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:python+opencv实现移动侦测(帧差法) - Python技术站

(0)
上一篇 2023年5月14日
下一篇 2023年5月14日

相关文章

  • Python工具箱系列(三十一)

    Neo4j是一个高性能的开源的,使用Java语言实现的NoSQL图数据库,它将结构化数据存储在网络上而不是表中。它是一个嵌入式的、基于磁盘的、具备完全的事务特性的Java持久化引擎,但是它将结构化数据存储在网络(从数学角度叫做图)上而不是表中。Neo4j也可以被看作是一个高性能的图引擎,该引擎具有成熟数据库的所有特性。现实中很多数据都是用图来表达的,比如社交…

    python 2023年5月11日
    00
  • python中的反斜杠问题深入讲解

    下面就给出一份 Python 中的反斜杠问题深入讲解攻略。 什么是反斜杠? 在计算机编程中,反斜杠(\)是一个特殊字符,通常用于转义(escape)被视为普通字符的字符。我们可以在字符串(string)中使用反斜杠来表示非打印字符、一些保留字符或其他特殊意义字符,这就是转义(escape)序列。 例如,我们可以使用反斜杠字符来在字符串中插入单引号或双引号,或…

    python 2023年6月3日
    00
  • python memory_profiler库生成器和迭代器内存占用的时间分析

    Python是一种动态语言,其内存管理机制相较于其他静态语言有着很大的不同。在Python编程过程中,一些常见的内存问题比如内存泄露、内存瓶颈等都是需要我们及时发现和解决的问题。为了解决这些问题,我们需要查看内存占用和使用情况。这个时候,memory_profiler库就可以派上用场了。 memory_profiler 是一个用于 Python 的内存分析工…

    python 2023年6月2日
    00
  • 使用ImageMagick进行图片缩放、合成与裁剪(js+python)

    使用ImageMagick进行图片缩放、合成与裁剪需要掌握以下几个方面的知识: 安装ImageMagick; 使用命令行操作ImageMagick; 用Python调用ImageMagick命令行。 以下是详细攻略。 1. 安装ImageMagick ImageMagick是一款开源的图片处理工具,它能够对图片进行处理、转换、合成和编辑。我们可以通过以下方式…

    python 2023年5月19日
    00
  • python3实现ftp服务功能(服务端 For Linux)

    Python3实现FTP服务功能(服务端 For Linux)攻略 本文将介绍如何使用Python3实现FTP服务端功能(适用于Linux平台),包括搭建FTP服务器、用户管理、上传下载文件等功能。 搭建FTP服务器 安装 vsftpd 在Linux终端中输入以下命令进行安装: sudo apt-get update sudo apt-get install…

    python 2023年5月19日
    00
  • python使用marshal模块序列化实例

    当我们在 Python 中使用某些数据结构时(例如列表、字典等),我们可能需要序列化(将它们转换为特定格式的字符串、文件)以进行长时间存储或网络传输。 Python 中有一个内置的序列化模块 marshal,该模块可以将实例序列化为二进制数据,也可以将二进制数据反序列化为相应的实例对象。下面是使用 marshal 模块序列化 Python 实例的完整攻略。 …

    python 2023年6月2日
    00
  • python爬虫库scrapy简单使用实例详解

    Python爬虫库Scrapy简单使用实例详解 Scrapy是Python语言编写的爬虫框架,可以用于抓取网站信息和数据,支持网站数据解析、存储、和导出,自动化请求和响应处理等功能。本文将为您详细介绍Scrapy框架的使用方法,包括以下几个方面: Scrapy框架的简介和安装 Scrapy爬虫的基本结构和文件 Scrapy爬虫的数据采集和存储 Scrapy爬…

    python 2023年5月14日
    00
  • 详解Python中的内建函数,可迭代对象,迭代器

    详解Python中的内建函数、可迭代对象、迭代器 Python作为一门高级编程语言,提供了很多内建函数、可迭代对象、迭代器等重要概念,下面我们详细讲解它们的用法和作用。 内建函数 Python提供了很多内建函数,这些函数是由Python开发者提供的,使用这些函数可以方便地完成一些基本操作和常用计算。常见的内建函数包括: print(): 打印输出内容到控制台…

    python 2023年5月13日
    00
合作推广
合作推广
分享本页
返回顶部