图像的腐蚀和膨胀_第1页
图像的腐蚀和膨胀_第2页
图像的腐蚀和膨胀_第3页
图像的腐蚀和膨胀_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、.图像的腐蚀和膨胀研究背景和意义依据数学形态学集合论方法发展起来的图像处理方法,在数字图像处理和机器视觉领域中得到了广泛的应用,形成了一种独特的数字图像分析和理论。数学形态学是图像处理和模式识别领域的新方法,其基本的思想是:用具有一定形态的结构元素去度量和提取图像中的对应形状,已达到图像分析和识别的目的。优势有一下几点:有效滤除噪声,保留图像中原有信息,算法很容易用并行处理方法有效实现,基于数学形态学的边缘信息提取处理优于基于微分运算的边缘提取算法,提取的边缘比较平滑,提取的图像骨架也比较连续,断点很少。二原理特殊领域运算形式结构元素,在每个像素位置上与二值图像对应的区域进行特定的逻辑运算。运

2、算结果是输出图像的相应像素。运算效果取决于结构元素大小、内容以及逻辑运算性质。结构元素:膨胀和腐蚀操作的最基本组成部分,用于测试输出图像,通常要比待处理的图像小的多。二维平面结构元素由一个数值为0或1的矩阵组成。结构元素的原点(锚点)指定了图像中需要处理的像素范围,结构元素中数值为1的点决定结构元素的领域像素在进行膨胀或腐蚀操作时是否需要参与计算。常见的形态学运算有腐蚀和膨胀两种:腐蚀:删除对象边缘某些像素。膨胀:给图像中的对象边缘添加像素。三算法及效果图膨胀算法:用3X3的结构元素扫描图像的每一个像素,用结构元素与其覆盖的二值图像做“与”操作,如果都为0,结果图像的该像素点为0,否则为1。膨

3、胀算法的效果是使二值图像扩大一圈。腐蚀的算法:用3X3的结构元素,扫描图像的每一个像素点,用结构元素与其覆盖的二值图像做“与”操作,如果结果都为1,结果图像的该像素点为1,否则为0。膨胀算法的结果:是二值图像减少一圈。四组合使用效果先腐蚀后膨胀的过程:利用它可以消除小物体,在纤细点处分离物体,平滑较大物体边界,但同时并不会明显改变原来物体的面积。先膨胀后腐蚀的过程:利用它可以填充物体内细小空洞,连接临近物体、平滑其边界,但同时并不会明显改变原来物体的面积。通常由于噪声的影响,图像在阈值化后所得到的边界通常都很不平滑,物体区域具有一些噪声孔,而背景区域上散布着一些小的噪声物体,连续的开和闭运算可

4、以有效的改善这种情况。而有时,我们需要经过多次腐蚀,然后再加上相同次数的膨胀,才能产生比较好的处理效果。可见图像的腐蚀与膨胀相结合有时可以使图像有较理想的处理效果。图像处理分为多种,对于不同的图像腐蚀和膨胀的定义不同。1. 形态学图像处理是在图像中移动一个结构元素,然后将结构元素与下面的二值图像进行交、并等集合运算;先腐蚀后膨胀的过程称为开运算。它具有消除细小物体,在纤细处分离物体和平滑较大物体边界的作用。先膨胀后腐蚀的过程称为闭运算。它具有填充物体内细小空洞,连接邻近物体和平滑边界的作用。2. 对灰度图像的膨胀(或腐蚀)操作有两类效果:(1)如果结构元素的值都为正的,则输出图像会比输入图像亮

5、(或暗);(2)根据输入图像中暗(或亮)细节的灰度值以及它们的形状相对于结构元素的关系,它们在运算中或被消减或被除掉。using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Windows.Forms;using System.Drawing.Imaging;using System.Runtime.InteropServices

6、;namespace WindowsFormsApplication2 public partial class Form1 : Form public Form1() InitializeComponent(); private void LockUnlockBitsExample(PaintEventArgs e) /Create a new bitmap Bitmap bmp = new Bitmap(house.jpg); /Lock the bitmaps bits Rectangle rect = new Rectangle(0, 0, bmp.Width, bmp.Height)

7、; BitmapData bmpData = bmp.LockBits(rect, ImageLockMode.ReadWrite, bmp.PixelFormat); /Get the address of the fist line IntPtr ptr = bmpData.Scan0; /Declare an array to hold the bytes of the bitmap int bytes = Math.Abs(bmpData.Stride) * bmp.Height; byte rgbValues = new bytebytes; /Copy the RGB values into the array Marshal.Copy(ptr, rgbValues, 0, bytes); /Set every third value to 255. A 24bpp bitmap will look red for (int counter = 2; counter rgbValues.Length; counter += 3 ) rgbValuescounter = 255; /Copy the RGB values back to the bitmap Marshal.Copy(rgbValu

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论