本篇文章要分享的是基于MATLAB的腐蚀膨胀算法实现,腐蚀膨胀是形态学图像处理的基础,腐蚀在二值图像的基础上做“收缩”或“细化”操作,膨胀在二值图像的基础上做“加长”或“变粗”的操作。

  什么是二值图像呢?把一幅图片看做成一个二维的数组,那么二值图像是一个只有0和1的逻辑数组,我们前面Sobel边缘检测后的图像输出边缘效果,设置个阈值,大于阈值输出为1,小于阈值输出为0,最后输出就是一幅二维图像了。

腐蚀

  腐蚀是一种消除边界点,使边界向内部收缩的过程。可以用来消除小且无意义的物体。用3X3的结构元素,扫描图像的每一个像素,用结构元素与其覆盖的二值图像做“与”操作,如果都为1,结果图像的该像素为1。否则为0。结果会使二值图像小一圈。

  有一个形象的比喻来可以说明该运算,用0表示蛀虫,1表示大米。蛀虫腐蚀大米的过程便是腐蚀运算,

腐蚀

  如图所示,对于一个像素矩阵而言,只要有蛀虫(0)的存在,大米(1)就会被腐蚀掉了,即使只存在一个蛀虫(0),但是还是会被蛀虫腐蚀完毕,最后一幅图上面由于没有蛀虫(0)所以大米完好无损。

关于算法的实现,可以用下式子来表示,即3x3像素的运算:

P = P11 & P12 & P13 & P21 & P22 & P23 & P31 & P32 & P33

在FPGA中,为了通过面积去换速度,我们将上式改变如下:                       

P1 = P11 & P12 & P13

P2 = P21 & P22 & P23

P3 = P31 & P32 & P33

P = P1 & P2 & P3

MATLAB中可以直接写一个按位或运算。

膨胀

  膨胀是将与物体接触的所有背景点合并到该物体中,使边界向外部扩张的过程。可以用来填补物体中的空洞。用3X3的结构元素,扫描图像的每一个像素,用结构元素与其覆盖的二值图像做“与”操作,如果都为0,结果图像的该像素为0,。否则为1。结果使二值图像扩大一圈。

  先腐蚀后膨胀的过程称为开运算。用来消除小物体、在纤细点处分离物体、平滑较大物体的边界的同时并不明显的改变其面积。先膨胀后腐蚀的过程称为比运算,用来填充物体内细小空间、连接邻近物体、平滑其边界的同时并不明显改变其面积。

  膨胀算法用最简单的比喻来描述:0表示害虫,1表示青蛙,青蛙吃了害虫表示膨胀运算,我们用3*3像素阵列来解释:

膨胀

  如图所示,图左只有害虫(0),所以害虫都活着,中间那个图,虽然只有一个害虫,但是还是会被青蛙全部吃掉,最右边的那幅图,都是青蛙,所以青蛙始终是青蛙。

关于算法的实现,可以用下式子来表示,即3x3像素的运算:

P = P11 | P12 | P13 | P21 | P22 | P23 | P31 | P32 | P33

在HDL中,为了通过面积去换速度,我们将上式改变如下:                             

P1 = P11 | P12 | P13

P2 = P21 | P22 | P23

P3 = P31 | P32 | P33

P = P1 | P2 | P3

MATLAB中可以直接写一个按位与运算。

开运算闭运算

  先腐蚀后膨胀叫开运算,开运算的作用是清除图像边缘周围非边缘的细小的点。先膨胀后腐蚀为闭运算,闭运算的作用是清除图像内部的空洞,

  如果我们的目标物体外面有很多无关的小区域,就用开运算去除掉;如果物体内部有很多小黑洞,就用闭运算填充掉。

MATLAB逻辑运算函数

bitand(), 对十进制数进行逐位逻辑与运算:先将十进制数转换成二进制数,然后逐位与运算,其运算结果转换为十进制。

bitor(), 对十进制数进行逐位逻辑或运算:先将十进制数转换成二进制数,然后逐位与运算,其运算结果转换为十进制。

MATLAB代码实现

 %RGB_YCbCr
clc;
clear all;
close all; RGB_data = imread('lena.jpg'); R_data = RGB_data(:,:,);
G_data = RGB_data(:,:,);
B_data = RGB_data(:,:,); %imshow(RGB_data); [ROW,COL, DIM] = size(RGB_data); Y_data = zeros(ROW,COL);
Cb_data = zeros(ROW,COL);
Cr_data = zeros(ROW,COL);
Gray_data = RGB_data; for r = :ROW
for c = :COL
Y_data(r, c) = 0.299*R_data(r, c) + 0.587*G_data(r, c) + 0.114*B_data(r, c);
Cb_data(r, c) = -0.172*R_data(r, c) - 0.339*G_data(r, c) + 0.511*B_data(r, c) + ;
Cr_data(r, c) = 0.511*R_data(r, c) - 0.428*G_data(r, c) - 0.083*B_data(r, c) + ;
end
end Gray_data(:,:,)=Y_data;
Gray_data(:,:,)=Y_data;
Gray_data(:,:,)=Y_data; figure;
imshow(Gray_data); %Median Filter
imgn = imnoise(Gray_data,'salt & pepper',0.02); figure;
imshow(imgn); Median_Img = Gray_data;
for r = :ROW-
for c = :COL-
median3x3 =[imgn(r-,c-) imgn(r-,c) imgn(r-,c+)
imgn(r,c-) imgn(r,c) imgn(r,c+)
imgn(r+,c-) imgn(r+,c) imgn(r+,c+)];
sort1 = sort(median3x3, , 'descend');
sort2 = sort([sort1(), sort1(), sort1()], 'descend');
sort3 = sort([sort1(), sort1(), sort1()], 'descend');
sort4 = sort([sort1(), sort1(), sort1()], 'descend');
mid_num = sort([sort2(), sort3(), sort4()], 'descend');
Median_Img(r,c) = mid_num();
end
end figure;
imshow(Median_Img); %Sobel_Edge_Detect Median_Img = double(Median_Img);
Sobel_Threshold = ;
Sobel_Img = zeros(ROW,COL); for r = :ROW-
for c = :COL-
Sobel_x = Median_Img(r-,c+) + *Median_Img(r,c+) + Median_Img(r+,c+) - Median_Img(r-,c-) - *Median_Img(r,c-) - Median_Img(r+,c-);
Sobel_y = Median_Img(r-,c-) + *Median_Img(r-,c) + Median_Img(r-,c+) - Median_Img(r+,c-) - *Median_Img(r+,c) - Median_Img(r+,c+);
Sobel_Num = abs(Sobel_x) + abs(Sobel_y);
%Sobel_Num = sqrt(Sobel_x^ + Sobel_y^);
if(Sobel_Num > Sobel_Threshold)
Sobel_Img(r,c)=;
else
Sobel_Img(r,c)=;
end
end
end figure;
imshow(Sobel_Img); %imopen Erosion_Dilation
%Erosion
% Erosion_img = zeros(ROW,COL);
% for r = :ROW-
% for c = :COL-
% and1 = bitand(Sobel_Img(r-, c-), bitand(Sobel_Img(r-, c), Sobel_Img(r-, c+)));
% and2 = bitand(Sobel_Img(r, c-), bitand(Sobel_Img(r, c), Sobel_Img(r, c+)));
% and3 = bitand(Sobel_Img(r+, c-), bitand(Sobel_Img(r+, c), Sobel_Img(r+, c+)));
% Erosion_img(r, c) = bitand(and1, bitand(and2, and3));
% end
% end % figure;
% imshow(Erosion_img); % %Dilation
% Dilation_img = zeros(ROW,COL);
% for r = :ROW-
% for c = :COL-
% or1 = bitor(Erosion_img(r-, c-), bitor(Erosion_img(r-, c), Erosion_img(r-, c+)));
% or2 = bitor(Erosion_img(r, c-), bitor(Erosion_img(r, c), Erosion_img(r, c+)));
% or3 = bitor(Erosion_img(r+, c-), bitor(Erosion_img(r+, c), Erosion_img(r+, c+)));
% Dilation_img(r, c) = bitor(or1, bitor(or2, or3));
% end
% end % figure;
% imshow(Dilation_img); %imclose Erosion_Dilation
%Dilation
Dilation_img = zeros(ROW,COL);
for r = :ROW-
for c = :COL-
or1 = bitor(Sobel_Img(r-, c-), bitor(Sobel_Img(r-, c), Sobel_Img(r-, c+)));
or2 = bitor(Sobel_Img(r, c-), bitor(Sobel_Img(r, c), Sobel_Img(r, c+)));
or3 = bitor(Sobel_Img(r+, c-), bitor(Sobel_Img(r+, c), Sobel_Img(r+, c+)));
Dilation_img(r, c) = bitor(or1, bitor(or2, or3));
end
end figure;
imshow(Dilation_img); %Erosion
Erosion_img = zeros(ROW,COL);
for r = :ROW-
for c = :COL-
and1 = bitand(Dilation_img(r-, c-), bitand(Dilation_img(r-, c), Dilation_img(r-, c+)));
and2 = bitand(Dilation_img(r, c-), bitand(Dilation_img(r, c), Dilation_img(r, c+)));
and3 = bitand(Dilation_img(r+, c-), bitand(Dilation_img(r+, c), Dilation_img(r+, c+)));
Erosion_img(r, c) = bitand(and1, bitand(and2, and3));
end
end figure;
imshow(Erosion_img);

处理后结果对比

为了可以清晰的看到图像边缘的变化,我们把黑色作为背景,白色作为边缘。

Sobel边缘检测后的lena

腐蚀后的lena

膨胀后的lena

先腐蚀后膨胀开运算lena

先膨胀后腐蚀闭运算lena

  从上面两幅图可以看出,腐蚀后的图像边缘明显变细,消除了更多假边缘,在腐蚀基础上使用膨胀算法的lena将腐蚀后的边缘扩大、加粗,这样看起来更清楚。

转载请注明出处:NingHeChuan(宁河川)

个人微信订阅号:开源FPGA

如果你想及时收到个人撰写的博文推送,可以扫描左边二维码(或者长按识别二维码)关注个人微信订阅号

知乎ID:NingHeChuan

微博ID:NingHeChuan

原文地址:https://www.cnblogs.com/ninghechuan/p/9527915.html

基于MATLAB的腐蚀膨胀算法实现的更多相关文章

  1. 基于FPGA的腐蚀膨胀算法实现

    本篇文章我要写的是基于的腐蚀膨胀算法实现,腐蚀膨胀是形态学图像处理的基础,,腐蚀在二值图像的基础上做"收缩"或"细化"操作,膨胀在二值图像的基础上做" ...

  2. 基于MATLAB的人脸识别算法的研究

    基于MATLAB的人脸识别算法的研究 作者:lee神 现如今机器视觉越来越盛行,从智能交通系统的车辆识别,车牌识别到交通标牌的识别:从智能手机的人脸识别的性别识别:如今无人驾驶汽车更是应用了大量的机器 ...

  3. 基于MATLAB的Sobel边缘检测算法实现

    图像边缘就是图像灰度值突变的地方,也就是图像在该部分的像素值变化速度非常之快,就比如在坐标轴上一条曲线有刚开始的平滑突然来个大转弯,在变化出的导数非常大. Sobel算子主要用作边缘检测,它是一离散型 ...

  4. 【zz】matlab 腐蚀膨胀算法

    1.图像膨胀的Matlab实现: 可以使用imdilate函数进行图像膨胀,imdilate函数需要两个基本输入参数,即待处理的输入图像和结构元素对象.结构元素对象可以是strel函数返回的对象,也可 ...

  5. 基于MATLAB的均值滤波算法实现

    在图像采集和生成中会不可避免的引入噪声,图像噪声是指存在于图像数据中的不必要的或多余的干扰信息,这对我们对图像信息的提取造成干扰,所以要进行去噪声处理,常见的去除噪声的方法有均值滤波.中值滤波.高斯滤 ...

  6. [ZZ] 基于Matlab的标记分水岭分割算法

    基于Matlab的标记分水岭分割算法 http://blog.sina.com.cn/s/blog_725866260100rz7x.html 1 综述 Separating touching obj ...

  7. 数字图像处理:基于MATLAB的车牌识别项目 标签: 图像处理matlab算法 2017-06-24 09:17 98人阅读 评论(0)

    学过了数字图像处理,就进行一个综合性强的小项目来巩固一下知识吧.前阵子编写调试了一套基于MATLAB的车牌识别的项目的代码.今天又重新改进了一下代码,识别的效果好一点了,也精简了一些代码.这里没有使用 ...

  8. 数学软件 之 基于MATLAB的DFP算法

    DFP算法是本科数学系中最优化方法的知识,也是无约束最优化方法中非常重要的两个拟Newton算法之一,上一周写了一周的数学软件课程论文,姑且将DFP算法的实现细节贴出来分享给学弟学妹参考吧,由于博客不 ...

  9. 基于MATLAB的手写公式识别(5)

    基于MATLAB的手写公式识别 总结一下昨天一天的工作成果: 获得了大致的识别过程. 一个图像从生肉到可以被处理需要经过预处理(灰质化.增加对比度.中值过滤.膨胀或腐蚀.闭环运算). 掌握了相关函数的 ...

随机推荐

  1. 26.mysql日志

    26.mysql日志mysql日志包括:错误日志.二进制日志.查询日志.慢查询日志. 26.1 错误日志错误日志记录了mysqld启动到停止之间发生的任何严重错误的相关信息.mysql故障时应首先查看 ...

  2. Oracle_PL/SQL(6) 触发器(序列、视图)

    序列1.创建序列create sequence seq_alog start with 1 increment by 1 maxvalue 999999999999999999999999999 mi ...

  3. Oracle_SQL(1) 基本查询

    1.oracle的安装与卸载 2.PL/SQL Developer的安装 3.登陆PL/SQL Developer 4.SCOTT用户下表的介绍 5.基本查询语句 查询雇员的所有信息: select ...

  4. 3A - Holding Bin-Laden Captive!

    We all know that Bin-Laden is a notorious terrorist, and he has disappeared for a long time. But rec ...

  5. Liunx cp

    功能: 复制文件或目录 使用权限:所有使用者说明: cp指令用于复制文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则它会把前面指定的所有文件或目录复制到此目录中.若同 ...

  6. DOM-设置样式心得

    一.style属性的设置和获取 style是一个对象,不能通过内嵌或外链获取,也就是只有是行内式的时候才能打印显示 style本身是一个对象 属性的值是字符串,没有赋值的情况下是"" ...

  7. IDEA 的 Edit 设置

    1.设置鼠标悬浮提示 General -- Show quick documentation on mouse move 2.自动导包 3.设置显示行号和方法的间隔符 4.忽略大小写  4.设置取消单 ...

  8. iOS.FileSystem.HardLinkAndSymbolicLink

    关于iOS中的硬连接和符号连接(软连接),iOS其实是Unix的变体, 所以在这方面也继承了Unix的特性,下面这个连接比较详细的进行了 类比说明. 1. http://www.tanhao.me/p ...

  9. POJ1966 Cable TV Network

    原题链接 割去点使得无向图不连通,和最小割相似. 我们可以将点转化成边,这样就能跑最小割了. 枚举每两个不能直接到达的点\(S,T\),使得删去一些点(除去这两个点)使得这两个点不连通(若两点能直接到 ...

  10. ASP.NET 在OnClientClick中js方法直接调用Eval绑定字段的数据

    最近有一项目中使用到了asp.net的GridView控件.需要在前端被点击某一行数据时,前端获取到改行后台绑定的数据序列号.遍用<%# Bind("ID) %>.<%# ...