静态图像分割——水表指针提取(二)

说明

此文为静态图像分割——水表指针提取(一)的续,主要解决指针分割后的图像指针角度问题。

图像摆正

核心代码

I=imread('img4.jpg');  
BW=rgb2gray(I);    
thresh=[0.01,0.10];    
sigma=2; 
f = edge(double(BW),'canny',thresh,sigma);     
title('canny 边缘检测');   
[H, theta, rho]= hough(f,'theta',-89.9:1:89.9); 
peak=houghpeaks(H,5);   
hold on    
lines=houghlines(f,theta,rho,peak,'FillGap',5,'MinLength',20);    
figure(1),imshow(f,[]),hold on    
for k=1:length(lines)                     %画出直线
    xy=[lines(k).point1;lines(k).point2];    
    plot(xy(:,1),xy(:,2),'LineWidth',2,'Color','red');   
end
x=lines(1).point1(1)-lines(1).point2(1);
y=lines(1).point1(2)-lines(1).point2(2);
mm=x*x+y*y;
angle=0;
for i=1:k                                 %寻找最长直线的角度
    x=lines(i).point1(1)-lines(i).point2(1);
    y=lines(i).point1(2)-lines(i).point2(2);
    m=x*x+y*y;
    if(m>=mm)
        mm=m;
        angle=lines(i).theta;
    end
end
i=imread('a4.bmp');
if(angle<0)
    A = imrotate(i,90+angle,'bilinear','crop');
else
    A = imrotate(i,angle-90,'bilinear','crop');
end
figure(2), imshow(A);saveas(2,'44-rotate.jpg');
saveas(1,'44-canny-line.jpg');

实验结果

在这里插入图片描述
在这里插入图片描述

指针角度

思路:先将指针的轮廓标出,然后找到轮廓的质心,再求出轮廓与质心距离,找到距离质心最远的点,最后求出质心与最远点连线的线段角度,根据线段角度计算读数(例如,以0°为0,180°为5)。

轮廓标记代码

filename = sprintf('1.jpg'); 
I = imread(filename);
BW = im2bw(I, graythresh(I));
BW=~BW;
[L,num]=bwlabel(BW,8);
STATS = regionprops(BW,'basic');      %获取轮廓信息,Area、Centroid、BoundingBox
[B,L] = bwboundaries(BW,'noholes');   %寻找边缘  
imshow(label2rgb(L, @jet, [.5 .5 .5])),hold on
 for k = 1:length(B)
     boundary = B{k};
     plot(boundary(:,2), boundary(:,1), 'w', 'LineWidth', 2)  %框轮廓
     for i=1:num
         if((STATS(i).Area>600)&&(STATS(i).Area<2500))
             rectangle('Position',STATS(i).BoundingBox,'Curvature',[0,0],'LineWidth',2,'EdgeColor','r');
             %text命令
             text(STATS(i).Centroid(1),STATS(i).Centroid(2),'pointer','Color','black');
             plot(STATS(i).Centroid(1),STATS(i).Centroid(2), '*');
         end
     end
 end

标记效果

在这里插入图片描述
在这里插入图片描述
从上图标记效果来看,由于初始的指针分割效果不佳,所以无法将每张图的指针区域标记出来,这对想通过上述思路解决问题造成了阻碍。遗憾最后也未能找到无需人工读数的方法,对于拍摄环境复杂的照片,建议人工读数。

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
PaddleOCR是一个开源的OCR(Optical Character Recognition,光学字符识别)工具,可以用于识别图像或文档中的文字内容。而水表数字识别是指利用这个工具对水表上的数字进行自动识别。 水表数字识别在日常生活中具有重要的应用价值,可以方便地获取水表的读数,帮助用户了解自己的用水情况。通过使用PaddleOCR进行水表数字识别,可以实现自动化的数字提取,避免了手动输入的繁琐和可能出现的误差。 使用PaddleOCR进行水表数字识别的步骤包括以下几个方面: 1. 准备数据:首先,需要收集一定数量的水表图片作为训练集。这些图片应包含不同角度、光照条件和数字大小等不同情况,以保证训练模型的泛化能力。 2. 数据预处理:对于收集到的训练集图片,需要进行数据预处理,包括图像增强、尺寸统一等操作,以提升模型的训练效果。 3. 模型训练:利用PaddleOCR提供的训练接口,可以使用训练集对模型进行训练。训练过程中,可以根据需要调整模型的参数和网络结构,以达到更好的识别效果。 4. 模型测试与优化:训练完成后,需要利用测试集对模型进行测试,并根据测试结果对模型进行优化。可以通过调整模型的超参数、增加训练集数量等方式提升模型的准确率。 5. 使用模型进行水表数字识别:完成模型的训练和优化后,就可以将其部署到实际应用中,用于水表数字的识别。用户只需将水表照片输入到模型中,即可快速获取水表的读数。 综上所述,利用PaddleOCR进行水表数字识别可以帮助提高工作效率,实现水表读数自动化,减少了人工操作和错误率,具有广泛的实用价值。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值