使用OpenCV实现帧间变化检测:基于轮廓的动态区域标注

在计算机视觉中,帧间差异检测(frame differencing)是一种常用的技术,用于检测视频流中的动态变化区域。这种方法尤其适用于监控、运动分析、目标追踪等场景。在这篇博客中,我们将通过分析一个基于OpenCV的简单帧间差异检测代码,深入探讨其应用技术、使用算法以及可能的应用场景。

1. 代码概述
import cv2
import numpy as np

class FrameObject:
    def __init__(self):
        self.prev_frame = None
        self.color_list = [(0, 255, 0), (0, 0, 255), (255, 0, 0), (0, 255, 255), (255, 255, 0)]  # 预定义几种颜色

    def init_parameters(self, *args, **kwargs):
        pass

    def get_complementary_color(self, color):
        """计算互补色"""
        return (255 - color[0], 255 - color[1], 255 - color[2])

    def do(self, frame, device):
        # 转换为灰度图像
        gray_frame = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)

        # 如果是第一次处理,保存当前帧并返回原图
        if self.prev_frame is None:
            self.prev_frame = gray_frame
            return frame

        # 计算当前帧和上一帧的差异
        diff = cv2.absdiff(self.prev_frame, gray_frame)

        # 对差异图像应用阈值,以突出显示变化区域
        _, thresh = cv2.threshold(diff, 25, 255, cv2.THRESH_BINARY)

        # 找到轮廓,标识出变化的区域
        contours, _ = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

        color_idx = 0  # 颜色索引

        # 在原始图像上绘制变化区域的轮廓
        for contour in contours:
            if cv2.contourArea(contour) > 500:  # 过滤掉小的变化区域
                (x, y, w, h) = cv2.boundingRect(contour)
                color = self.color_list[color_idx % len(self.color_list)]  # 循环使用颜色
                complementary_color = self.get_complementary_color(color)  # 获取对比色

                # 使用不同的颜色绘制矩形框
                cv2.rectangle(frame, (x, y), (x + w, y + h), color, 2)
                
                # 绘制轮廓边界使用对比色
                cv2.drawContours(frame, [contour], -1, complementary_color, 2)

                # 增加颜色索引,以便为下一个变化区域使用不同颜色
                color_idx += 1

        # 更新上一帧
        self.prev_frame = gray_frame

        return frame
2. 算法解析

该代码实现了一个基于帧间差异检测(frame differencing)的方法,用于检测视频流中连续帧之间的变化。其核心算法步骤如下:

2.1 灰度转换

首先,将每一帧图像转换为灰度图像。这一步的目的是减少计算量,因为灰度图像只包含亮度信息,而去除了色彩信息,这对于变化检测来说已经足够。

gray_frame = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
2.2 计算帧差异

接下来,使用cv2.absdiff计算当前帧和上一帧的差异。absdiff函数返回两个图像之间每个像素的绝对差值,差异越大的像素值越高,表示该区域发生了变化。

diff = cv2.absdiff(self.prev_frame, gray_frame)
2.3 阈值处理

通过设置一个阈值(在这里是25),我们将差异图像二值化,使得变化显著的区域更加突出。这个阈值操作帮助过滤掉较小的变化,保留较大、明显的动态区域。

_, thresh = cv2.threshold(diff, 25, 255, cv2.THRESH_BINARY)
2.4 轮廓检测

利用cv2.findContours函数,检测差异图像中的轮廓。轮廓检测可以识别出图像中连续的像素区域,标志着图像中的边界或形状。在这里,我们只关心那些变化较大的区域。

contours, _ = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
2.5 绘制变化区域

最后,我们对每一个检测到的轮廓绘制矩形框,并且使用不同的颜色突出显示变化区域。为了便于区分不同区域,我们预定义了一些颜色,并为每个轮廓分配一种颜色。在绘制矩形框的同时,还使用互补色来绘制轮廓,增加视觉对比。

cv2.rectangle(frame, (x, y), (x + w, y + h), color, 2) cv2.drawContours(frame, [contour], -1, complementary_color, 2)
3. 应用场景

帧间差异检测算法常用于以下场景:

3.1 视频监控

在安防领域,帧间差异检测是监控摄像头常用的检测手段,用于实时监控和异常检测。通过对视频帧进行差异分析,可以快速发现场景中是否发生了移动物体,或监控区域内是否出现了异常行为。

3.2 运动分析

运动分析(例如运动员的动作捕捉或体育赛事的动作分析)也可以利用帧间差异检测来提取动态变化区域。这些变化区域可以进一步分析,识别出特定的运动动作或行为模式。

3.3 物体追踪

在目标追踪应用中,帧间差异检测可以作为初步的候选区域检测方法,帮助追踪物体在视频帧中的运动轨迹。通过对每帧图像差异的分析,可以找到物体的位置变化。

3.4 异常检测

除了运动物体的检测,帧间差异检测也可以用于发现场景中的突发变化,比如人群聚集、物体掉落等。这对于自动化的监控系统尤为重要,尤其是在工业生产线、公共安全等领域。

4. 技术优势
4.1 实时性

该方法非常适合实时视频处理。由于计算的是两帧之间的差异,只需对图像进行简单的灰度化、阈值处理和轮廓检测,相比深度学习方法,其计算量小,速度较快,适用于实时应用。

4.2 简单易实现

与基于深度学习的物体检测方法相比,帧间差异检测方法实现简单,不需要大规模的数据集进行训练,也不依赖强大的硬件资源,易于部署和集成。

4.3 高效性

通过阈值处理和轮廓检测,该方法能够有效地过滤掉小范围的变化,减少无关信息,提高了效率和准确性。与基于光流或背景建模的方法相比,帧间差异检测算法在一些场景下可能更加高效。

5. 改进与挑战

尽管帧间差异检测方法简单且高效,但它也有一些局限性:

  • 光照变化的敏感性:如果光照发生变化,可能导致误报或漏报。可以通过引入背景建模技术,减少这一问题。
  • 动态背景:如树枝摆动、风等动态背景也可能被错误地标记为运动区域。对于此类场景,可能需要进一步的后处理步骤,如背景建模或目标检测。

为了进一步提高鲁棒性,可以考虑将该方法与深度学习模型结合,采用深度背景建模或基于卷积神经网络(CNN)的图像差异分析方法,以提升对复杂场景的适应能力。

6. 结论

通过这段代码,我们能够看到帧间差异检测的基本实现方式。这种方法具有快速、实时处理的优势,适用于许多需要检测场景变化的应用,如视频监控、运动分析和异常检测。虽然它在某些动态环境下可能面临挑战,但其简单性和高效性使其成为许多实时视频分析任务中的有效工具。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/978324.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

夜莺监控 - 边缘告警引擎架构详解

前言 夜莺类似 Grafana 可以接入多个数据源,查询数据源的数据做告警和展示。但是有些数据源所在的机房和中心机房之间网络链路不好,如果由 n9e 进程去周期性查询数据并判定告警,那在网络链路抖动或拥塞的时候,告警就不稳定了。所…

【QT 一 | 信号和槽】

Qt5基本模块 Qt Creator 中的快捷键 • 注释:ctrl / • 运⾏:ctrl R • 编译:ctrl B • 字体缩放:ctrl 鼠标滑轮 • 查找:ctrl F • 整行移动:ctrl shift ⬆/⬇ • 帮助⽂档:F1 • 自动…

Ubuntu本地使用AnythingLLM

1.介绍 AnythingLLM是一个全栈应用程序,由Mintplex Labs Inc.开发,旨在将任何文档、资源或内容片段转换为大语言模型(LLM)在聊天中可以利用的相关上下文。 2.在ubuntu本地安装 打开终端并运行: curl -fsSL https:/…

Rust学习总结之-枚举

枚举是一个很多语言都有的功能,不过不同语言中其功能各不相同但是要表达的意思是一致的,枚举就是对于一个事物可以穷举出所有可能得值。比如说人的性别就可以用枚举,男人和女人两种。下面我们来学习Rust中的枚举。 一:枚举定义 …

domain 网络安全 网络安全域

🍅 点击文末小卡片 ,免费获取网络安全全套资料,资料在手,涨薪更快 文章目录 1、域的概述 1.1、工作组与域1.2、域的特点1.3、域的组成1.4、域的部署概述1.5、活动目录1.6、组策略GPO 2、域的部署实验 2.1、建立局域网&#xf…

面试基础---深入解析 AQS

深入解析 AQS:从源码到实践,剖析 ReentrantLock 和 Semaphore 的实现 引言 在 Java 并发编程中,AbstractQueuedSynchronizer(AQS)是一个核心框架,它为构建锁和其他同步器提供了基础支持。ReentrantLock 和…

Harmony开发笔记(未完成)

一、感想 作为一名拥有11年经验的Android开发者,我亲历了Android从高速发展到如今面临“僧多粥少”的过程。技术的世界瞬息万变,没有一种技术能够让人依赖一辈子。去年初,我自学了鸿蒙系统,并顺利通过了鸿蒙官方的初级和高级认。…

计算机视觉(opencv-python)入门之常见图像处理基本操作(待补充)

图像预处理是计算机视觉任务中的关键步骤,它通过对原始图像进行处理,以提高后续图像分析、特征提取和识别的准确性。 示例图片 目录 常见图像预处理方法 灰度化处理 法一 法二 说明 切片截取部分图像数据 cv2.cvtColor() 颜色空间转换 cv2.spli…

设计模式Python版 备忘录模式

文章目录 前言一、备忘录模式二、备忘录模式示例1三、备忘录模式示例2 前言 GOF设计模式分三大类: 创建型模式:关注对象的创建过程,包括单例模式、简单工厂模式、工厂方法模式、抽象工厂模式、原型模式和建造者模式。结构型模式&#xff1a…

Linux红帽:RHCSA认证知识讲解(三)Linux基础指令与Vim编辑器的使用

Linux红帽:RHCSA认证知识讲解(三)Linux基础指令与Vim编辑器的使用 前言一、Linux基础指令二、Linux 文件系统层次结构概念三、通过路径指定文件四、使用命令行工具管理文件五、Vim 的安装方式六、Vim 的操作模式七、红帽建议掌握的 Vim 键和命…

auto.js例子之WebView多页面浏览器

"ui";ui.layout(<vertical><horizontal id"webs" layout_weight"1"></horizontal><button id"one" text"第一个" /><button id"two" text"第二个" /><button id"…

跨平台公式兼容性大模型提示词模板(飞书 + CSDN + Microsoft Word)

飞书云文档 CSDN MD编辑器 Microsoft Word 跨平台公式兼容方案&#xff1a; 一、背景痛点与解决方案 在技术文档创作中&#xff0c;数学公式的跨平台渲染一直存在三大痛点&#xff1a; 飞书云文档&#xff1a;原生KaTeX渲染与导出功能存在语法限制微软Word&#xff1a;Math…

HTTP 动态报错码的原因和解决方法

目录 1xx&#xff08;信息性状态码&#xff09; 2xx&#xff08;成功状态码&#xff09; 3xx&#xff08;重定向状态码&#xff09; 4xx&#xff08;客户端错误状态码&#xff09; 5xx&#xff08;服务器错误状态码&#xff09; 参考文章 以下是 HTTP 动态报错码的常见原…

Docker基础-常见命令

docker images -查看所有的本地镜像。 docker pull -把远端镜像拉取到本地。 docker rmi -删除镜像。 docker push -推到镜像仓库。 docker run -创建并运行容器&#xff08;自动化&#xff0c;如果发现镜像不存在会先去拉取&#xff0c; 拉取完了以后再去自动创建容器&am…

Spring MVC框架六:Ajax技术

精心整理了最新的面试资料&#xff0c;有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 简介 jQuery.ajax Ajax原理 结语 创作不易&#xff0c;希望能对大家给予帮助 想要获取更多资源? 点击链接获取

36. Spring Boot 2.1.3.RELEASE 中实现监控信息可视化并添加邮件报警功能

1. 创建 Spring Boot Admin Server 项目 1.1 添加依赖 在 pom.xml 中添加 Spring Boot Admin Server 和邮件相关依赖&#xff1a; <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-w…

PowerShell 执行策略:fnm管理软件安装nodejs无法运行npm,错误信息:about_Execution_Policies

通过fnm管理软件安装NodeJS后添加环境变量依然无法执行npm,提示无法加载文件&#xff0c;错误如下&#xff1a; PowerShell 执行策略简介&#xff1a; PowerShell 执行策略是一项安全功能&#xff0c;用于控制 PowerShell 加载配置文件和运行脚本的条件。 此功能有助于防止恶…

Java在云计算平台中的应用研究

Java在云计算平台中的应用研究 随着云计算的广泛应用&#xff0c;越来越多的企业和开发者开始选择基于云计算的架构来构建和部署应用。Java作为一种成熟的编程语言&#xff0c;凭借其跨平台性、强大的生态系统以及优秀的并发处理能力&#xff0c;已成为云计算平台中常用的编程…

电脑键盘知识

1、键盘四大功能区 1. 功能区 2. 主要信息输入区 3. 编辑区 4. 数字键盘区 笔记本电脑键盘的功能区&#xff0c;使用前需先按Fn键 1.1、功能区 ESC&#xff1a;退出 F1&#xff1a;显示帮助信息 F2&#xff1a;重命名 F4&#xff1a;重复上一步操作 F5&#xff1a;刷新网页 …

论文阅读笔记:Continual Forgetting for Pre-trained Vision Models

论文阅读笔记&#xff1a;Continual Forgetting for Pre-trained Vision Models 1 背景2 创新点3 方法4 模块4.1 问题设置4.2 LoRA4.3 概述4.4 GS-LoRA4.5 损失函数 5 效果6 结论 1 背景 出于隐私和安全考虑&#xff0c;如今从预先训练的视觉模型中删除不需要的信息的需求越来…