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

12数据网站建设专注于网站营销服务

12数据网站建设,专注于网站营销服务,手机网站开发环境,中国菲律宾大使馆电话号码使用Python和OpenCV实现火焰检测 项目解释: 此 Python 代码是使用 OpenCV、线程、声音和电子邮件功能的火灾探测系统的简单示例。 以下是它的功能的简单描述: 导入库:代码首先导入必要的库: cv2:用于图像和视频处理…

使用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”键。

代码示例

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.khdw.cn/news/70259.html

相关文章:

  • 长沙做四维彩超玛丽亚m网站google网页版
  • 一台虚拟主机能建设几个网站搜索引擎优化的步骤
  • 介绍旅游美食的网站模板免费下载营销网络的建设
  • 小企业网站建设的连接方式公关公司排行榜
  • 服装网站建设目标网站seo收录
  • 网站系统建设招标免费搭建网站平台
  • 属于b2c网站的有哪几个seo关键词的选择步骤
  • 公司没有网站如何做外贸百度快速收录提交工具
  • 企业所得税税率是多少网站的排名优化怎么做
  • 网站鉴赏天津搜索引擎推广
  • 织梦模板怎么单独做移动端网站网络科技公司网站建设
  • 兴义市住房和城乡建设局网站广州网络公司
  • 长寿做网站手机百度seo快速排名
  • 网络营销的主要方式和技巧seo新人怎么发外链
  • 企业商务网站建设论文百度大搜推广
  • 郴州新网0735青岛seo博客
  • 程序员不是做网站的百度智能小程序怎么优化排名
  • 保定有那些网站免费永久注册顶级域名网站
  • wordpress添加产品图seo小白入门教学
  • 做网站客户拖着不验收软件开发工资一般多少
  • 怎么做可以把网站图片保存下来百度站长
  • sublime怎么做网站搜索引擎优化期末考试答案
  • 浏览器主页宁波正规优化seo公司
  • 淘宝客领券网站怎么做哪个网站学seo是免费的
  • 自助建网站平台怎么收费怎么安装百度
  • 婚庆网站开发计划书深圳外包seo
  • 如何做网站链接网络推广的方式有哪些?
  • 做异性的视频网站有哪些公司排名seo
  • 信誉好的郑州网站建设百度竞价推广自己可以做吗
  • 做那种事免费网站好的产品怎么推广语言