首页/文章/ 详情

大神带你玩转matlab图像处理(6)——Hough变换

7月前浏览9757

本文摘要(由AI生成):

本文主要介绍了图像处理中的Hough变换,包括其基本原理、思想、应用以及与其他边缘检测手段的对比。Hough变换是一种基于特征值提取技术的图像变换方案,通过将图像空间中的点映射到参数空间中的线,从而实现对图像中直线、圆等形状的检测。Hough变换的基本思想是将图像空间中的点对应到参数空间中的线,通过在参数空间中寻找峰值来检测直线。Hough变换在图像处理中有广泛的应用,例如边缘检测、形状识别等。


    近段时间过冷水开始接触一点点图像处理的知识三维空间分布函数绘制实例推文就有关于读取图像上的数据程序处理。所以说有些知识说不定你那天就能够使用到,秉持着“技多不压身”的原则,本期跟随过冷水了解一点点图像处理方面的知识吧!

    为了能够有效的快速对图像进行处理,需要在图像空间的图像以某种形式转换到另一空间,在过冷水的工作中就存在倒易空间和实空间的概念。各空间概念的提出必然有其便捷性。利用空间的特点性质进行图像加工,就是图像转换,比较常见的图像转换方式有:算术计算、几何变换、Hough变换、傅里叶变换、离散变化,本期过冷水重点讲讲Hough变换。

Hough是基于特征值提取技术的图像变换方案。Hough运用两个坐标空间的之间的变换将在一个空间中具有相同形状的曲线或直线映射到另一个坐标空间的一个点上形成峰值,从而把检测任意形状的问题转换为统计峰值问题。

基本原理

Hough变换是利用表决原理的参数轨迹技术,说到参数估计,大家能够想到过冷水做的有关概率统计的推文不?——统计分布讲解。基本原理在于利用图像空间和Hough参数空间点与线的对偶性,把图像空间中检测问题转换为参数空间。通过在参数空间里进行简单的累加统计,然后在Hough参数空间寻找累加器峰值的方法找检测直线。Hough变换的实质是将图像空间内具有一定关系的像元进行聚类,寻找能把这些像元用某一解析形势联系起来的参数空间累计对应点。在参数空间不超过二维的情况下,这种变换效果理想。将原始图像空间的给定的曲线表达形式变为参数空间的一个点,这样就把原始图像中给定曲线的检测问题转化为寻找参数空间的峰值问题,也就是把检测整体特性转化为检测局部特性,例如直线、椭圆、圆、弧线等。

简而言之,Hough变换思想是:在原始图像坐标系下的一个点对应了参数坐标系中的一条直线同样参数坐标系的一条直线对应原始坐标系下的一个点,然后,标系下呈现直线的所有点,它们的斜率和截距是相同的,所以它们在参数坐标系下对应于同一个点。这样在原始坐标系下的各个点的投影到多数坐标系下之后,看参数坐标系下没有聚集点,这样的聚集点就对应了原始坐标系下的直线。
     
在图像处理中,从图像中识别几何形状的基本方法之一是Hough变换,它有很多改进算法。最基本的Hough变换是从黑白图像中检测直线。广义的Hough变换已经不仅仅局限于提取直线,二值任意可以用表达式表达的曲线都可以提取,例如圆、椭圆、正弦余弦曲线等。曲线越是复杂.所需参数越多,运算的时间也就越多。Hough 变换的精髓在于投票算法,将图像空间转换到参数空间进行求解。假如已知黑白图像上画了一 条直线,要求出这条 直线所在的位置。直线的方程用y=kx b来表示,其中kb是参数,分别是斜率和截距,过某一点(x0,y0)的所有直线的参数都会满足方程y0=kx0 b,即点(x0,y0)确定了一组直线。方程y0=kx0 b在参数k-b平面上是一条直线,这样,图像x-y平面上的一个像素点就对应到参数k-b平面上的一条直线Hough变换的基本思想就是把图像平面上的点对应到参数平面上的线。在实际应用中,y=kx b形式的直线方程没有办法表示x=c形式的直线。

Hough进行边缘检测

图片


图片

clear 
f=imread('11.jpg'); %读入彩色图像,注意不能使用灰度图像
o=f; %保留彩色原图
f=rgb2gray(f); %将彩色图像转换为灰度图像,[检查下看能否运行,给的代码里没有这个程序。没有运行结果]
f=im2double(f);
figure();
subplot(231);
imshow(o);
title('原图');
[m,n]=size(f); %得到图像矩阵行数m,列数n
for i=3:m-2 
    for j=3:n-2 %处理领域较大,所以从图像(3,3)开始,在(m-2,n-2)结束 
        %LoG算子 
        l(i,j)=-f(i-2,j)-f(i-1,j-1)-2*f(i-1,j)-f(i-1,j 1)-f(i,j-2)-2*f(i,j-1) 16*f(i,j)-2*f(i,j 1)...
            -f(i,j 2)-f(i 1,j-1)-2*f(i 1,j)-f(i 1,j 1)-f(i 2,j); 
    end
end
subplot(232);imshow(l);title('LoG算子提取图像边缘');
%均值化滤波处理
[m,n]=size(l);
for i=2:m-1 
    for j=2:n-1 
        %LoG算子提取边缘后,对结果进行均值滤波以去除噪声,为下一步hough变换提取直线作准备 
        y(i,j)=l(i-1,j-1) l(i-1,j) l(i-1,j 1) l(i,j-1) l(i,j) l(i,j 1) l(i 1,j-1) l(i 1,j) l(i 1,j 1); 
        y(i,j)=y(i,j)/9; 
    end
end
subplot(233);imshow(y);title('均值滤波器处理后')
%二值化处理
q=im2uint8(y);
[m,n]=size(q);
for i=1:m 
    for j=1:n 
        if q(i,j)>80; %设置二值化的阈值为80 
            q(i,j)=255; %对图像进行二值化处理,使图像边缘更加突出清晰 
        else q(i,j)=0; 
        end
    end
end
subplot(234);imshow(q);title('二值化处理后');
%Hough变换检测直线,使用(a,p)参数空间,a∈[0,180],p∈[0,2d])
a=180; %角度的值为0到180度
d=round(sqrt(m^2 n^2)); %图像对角线长度为p的最大值
s=zeros(a,2*d); %存储每个(a,p)个数
z=cell(a,2*d); %用元胞存储每个被检测的点的坐标
for i=1:m 
    for j=1:n %遍历图像每个点 
        if(q(i,j)==255) %只检测图像边缘的白点,其余点不检测 
            for k=1:a %对每个点从1到180度遍历,取得经过该点的所有直线的p值 
                p = round(i*cos(pi*k/180) j*sin(pi*k/180)); %若p大于0,则将点存储在(d,2d)空间 
                if(p > 0) 
                    s(k,d p)=s(k,d p) 1; %(a,p)相应的累加器单元加1 
                    z{k,d p}=[z{k,d p},[i,j]']; %存储点坐标 
                else
                    ap=abs(p) 1; %若p小于0,则将点存储在(0,d)空间 
                    s(k,ap)=s(k,ap) 1; %(a,p)相应的累加器单元加一 
                    z{k,ap}=[z{k,ap},[i,j]'];%存储点坐标 
                end
            end
        end
    end
end
for i=1:a 
    for j=1:d*2 %检查每个累加器单元中存储数量 
        if(s(i,j) >35) %将提取直线的阈值设为35 
            lp=z{i,j}; %提取对应点坐标 %对满足阈值条件的累加器单元中(a,p)对应的所有点进行操作 
            for k=1:s(i,j) 
                o(lp(1,k),lp(2,k),1)=255; %每个点R分量=255,G分量=0,B分量=0 
                o(lp(1,k),lp(2,k),2)=0; 
                o(lp(1,k),lp(2,k),3)=0; %为满足阈值要求的直线上的点赋红色 
            end
        end
    end
end
subplot(235);imshow(o);title('hough变换提取边界直线');




    该代码案例还包含了其它边缘检测的手段,本文没有提及 方式可以查看过冷水的相关推文。本期过冷水就重点讲讲Hough变换,对图像变换其它问题感兴趣的可以留言共同探讨


代码&命令其他软件MATLAB理论科普
著作权归作者所有,欢迎分享,未经许可,不得转载
首次发布时间:2021-03-16
最近编辑:7月前
过冷水
博士 | 讲师 讨论号:927550334
获赞 361粉丝 184文章 107课程 11
点赞
收藏
作者推荐

免费 5.0
未登录
1条评论
金浩
签名征集中
1年前
程序中提示确实的运算符为+,请注意
回复
课程
培训
服务
行家
VIP会员 学习 福利任务 兑换礼品
下载APP
联系我们
帮助与反馈