openvino yolov5/ssd 实时推流目标检测在html上显示
安装ffmepg并添加到环境变量中,流媒体使用m7s
运行效果 SSD:检测在10ms左右,yolov5在100ms左右

app.py

#!/usr/local/bin/python3
# encodin: utf-8import subprocess
import threading
import time
import cv2
import osfrom OpenVinoYoloV5Detector import OpenVinoYoloV5Detector
from OpenVinoSSDDetector import OpenVinoSSDDetectorclass RTSCapture(cv2.VideoCapture):_cur_frame = None_reading = False_frame1 = None# 视频播放质量 值越大越模糊# _quality = 2.5 # 1;1.5;2;2.5# _interval_check = 1000 # 检测间隔 0 不跳帧 1秒10帧_quality = 1_interval_check = 0_recvtime = 0@staticmethoddef get_even(num):if (num % 2) != 0:num = num + 1return num@staticmethoddef create(srcstream, dststream):rtscap = RTSCapture(srcstream)rtscap.frame_receiver = threading.Thread(target=rtscap.recv_frame, daemon=True)rtscap.frame_processer = threading.Thread(target=rtscap.prcoess_frame, daemon=True)rtscap.frame_sender = threading.Thread(target=rtscap.send_frame, daemon=True)fps = int(rtscap.get(cv2.CAP_PROP_FPS))rtscap.width = rtscap.get_even(int(rtscap.get(cv2.CAP_PROP_FRAME_WIDTH) / rtscap._quality))rtscap.height = rtscap.get_even(int(rtscap.get(cv2.CAP_PROP_FRAME_HEIGHT) / rtscap._quality))rtscap.command = ['G:\\ZLMediaKit_Release\\ffmpeg.exe','-y','-f', 'rawvideo','-vcodec', 'rawvideo','-pix_fmt', 'bgr24','-s', "{}x{}".format(rtscap.width, rtscap.height),'-r', str(fps),'-i', '-','-c:v', 'libx264','-pix_fmt', 'yuv420p','-preset', 'ultrafast','-f', 'rtsp', # flv rtsp'-rtsp_transport', 'udp', # 使用TCP推流,linux中一定要有这行dststream]# 管道配置rtscap._reading = True# 加载算法rtscap.box_color = (0, 255, 0)# yolov5# conf = {# # "weight_file": "weights/yolov5n_openvino_model/yolov5n.xml",# "weight_file": "weights/yolov5n_openvino_model/yolov5n.xml",# "device": "CPU"# }# rtscap.detector = OpenVinoYoloV5Detector(IN_conf=conf)#ssdconf = {"model_xml": "./weights/ssdlite_mobilenet_v2/FP16/ssdlite_mobilenet_v2.xml","model_bin": "./weights/ssdlite_mobilenet_v2/FP16/ssdlite_mobilenet_v2.bin","device": "CPU"}rtscap.detector = OpenVinoSSDDetector(IN_conf=conf)return rtscapdef get_milsecond(self):t = time.time()return (int(round(t * 1000)))def isOK(self):status = self.isOpened() and self._readingreturn statusdef recv_frame(self):while self.isOK():time.sleep(0.01)ok, frame = self.read()if not ok:breakself._cur_frame = frame#self.p.stdin.write(frame.tostring())self._reading = Falsedef prcoess_frame(self):while self.isOK():time.sleep(0.01)try:ok, frame = self.read_latest_frame()if not ok:continue# 算法解析# 跳帧检测if self.get_milsecond() - self._recvtime > self._interval_check:starttime = self.get_milsecond()detect_num, detect_data = self.detector.detect(frame)if len(detect_data):for m in detect_data:classname = m.get('class_name')score = m.get('score')location = m.get('location')box_l, box_t = int(location.get('x1')), int(location.get('y1'))box_r, box_b = int(location.get('x2')), int(location.get('y2'))frame = cv2.rectangle(frame, (box_l, box_t), (box_r, box_b), self.box_color, 2)frame = cv2.putText(frame, classname, (box_l, box_t + 15), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (0, 0, 255), 2)self._recvtime = self.get_milsecond()endtime = self.get_milsecond();print('检测耗时:' + str(endtime - starttime))self._frame1 = cv2.resize(frame, (self.width, self.height)) # 图像压缩#self.p.stdin.write(frame1.tostring())except Exception as e:ss = str(e)def send_frame(self):timeout = 3self.p = subprocess.Popen(self.command, shell=False, stdin=subprocess.PIPE)while self.isOK():time.sleep(0.01)try:if self._frame1 is not None:self.p.stdin.write(self._frame1.tostring())except Exception as e:ss = str(e)def read2(self):frame = self._cur_frameself._cur_frame = Nonereturn frame is not None, framedef start_read(self):self.frame_receiver.start()self.frame_processer.start()self.frame_sender.start()self.read_latest_frame = self.read2 if self._reading else self.readdef stop_read(self):self._reading = Falseif self.frame_receiver.is_alive():self.frame_receiver.join()if self.frame_processer.is_alive():self.frame_processer.join()if self.frame_sender.is_alive():self.frame_sender.join()if __name__ == '__main__':url = src = '0'if src.isdigit():url = int(src)rtscap1 = RTSCapture.create(url, "rtsp://127.0.0.1:554/live/test0") # test.mp4 0rtscap1.start_read()os.system('pause')

相关文章:
openvino yolov5/ssd 实时推流目标检测在html上显示
安装ffmepg并添加到环境变量中,流媒体使用m7s 运行效果 SSD:检测在10ms左右,yolov5在100ms左右 app.py #!/usr/local/bin/python3 # encodin: utf-8import subprocess import threading import time import cv2 import osfrom OpenVinoYoloV…...
基于FPGA的 SPI通信 设计(1)
引言 低速通信目前搞过 UART串口通信、IIC通信。其实 SPI 也算是中低速(有时也可以用作高速通信)串行通信的范畴,但是一直还没真正实现过,所以此系列就 SPI的协议以及FPGA设计作几篇博客记录。欢迎订阅关注~ SPI 标准协议 x1模式…...
为什么西门子、美的等企业这样进行架构升级,看看改造效果就知道了
在工业领域, 生产、测试、运行阶段都可能会产生大量带有时间戳的传感器数据,这都属于典型的时序数据。时序数据主要由各类型实时监测、检查与分析设备所采集或产生,涉及制造、电力、化工、工程作业等多个行业,具备写多读少、量非常…...
open3d点云配准函数registration_icp
文章目录基本原理open3d调用绘图基本原理 ICP, 即Iterative Closest Point, 迭代点算法。 ICP算法有多种形式,其中最简单的思路就是比较点与点之间的距离,对于点云P{pi},Q{qi}P\{p_i\}, Q\{q_i\}P{pi},Q{qi}而言,如果二者是同一目标&am…...
HTML编码规范
本篇文章是基于王叨叨大佬师父维护的文档梳理的,有兴趣可以去看一下原文HTML编码规范。 1. 缩进与换行 【建议】 使用 2 个空格作为一个缩进层级,不允许使用tab字符 解释: 具体项目,可以使用2个空格,也可以使用…...
PDF SDK for Linux 8.4.2 Crack
PDF SDK for Linux 是适用于任何 Linux 企业或云应用程序的强大解决方案,非常适合需要完全可定制的 PDF 查看器或后端流程的任何 Linux 开发人员。 将 Foxit PDF SDK 嵌入到基于 Linux 的应用程序中非常容易。只需打开您最喜欢的 Linux IDE,复制您需要的…...
vb 模块和作用域的关系
模块在VB中有三种类型的模块,分别是窗体模块、标准模块和类模块。窗体模块窗体模块中包含了窗体以及窗体中所有控件的事件过程,文件扩展名为(*.frm),窗体文件中不仅包含窗体对象的外观设计,也包含窗体模块(…...
Redis分布式锁
一、背景 与分布式锁相对应的是「单机锁」,我们在写多线程程序时,避免同时操作一个共享变量产生数据问题,通常会使用一把锁来「互斥」,以保证共享变量的正确性,其使用范围是在「同一个进程」中。单机环境下࿰…...
京东前端经典面试题整理
img的srcset属性的作⽤? 响应式页面中经常用到根据屏幕密度设置不同的图片。这时就用到了 img 标签的srcset属性。srcset属性用于设置不同屏幕密度下,img 会自动加载不同的图片。用法如下: <img src"image-128.png" srcset&qu…...
django+mysql实现一个简单的web登录页面
目录 一、使用pyacharm创建一个django项目 二、启动django项目验证 三、配置mysql数据库 1、本地安装mysql数据库 1)安装mysql数据库 2)自己创建一个数据库 2、安装 pymysql 3、配置mysql数据库 1)在项目同名包下的_init_.py里面添加…...
python cartopy手动导入地图数据绘制底图/python地图上绘制散点图:Downloading:warnings/散点图添加图里标签
……开学回所,打开电脑spyder一看一脸懵逼,简直不敢相信这些都是我自己用过的代码,想把以前的自己喊过来科研了() 废话少说,最近写小综述论文,需要绘制一个地图底图+散点图ÿ…...
JavaScript中常用的数组方法
在日常开发中,我们会接触到js中数组的一些方法,这些方法对我们来说,可以很便利的达到我们想要的结果,但是因为方法比较多,有些方法也不常用,可能会过一段时间就会忘记,那么在这里我整理了一些数…...
磁疗为什么“没效果”?原来真相是这样!
很多人磁疗之后, 总爱迫不及待问一个问题: “这个多长时间见效啊?” …… 还有些人几天没有效果, 就果断下结论: “这东西没用!” …… 有不少人错误地把磁疗等同于“药品”一样看待,总觉得…...
【直击招聘C++】5.1函数模板
5.1函数模板一、要点归纳1.定义函数模板2.实例化函数模板3.重载模板函数4.函数调用的匹配顺序一、要点归纳 1.定义函数模板 定义函数模板的一般格式如下: template<类型形参表> 返回类型 函数名(形参表) {函数体; }例如以…...
谈谈Java多线程离不开的AQS
如果你想深入研究Java并发的话,那么AQS一定是绕不开的一块知识点,Java并发包很多的同步工具类底层都是基于AQS来实现的,比如我们工作中经常用的Lock工具ReentrantLock、栅栏CountDownLatch、信号量Semaphore等,而且关于AQS的知识点…...
国际化语言,多语言三种方式
可以用透传的方式,自己写local的json文件,不需要配置什么,直接传,自己写方法i18n nextjsi18n umi4一、透传的方式 export const AppContext React.createContext<any>({})app.tsx 用context包裹import type { AppProps } f…...
C++——哈希3|位图
目录 常见哈希函数 位图 位图扩展题 位图的应用 常见哈希函数 1. 直接定址法--(常用) 这种方法不存在哈希冲突 取关键字的某个线性函数为散列地址:Hash(Key) A*Key B 优点:简单、均匀 缺点:需要事先知道关键字的…...
75 error
全部 答对 答错 选择题 3. 某公司非常倚重预测型方法交付项目,而其招聘的新项目经理却习惯于运用混合型方法。项目范围包含很多不清晰的需求。项目经理应该如何规划项目的交付? A company that is heavily focused on delivering projects using predi…...
ESP-C3入门8. 连接WiFi并打印信息
ESP-C3入门8. 连接WiFi并打印信息一、ESP32 连接WiFi的基本操作流程1. 初始化nvs存储2. 配置WiFi工作模式3. 设置WiFi登陆信息4. 启动WiFi5. 开启连接6. 判断是否成功二、事件处理函数1. 定义事件处理函数2. 创建事件组3. 在事件处理函数中设置事件组位4. 在其他任务中等待事件…...
使用python将EXCEL表格中数据转存到数据库
使用Python将excel表格中数据转存到数据库 1. 思路: 1) 使用python读取excel表格中数据 2)根据数据生成sql语句 3)批量运行sql语句 2. 代码: import pandas as pddef readExcel(path, excel_file):return pd.read_e…...
HFSS Optimetrics保姆级教程:从参数扫描到蒙特卡洛分析,手把手搞定天线优化
HFSS Optimetrics实战指南:构建天线优化全流程方法论 在射频与微波器件设计领域,天线性能优化往往是一个反复迭代的试错过程。传统手动调整参数的方式不仅效率低下,更难以捕捉复杂参数间的非线性关系。HFSS Optimetrics模块的五大核心功能——…...
Sketch MeaXure:3步告别设计标注烦恼的TypeScript重构方案
Sketch MeaXure:3步告别设计标注烦恼的TypeScript重构方案 【免费下载链接】sketch-meaxure 项目地址: https://gitcode.com/gh_mirrors/sk/sketch-meaxure Sketch MeaXure是一款基于TypeScript重构的Sketch设计标注插件,专为解决UI设计师与开发…...
如何构建你的个人AI记忆库:三步完成微信聊天数据永久留存
如何构建你的个人AI记忆库:三步完成微信聊天数据永久留存 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/We…...
凌扬微优势代理 LY3508 4.2V/1A充电/1.6A驱动 全桥马达驱动控制芯片 ESOP8 技术解析
在电动牙刷、智能垃圾桶等单节锂电池供电的马达类产品中,需要一款集成锂电池充电管理和全桥马达驱动的芯片,以实现电机正反转、刹车控制,并简化外围电路设计。LY3508是一款集成了锂电池充电管理模块、全桥马达驱动模块、续流二极管和逻辑控制…...
离线式SMPS输入整流器设计与优化指南
1. 离线式SMPS输入整流器设计基础开关电源(SMPS)的输入整流环节如同电力系统的"第一道闸门",其设计质量直接影响后续DC-DC转换环节的稳定性。在离线式设计中,整流器需要将85-265VAC的宽范围交流输入转换为高压直流,这个看似简单的过…...
EMC预合规测试:传导与辐射发射的实战指南
1. 预合规EMC测试的核心价值与挑战在电子设备开发领域,电磁兼容性(EMC)问题如同无形的暗礁,往往在产品开发后期才突然显现,导致昂贵的重新设计和上市延迟。我曾参与过一个工业控制设备的项目,团队在功能验证…...
js脚本翻页自用
版本 1:按键停止(推荐)// 按 ESC 键随时停止let count 0;let running true;const stop () > {running false;console.log(⏹️ 已停止,共点击 count 次);};const interval setInterval(() > {if (!running) {clear…...
别再只盯着信号强度了!深入浅出解读LoRa天线S11、驻波比与回波损耗
别再只盯着信号强度了!深入浅出解读LoRa天线S11、驻波比与回波损耗 当你的LoRa设备通信距离突然缩水,或是信号时断时续,大多数工程师的第一反应往往是检查发射功率和环境干扰。但真正的高手会拿起矢量网络分析仪,直击问题核心——…...
DNS 服务器学习笔记:核心总结与实验指南
DNS 服务器学习笔记:核心总结与实验指南 📌 一、文章核心重点总结 1. DNS 基础知识 什么是 DNS? DNS(Domain Name System,域名系统)是互联网的“电话簿”,负责将人类易记的域名(如 w…...
【STM32F407启动探秘】从复位向量到main():深入剖析启动文件与BOOT模式
1. STM32F407启动过程全景图 当你按下STM32F407开发板的电源按钮时,芯片内部就像被施了魔法一样开始运转。这个看似简单的上电过程,实际上隐藏着一套精密的启动机制。作为开发者,理解这个过程就像掌握了一把打开STM32内核奥秘的钥匙。 我刚开…...
