码迷,mamicode.com
首页 > 其他好文 > 详细

膨胀和腐蚀 - 解决图像缺陷问题

时间:2019-12-18 21:56:31      阅读:212      评论:0      收藏:0      [点我收藏+]

标签:遍历   插入图片   上进   str   存在   预算   扫描   表示   目录   

腐蚀

故名思义就是将图片向内进行收缩。

技术图片
图1 腐蚀示意图

??设经过背景减后的图像为 B,经过腐蚀运算处理后的图像为 P,用 S 表示所用 3R圆(为进化计算可由采用3x3的矩形来代替) 的结构元素,计算公式如下:

\[ P=B\Theta S= \{x,y | S_{x,y}\subseteq B\} \]
??这里 \(S_{x,y}\) 表示将结构元素的原点移动到点 (x, y) 处。

腐蚀运算的具体过程如下:

??选定结构元素 S 的起点,以该点开始遍历经背景减的图像 B 上的所有像素点;结构元素与其所覆盖范围的所有像素点进行“”操作,若相“与”后的像素值全部为 255,则腐蚀运算后该点的像素值为 255;若像素值不全为 255,则腐蚀运算后该点的像素值为 0。
??常用的结构元素一般都是大小为 3*3 的矩阵算子,由实验可知,对运动图像进行闭运算,可以很好的修补轮廓上的一些缺陷,填充运动对象内部较小的空洞。图2为图像经闭运算处理后的变化。

膨胀

故名思义就是将图片向外延进行收缩。

技术图片
图2 膨胀示意图

??设经过背景减后的图像为 B,经过膨胀运算处理后的图像为 P,用 S 表示所用 3*3 的结构元素,计算公式如下。

\[ P=B\oplus S=\{x,y|S_{x,y}\cap B \ne\varnothing\} \]

??这里,\(S_{x,y}\)表示将结构元素的原点移动到点 (x, y) 处。

??膨胀运算的过程如下:

??首先确定膨胀算子的结构元素 S 的原点,以该原点开始,扫描图像 B 中的所有像素点。把结构元素在图像上进行遍历,把结构元素与其覆盖的像素点进行“与”操作,如果该区域中存在像素值为 255 的点,则经过该操作就把当前点赋为 255,若该区域所有的点的值都是 0,经膨胀操作后该点的值也为 0。

闭运算 && 开运算

??开运算是先后进行腐蚀和膨胀的运算,如果图像中杂散的背景噪声过多时,腐蚀运算消去这些背景噪声,由于在进行腐蚀操作时,被测目标的轮廓也会被腐蚀掉一部分,因此就需要采用膨胀运算对目标轮廓进行恢复。开运算可以消除一些杂散噪声的影响,且可以保证被测目标的轮廓不变形。

??闭运算是采用先膨胀后腐蚀的方式进行的,膨胀运算可以把图像中一些小的断开或者目标区域背部的空洞补齐,然后由腐蚀预算把目标轮廓外围的一些噪声消掉。

闭运算处理以后的图片如下,可以看出,将有缺陷的部分补全。

????????????技术图片 技术图片

??????????????????a)处理之前??????????b)处理以后

图3 闭运算示意图

膨胀和腐蚀 - 解决图像缺陷问题

标签:遍历   插入图片   上进   str   存在   预算   扫描   表示   目录   

原文地址:https://www.cnblogs.com/teaurn/p/12063714.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!