使用Python和OpenCV实现火焰检测

news/2024/11/6 0:48:12/

使用Python和OpenCV实现火焰检测

项目解释:

此 Python 代码是使用 OpenCV、线程、声音和电子邮件功能的火灾探测系统的简单示例。
以下是它的功能的简单描述:

  1. 导入库:代码首先导入必要的库: cv2:用于图像和视频处理,特别是用于检测火灾。 threading:用于同时运行代码的某些部分(在后台)。 playsound:用于播放报警声音。 smtplib:用于发送电子邮件。
  2. 加载训练模型:代码加载预训练的机器学习模型(XML 文件),该模型可以检测图像中的火灾。
  3. 设置视频源:设置视频输入源,可以是笔记本电脑内置摄像头,也可以是外接USB 摄像头。该代码当前配置为从名为“fire2.mp4”的文件中读取视频。
  4. play_alarm_sound_function()4. 播放报警声音:定义播放报警声音的函数。该函数在后台运行(线程)并播放名为“fire_alarm.mp3”的警报声音文件。
  5. 发送电子邮件:send_mail_function()定义了另一个函数来发送电子邮件。它使用 Gmail 的 SMTP 服务器向指定收件人发送有关火灾检测的警告电子邮件。代码中需要提供发件人的电子邮件和密码。
  6. 主循环:主循环处理视频的每一帧。它执行以下操作:将帧转换为灰度以便于处理。使用加载的模型检测框架中的火灾。如果检测到火灾,它会用蓝色矩形突出显示该区域。如果第一次检测到火灾(由 控制runOnce),则会触发警报声并使用线程发送电子邮件。警报和电子邮件功能在后台运行。一旦警报和电子邮件被触发一次,系统就不会为后续发生火灾的帧重复此过程。
  7. 显示视频:代码显示处理后的帧,并在检测到的火灾周围绘制矩形。视频将一直显示,直到您按“q”键。

代码示例

python">import cv2
import threading
import playsound
import smtplib# 加载训练好的 XML 文件
fire_cascade = cv2.CascadeClassifier('fire_detection_cascade_model.xml')# 初始化摄像头
vid = cv2.VideoCapture(0)  # 使用笔记本内置摄像头,索引为 0
runOnce = False  # 创建布尔变量# 定义播放警报声音的函数
def play_alarm_sound_function():playsound.playsound('fire_alarm.mp3', True)print("Fire alarm end")# 定义发送邮件的函数
def send_mail_function():recipientmail = "add recipients mail"recipientmail = recipientmail.lower()try:server = smtplib.SMTP('smtp.gmail.com', 587)server.ehlo()server.starttls()server.login("add senders mail", 'add senders password')server.sendmail('add senders mail', recipientmail, "Warning: Fire accident has been reported")print("Alert mail sent successfully to {}".format(recipientmail))server.close()except Exception as e:print(e)while True:Alarm_Status = Falseret, frame = vid.read()if not ret:print("Failed to grab frame")breakgray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)fire = fire_cascade.detectMultiScale(gray, 1.2, 5)# 增加调试输出print(f"Detected fire regions: {len(fire)}")# 绘制火焰矩形框for (x, y, w, h) in fire:cv2.rectangle(frame, (x-20, y-20), (x+w+20, y+h+20), (0, 255, 0), 2)roi_gray = gray[y:y+h, x:x+w]roi_color = frame[y:y+h, x:x+w]print("Fire alarm initiated")threading.Thread(target=play_alarm_sound_function).start()if not runOnce:print("Mail send initiated")threading.Thread(target=send_mail_function).start()runOnce = Trueelse:print("Mail is already sent once")cv2.imshow('frame', frame)if cv2.waitKey(1) & 0xFF == ord('q'):break# 释放资源
vid.release()
cv2.destroyAllWindows()

效果示例

在这里插入图片描述


http://www.ppmy.cn/news/1544676.html

相关文章

java设计模式之结构型模式(7种)

结构型模式 描述如何将类或者对象按某种布局组成更大的结构。它分为结构型模式和对象结构型模式,前者采用继承机制来组织接口和类,后者通过组合或聚合来组合对象。 分为7种:代理模式、适配器模式、装饰者模式、桥接模式、外观模式、组合模式、…

鸿蒙的进化史

历史性突破:华为发布鸿蒙操作系统,生态设备数突破10亿 10月22日晚,华为在深圳湾体育中心举行了盛大的“原生鸿蒙之夜暨华为全场景新品发布会”。此次发布会的核心亮点是我国首个完全自主可控的移动操作系统——华为原生鸿蒙操作系统正式发布…

基于Multisim光控夜灯LED电路带计时功能(含仿真和报告)

【全套资料.zip】光控夜灯LED电路设计Multisim仿真设计数字电子技术 文章目录 功能一、Multisim仿真源文件二、原理文档报告资料下载【Multisim仿真报告讲解视频.zip】 功能 光控夜灯LED电路 1.采用纯数字电路,非单片机。 2.通过检测周围光线,光线暗自…

ai面试辅助工具有哪些

目前市场上常见的AI面试辅助工具包括以下几款‌: ‌白瓜面试‌:这是一款专为在线面试和笔试场景设计的AI助手,支持实时语音识别、图片识别、智能辅助回答等功能,适用于多种岗位和面试平台‌ ‌Interview‌:这是一款基…

Redis-基本全局命令

Redis 有5种数据结构,但它们都是键值对种的值,对于键来说有⼀些通⽤的命令。 KETS 返回所有满⾜样式(pattern)的key。⽀持如下统配样式。 h?llo 匹配 hello, hallo 和 hxllo h*llo 匹配 hllo 和 heeeeeello h[ae]llo 匹配 hel…

Python绘制爱心

文章目录 系列目录写在前面技术需求完整代码代码分析写在后面 系列目录 序号直达链接爱心系列1Python制作一个无法拒绝的表白界面2Python满屏飘字表白代码3Python无限弹窗满屏表白代码4Python李峋同款可写字版跳动的爱心5Python流星雨代码6Python漂浮爱心代码7Python爱心光波代…

VMWARE ESXI VMFS阵列故障 服务器数据恢复

1:河南用户一台DELL R740 3块2.4T硬盘组的RAID5,早期坏了一个盘没有及时更换,这次又坏了一个,导致整组RAID5处于数据丢失的状态, 2:该服务器装的是VMware ESXI 6.7,用户把3块硬盘寄过来进行数据…

TS-AWG控制电光调制器:推动科技应用新发展的利器

一、电光调制有什么用? 如今,基于光学、光子学和脉冲激光以及电光调制器的应用正变得极为流行,最新一代科学家正在为其实际应用开辟新领域,如汽车激光雷达、医疗解决方案、航空航天和国防、量子和激光传感器。 测试挑战、上市时…