基于opencv的指针式仪表的识别与读数

对于指针式仪表的识别与读数,可以通过以下步骤使用OpenCV实现

  • 读取图像:使用cv2.imread()函数读取要处理的仪表图像。
    在这里插入图片描述

  • 灰度转换:使用cv2.cvtColor()函数将彩色图像转换为灰度图像。这是因为灰度图像只有一个通道,便于后续的处理。

  • 平滑滤波:为了去除噪声,可以使用中值滤波或高斯滤波。中值滤波通过将每个像素替换为其邻域像素的中值来消除噪声。高斯滤波则是通过计算像素周围邻域像素的加权平均值来平滑图像。你可以根据实际情况选择适合的滤波方法,例如使用cv2.medianBlur()进行中值滤波或使用cv2.GaussianBlur()进行高斯滤波。对于指针式仪表的识别与读数,可以通过以下步骤使用OpenCV实现:

  • 读取图像:使用cv2.imread()函数读取要处理的仪表图像。

  • 灰度转换:使用cv2.cvtColor()函数将彩色图像转换为灰度图像。这是因为灰度图像只有一个通道,便于后续的处理。
    在这里插入图片描述

  • 平滑滤波:为了去除噪声,可以使用中值滤波或高斯滤波。中值滤波通过将每个像素替换为其邻域像素的中值来消除噪声。高斯滤波则是通过计算像素周围邻域像素的加权平均值来平滑图像。你可以根据实际情况选择适合的滤波方法,例如使用cv2.medianBlur()进行中值滤波或使用cv2.GaussianBlur()进行高斯滤波。

  • 边缘检测:使用Canny边缘检测算法来检测图像中的边缘。Canny边缘检测算法首先使用Sobel算子计算图像的梯度强度和方向,然后通过非最大抑制和双阈值处理来提取出真正的边缘。使用cv2.Canny()函数可以方便地进行Canny边缘检测,你可以根据实际情况调整阈值参数。

  • 轮廓提取:使用cv2.findContours()函数来提取边缘图像中的轮廓。轮廓是连续的曲线,可以用来表示物体的形状。通过设置适当的参数,可以选择性地提取出仪表盘的指针轮廓。

  • 指针识别:对于仪表指针,通常可以通过以下特征进行识别:

  • 面积大小:指针通常具有相对较大的面积。

  • 形状:指针通常是细长的形状,可以通过检查轮廓的形状来判断是否为指针。

  • 位置:指针通常位于仪表盘中心附近。

    可以遍历提取到的轮廓,根据以上特征来筛选出指针轮廓。

  • 读数计算:对于选定的指针轮廓,可以通过计算指针与仪表盘中心之间的夹角来得到仪表的读数。可以使用cv2.minEnclosingCircle()函数找到指针的中心点,然后计算指针中心点与仪表盘中心点之间的夹角。

以上就是通过OpenCV对指针式仪表进行读数的一般步骤。根据实际情况,你可能需要调整参数、采取不同的滤波方法或添加其他处理步骤来适应不同的仪表图像。
在这里插入图片描述

  1. 边缘检测:使用Canny边缘检测算法来检测图像中的边缘。Canny边缘检测算法首先使用Sobel算子计算图像的梯度强度和方向,然后通过非最大抑制和双阈值处理来提取出真正的边缘。使用cv2.Canny()函数可以方便地进行Canny边缘检测,你可以根据实际情况调整阈值参数。

  2. 轮廓提取:使用cv2.findContours()函数来提取边缘图像中的轮廓。轮廓是连续的曲线,可以用来表示物体的形状。通过设置适当的参数,可以选择性地提取出仪表盘的指针轮廓。

  3. 指针识别:对于仪表指针,通常可以通过以下特征进行识别:

    • 面积大小:指针通常具有相对较大的面积。
    • 形状:指针通常是细长的形状,可以通过检查轮廓的形状来判断是否为指针。
    • 位置:指针通常位于仪表盘中心附近。

    可以遍历提取到的轮廓,根据以上特征来筛选出指针轮廓。

  4. 读数计算:对于选定的指针轮廓,可以通过计算指针与仪表盘中心之间的夹角来得到仪表的读数。可以使用cv2.minEnclosingCircle()函数找到指针的中心点,然后计算指针中心点与仪表盘中心点之间的夹角。

结果展示

可以看出下图给出了角度值,通过圆盘的固定尺度的丈量,就可以自动化推理出,指数是多少。

在这里插入图片描述

代码与总结

要基于OpenCV对指针式仪表进行读数,可以采用以下步骤:

  • 读取图像:使用cv2.imread()函数读取图像文件,或从摄像头中实时获取图像。
  • 图像预处理:对图像进行预处理,以便提取出仪表盘的指针和刻度线等关键部分。例如,可以使用cv2.cvtColor()函数将图像转换为灰度图像,然后使用cv2.GaussianBlur()函数进行高斯模糊,以去除噪声。
  • 提取特征:使用OpenCV的特征提取算法,如Canny边缘检测、Hough变换等,找到仪表盘的指针和刻度线等关键部分。
  • 计算角度:通过计算指针与刻度线之间的夹角,即可得到仪表的读数。可以使用cv2.minEnclosingCircle()函数找到指针的中心点,然后计算指针中心点与仪表盘中心点之间的夹角。
  • 显示结果:将读数显示在图像上,并将图像显示出来或保存为文本
import cv2
import numpy as np# 读取图像
img = cv2.imread('meter.jpg')# 图像预处理
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
blur = cv2.GaussianBlur(gray, (5, 5), 0)# 提取特征
edges = cv2.Canny(blur, 50, 200, apertureSize=3)
lines = cv2.HoughLines(edges, 1, np.pi/180, 100)# 找到指针和刻度线
for line in lines:rho, theta = line[0]if theta < np.pi/4 or theta > 3*np.pi/4:x0 = np.cos(theta) * rhoy0 = np.sin(theta) * rhopt1 = (int(x0 + 1000*(-np.sin(theta))), int(y0 + 1000*np.cos(theta)))pt2 = (int(x0 - 1000*(-np.sin(theta))), int(y0 - 1000*np.cos(theta)))cv2.line(img, pt1, pt2, (0, 0, 255), 3)# 计算角度
center = (img.shape[1]//2, img.shape[0]//2)

最后

#联系qq1309399183

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Navicat导入csv数据至mysql

问题 使用Navicat导入csv数据至mysql 详细问题 笔者有已进行数据处理的csv&#xff0c;需要将数据信息导入mysql中 解决方案 步骤1、建立数据表&#xff0c;字段信息&#xff08;最好&#xff09;与csv字段信息保持一致&#xff0c;方便后续导入。 具体的&#xff0c;双击…

基于SpringBoot+Thymeleaf的医院挂号管理系统(有文档、Java毕业设计)

大家好&#xff0c;我是DeBug&#xff0c;很高兴你能来阅读&#xff01;作为一名热爱编程的程序员&#xff0c;我希望通过这些教学笔记与大家分享我的编程经验和知识。在这里&#xff0c;我将会结合实际项目经验&#xff0c;分享编程技巧、最佳实践以及解决问题的方法。无论你是…

C++|44.智能指针

文章目录 智能指针unique_ptr特点一——无法进行复制 shared_ptr特点一——可复制特点二——计数器&#xff08;用于确定删除的时机&#xff09; 其他 智能指针 通常的指针是需要特殊地去申请对应的空间&#xff0c;并在不使用的时候还需要人工去销毁。 而智能指针相对普通的指…

统计学-R语言-3

文章目录 前言给直方图增加正态曲线的不恰当之处直方图与条形图的区别核密度图时间序列图洛伦茨曲线计算绘制洛伦茨曲线所需的各百分比数值绘制洛伦茨曲线 练习 前言 本篇文章是介绍对数据的部分图形可视化的图型展现。 给直方图增加正态曲线的不恰当之处 需要注意的是&#…

NVMe over TCP高性能文件存储,让未来照进现实,400us

你真的懂NVMe吗&#xff1f; 在说NVMe之前&#xff0c;我们觉得有必要先聊一聊NVM&#xff08;Non-Volatile Memory&#xff09;&#xff0c;即非易失性内存。从名字上看就知道&#xff0c;NVM是一种类内存式&#xff08;访问及寻址方式类似&#xff09;的设备&#xff0c;它必…

STM32 SPI通信协议3——读取MAX6675温度传感器

在上两章中&#xff0c;我们已经配置了相应的GPIO和SPI功能。这里说一下MAX6675如何读取温度。 从MAX6675手册中我们可以看到&#xff0c;当0的时候SCK启动&#xff0c;数据线开始发送信息&#xff0c;此时可以读取数据&#xff0c;当数据读完后&#xff0c;再拉高电平停止发送…

VMware workstation安装MX-23.1虚拟机并配置网络

VMware workstation安装MX-23.1虚拟机并配置网络 MX Linux是基于Debian稳定分支的面向桌面的Linux发行&#xff0c;采用Xfce作为缺省桌面&#xff0c;是一份中量级操作系统。该文档适用于在VMware workstation平台安装MX-23.1虚拟机。 1.安装准备 1.1安装平台 Windows 11 …

.nfsxxxxxx文件无法删除

先&#xff1a; sudo apt-get update sudo apt-get install lsof然后&#xff1a; lsof 文件路径 输出&#xff1a; 37012是id号 kill -9 id号 参考文章&#xff1a; 如何删除服务器出现的.nfs文件-CSDN博客 如何删除.nfs00000xxxx文件_.nfs0000000000004cca0000002a-CSDN博…

【MATLAB】MVMD_LSTM神经网络时序预测算法

有意向获取代码&#xff0c;请转文末观看代码获取方式~也可转原文链接获取~ 1 基本定义 MVMD-LSTM神经网络时序预测算法是一种结合了多变量经验模态分解&#xff08;Multivariate Multiscale Decomposition&#xff0c;MMD&#xff09;和长短期记忆神经网络&#xff08;LSTM&a…

虚幻UE 材质-材质编辑器节点 1

之前的几篇文章基本上都是对一些材质名词进行讲解 而这篇文章会对材质编辑器中的常用节点和常用用法进行讲解 文章目录 前言一、Add添加二、BumpOffset凹凸偏移三、Divide划分除法四、Power亮度/对比度五、MaterialFunctionCall材质函数六、If通道提取七、Lerp线性插值八、Mult…

Docker之概述与安装

&#x1f389;&#x1f389;欢迎来到我的CSDN主页&#xff01;&#x1f389;&#x1f389; &#x1f3c5;我是君易--鑨&#xff0c;一个在CSDN分享笔记的博主。&#x1f4da;&#x1f4da; &#x1f31f;推荐给大家我的博客专栏《Docker之概述与安装》。&#x1f3af;&#x1f…

13个自媒体文库平台(附通道链接)

​划到最后“阅读原文” ——进入官网 Hi&#xff0c;大家好&#xff0c;我是胡猛夫&#xff0c;每天分享实用运营工具&#xff01; 更多内容&#xff0c;更多资源&#xff0c;欢迎交流&#xff01; 公 号 | 微视角文化 》》精彩推荐 >>微视角文化知识库&#xff1a;移…

深入理解UML中的继承关系

深入理解UML中的继承关系 在面向对象的设计中&#xff0c;继承关系是构建清晰、可维护系统的关键。统一建模语言&#xff08;UML&#xff09;提供了一种标准化的方法来可视化这些关系。本文将深入探讨UML中的继承关系&#xff0c;并探讨它如何在代码中体现。 什么是继承关系&a…

Selenium的使用

Selenium 是一个自动化测试工具&#xff0c;它主要用于自动化网络应用程序的测试。不过&#xff0c;除了测试之外&#xff0c;它也常用于自动执行各种浏览器操作&#xff0c;比如自动填写表单、抓取网页数据、点击、下拉等。同时还可以获取浏览器当前所呈现的页面的源代码&…

【VRTK】【Unity】【游戏开发】更多技巧

课程配套学习项目源码资源下载 https://download.csdn.net/download/weixin_41697242/88485426?spm=1001.2014.3001.5503 【概述】 本篇将较为零散但常用的VRTK开发技巧集合在一起,主要内容: 创建物理手震动反馈高亮互动对象【创建物理手】 非物理手状态下,你的手会直接…

Vue+ElementUI+Axios实现携带参数的文件上传(数据校验+进度条)

VueElementUIAxios实现携带参数的文件上传&#xff08;数据校验进度条&#xff09; 可以实现对上传文件的类型&#xff0c;大小进行数据校验&#xff0c;以及对上传文件所要携带的数据也进行的校验&#xff0c;也有文件上传进度的进度条。 一、Vue 结构部分 弹窗显示&#xff0…

【服务器数据恢复】服务器硬盘磁头损坏的数据恢复案例

服务器硬盘故障&#xff1a; 一台服务器上raid阵列上有两块硬盘出现故障&#xff0c;用户方已经将故障硬盘送到其他机构检测过&#xff0c;其中一块硬盘已经开盘&#xff0c;检测结果是盘片损伤严重&#xff1b;另一块硬盘尚未开盘&#xff0c;初步判断也存在硬件故障&#xff…

UCB Data100:数据科学的原理和技巧:第十三章到第十五章

十三、梯度下降 原文&#xff1a;Gradient Descent 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 学习成果 优化复杂模型 识别直接微积分或几何论证无法帮助解决损失函数的情况 应用梯度下降进行数值优化 到目前为止&#xff0c;我们已经非常熟悉选择模型和相应损…

机器学习-决策树

1、什么是决策树&#xff1f; 一种描述概念空间的有效的归纳推理办法。基于决策树的学习方法可以进行不相关的多概念学习&#xff0c;具有简单快捷的优势&#xff0c;已经在各个领域取得广泛应用。 决策树是一种树型结构&#xff0c;其中每个内部结点表示在一个属性上的测试&a…

Pandas十大练习题,掌握常用方法

文章目录 Pandas分析练习题1. 获取并了解数据2. 数据过滤与排序3. 数据分组4. Apply函数5. 合并数据6. 数据统计7. 数据可视化8. 创建数据框9. 时间序列10. 删除数据 代码均在Jupter Notebook上完成 Pandas分析练习题 数据集可从此获取&#xff1a; 链接: https://pan.baidu.co…