计算机视觉(7)————特征检测(边缘/角/斑点)小专题(1)线段检测

前言

边缘检测是检测图像特性发生变化的位置。不同的图像灰度不同,边界处会有明显的边缘,利用此特征可以分割图像。边缘检测分割法是通过检测出不同区域边界来进行分割的。边缘总是以强度突变的形式出现,可以定义为图像局部特性的不连续性,如灰度的突变和纹理结构的突变等。图像的边缘包含了物体形状的重要信息,它不仅在分析图像时大幅度地减少了要处理的信息量,而且还保护了目标的边界结构。

边缘检测是利用物体和背景在某种图像特性上的差异来实现的。常见的边缘检测方法有微分算子、Canny 算子和LOG 算子等。常用的微分算子有 Sobel 算子、Roberts 算子和 Prewit 算子等。

1.线段检测

1.1 代码

主函数

set(0,'defaultfigurecolor','w')
I=imread('gantrycrane.png');
figure(1)
imshow(I)
saveas(gcf,'原始图像','jpg')
I=rgb2gray(I);
h1=[-1, -1, -1; 2, 2, 2; -1, -1, -1];
I1=uint8(zeros(size(I,1),size(I,2)));
for i=1+1:size(I,1)-1
    for j=1+1:size(I,2)-1
        I1(i,j)=chengzi(h1,I(i-1:i+1,j-1:j+1));
    end
end
figure(2)
subplot(2,2,1)
imshow(I1)
title('水平线段')
h2=[-1, -1, 2; -1, 2, -1; 2, -1, -1];
I2=uint8(zeros(size(I,1),size(I,2)));
for i=1+1:size(I,1)-1
    for j=1+1:size(I,2)-1
        I2(i,j)=chengzi(h2,I(i-1:i+1,j-1:j+1));
    end
end
subplot(2,2,2)
imshow(I2)
title('+45°线段')
h3=[-1, 2, -1; -1, 2, -1; -1, 2, -1];
I3=uint8(zeros(size(I,1),size(I,2)));
for i=1+1:size(I,1)-1
    for j=1+1:size(I,2)-1
        I3(i,j)=chengzi(h3,I(i-1:i+1,j-1:j+1));
    end
end
subplot(2,2,3)
imshow(I3)
title('垂直线段')
h4=[2, -1, -1; -1, 2, -1; -1, -1, 2];
I4=uint8(zeros(size(I,1),size(I,2)));
for i=1+1:size(I,1)-1
    for j=1+1:size(I,2)-1
        I4(i,j)=chengzi(h4,I(i-1:i+1,j-1:j+1));
    end
end
subplot(2,2,4)
imshow(I4)
title('-45°线段')
saveas(gcf,'线段检测','jpg')

相关计算函数

function s=chengzi(A,B)
A=double(A);
B=double(B);
s=0;
for i=1:size(A,1)
    for j=1:size(A,2)
        s=s+A(i,j)*B(i,j);
    end
end
end

1.2计算结果

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

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

leetteel

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值