【数字图像处理】【Matlab】【实验五】形态学图像处理

news/2025/1/22 19:19:55/

author:zox
实验环境:Matlab2019a


形态学图像处理

  • 一、实验目的
  • 二、实验题目
  • 三、实验内容
    • 3.1 相关知识
      • 1、形态处理学
      • 2、形态学去噪
      • 3、腐蚀原理
      • 4、膨胀原理
      • 5、开闭运算
      • 6、实验中直接使用的函数
    • 3.2 实验代码
      • 【sy5.m】
      • 【mycorrode.m】
      • 【myswell.m】
      • 【myopen.m】
      • 【myclose.m】
    • 3.3 实验结果
  • 四、实验心得

一、实验目的

  1. 了解形态学的基本理论和方法。
  2. 掌握对图像进行膨胀、腐蚀的方法。
  3. 掌握开闭运算。

二、实验题目

  1. 采用形态学处理方法实现图像去噪。
  2. 对图像分割实验(实验四)得到的分割结果进行形态学处理,对肺部区域的空洞进行填充。

三、实验内容

3.1 相关知识

1、形态处理学

  基本思想: 用一定形态的结构元素去量度和提取图像中的对应形状, 达到分析和识别目的。可用于图像处理的各个方面, 包括图像分割、特征抽取、边界检测等。对图像处理的理论和技术产生了重大影响,已经构成一种新的图像处理方法和理论,成为一个重要研究领域。
  这门学科在计算机文字识别, 计算机显微图像分析, 医学图像处理,工业检测等方面都取得了非常成功的应用。形态学方法已成为图像应用领域工程技术人员的必备工具。目前,有关数学形态学的技术和应用正在不断地研究和发展。
  二值形态学中的运算对象是集合。设X为图像集合, B为结构元素, 数学形态学运算是用B对X进行操作。其中结构元素本身也是一个图像集合。

2、形态学去噪

  基于形态学的方法有很多,比如腐蚀膨胀开运算闭运算就是形态学运算最基本的运算,在本次实验中我们就使用这几种运算来对有噪声的指纹图像进行去噪。
  除此之外在数学形态学图像去噪的过程中,通过适当地选取结构元素的形状和维数可以提高滤波去噪的效果。在多结构元素的级联过程中,需要考虑到结构元素的形状和维数。数字图像在进行数学形态滤波去噪时,根据噪声特点可以尝试采用维数由小到大的结构元素来进行处理,进而达到滤除不同噪声的目的。采用数学形态学的多结构元素,可以更多地保持数字图像的几何特征。比如构建串联滤波器来进行图像滤波,就是将同一形状的结构元素按维数从小到大的顺序来对图像进行滤波。

3、腐蚀原理

  图像腐蚀的基本思想是将图像X中每一与结构元素B全等的子集S+x收缩为点x。具体就是比较S+x与结构元素B的像素,当完全相同时就保留像素点x,否则就删除该点(即将该点转换为背景色),对图像X的所有点处理完即完成了一次腐蚀过程。公式如下:
S = X ⊗ B = x , y ∣ B x y ⊆ X S=X\otimes B={x,y|B_{xy}\subseteq X} S=XB=x,yBxyX

  对图像腐蚀能够消除物体边界点,使边界向内部收缩,可以把小于结构元素的物体去除。如果两个物体之间有细小的连通,当结构元素足够大时,可以将两个物体分开。
  根据结构元素的不同,通常将腐蚀分为水平腐蚀、竖直腐蚀、全方向腐蚀,本次实验中自编写的代码使用的是全方向腐蚀的结构元素。

4、膨胀原理

  图像膨胀的基本思想是对二值化图像的边界点扩充, 将X中的每一个点x扩大为B+x,将与物体接触的所有背景点合并到该物体中, 使边界向外部扩张。具体就是比较S+x与结构元素B的像素,只要有一个相同就就保留像素点x,否则处理为背景色。公式如下:
S = X ⊕ B = x , y ∣ B x y ∩ X ≠ ∅ S=X\oplus B={x,y|B_{xy}\cap X\neq\emptyset} S=XB=x,yBxyX=
  对图像膨胀操作可填充图像中的小孔(比结构元素小的孔洞)及图像边缘处的小凹陷部分。如果两个物体之间的距离比较近,会把两个物体连通到一起。对填补图像分割后物体中的空洞有用。
膨胀和腐蚀并不互为逆运算,可以级连结合使用。

5、开闭运算

  开运算就是使用同一个结构元素先对图像进行腐蚀然后膨胀。
  开运算能够去除孤立的小点,毛刺和小桥(即连通两块区域的小点), 消除小物体、平滑较大物体的边界,同时并不明显改变其面积。不过这一恢复不是信息无损的,即它们通常不等于原始图像。
开运算的公式为: S = X ∘ B = ( X ⊗ B ) ⊕ B S=X\circ B=(X\otimes B)\oplus B S=XB=(XB)B

  闭运算就是使用同一个结构元素先对图像进行膨胀然后腐蚀。
  闭运算用来填充物体内细小空洞、连接邻近物体、平滑其边界,同时不明显改变其面积。
闭运算的公式为: S = X ∙ B = ( X ⊕ B ) ⊗ B S=X\bullet B=(X⊕B)⊗B S=XB=(XB)B

6、实验中直接使用的函数

(1)imread(path)函数:从图像所在路径读取图像的数据信息存为矩阵。
(2)imshow(image)函数:将读取到的图像显示到figure中。
(3)subplot(m,n,p)函数
subplot函数是将多个图画到一个平面上的工具。其中m、n表示一个m行n列的大画框,可显示 m ∗ n m*n mn个图 ,p表示图所在位置。
(4)构造函数
function[输出形参]=函数名([输入形参])
函数体
(5)size()函数
[m,n] = size(X)
返回矩阵X的尺寸信息, 并存储在m、n中。其中m中存储的是行数,n中存储的是列数。
(6)zeros(m,n)函数:产生 m ∗ n m*n mn的double类型零矩阵。
(7)im2bw(x):二值化(即转化为逻辑值)。
(8)sum():求和
(9)nargin:判断函数输入参数的数目参数。用于控制函数如果没有输入这个参数可使用函数默认的,或者根据不同的参数有不同的选择,使得自编写的函数功能更加完善。

3.2 实验代码

【sy5.m】

clear all;close all;clc;
%% 1、采用形态学处理方法实现图像去噪。
I=imread('Fig0911(a).tif');
model=[0,1,0;1,1,1;0,1,0];  %定义3×3模板(背景色为黑色)
I1=myswell(I,model);%膨胀
I2=myclose(I1,model,5);%闭运算
I3=mycorrode(I2,model,2);%腐蚀
I4=myopen(I3,model,5);%开运算
I5=myswell(I4,model);%膨胀
figure,suptitle('指纹去噪');     %Figure 1
subplot(231),imshow(I),axis on,title('指纹(有噪声)'); 
subplot(232),imshow(I1),axis on,title('膨胀1次');
subplot(233),imshow(I2),axis on,title('闭运算5次');
subplot(234),imshow(I3),axis on,title('腐蚀2次'); 
subplot(235),imshow(I4),axis on,title('开运算5次');
subplot(236),imshow(I5),axis on,title('膨胀1次');
%% 2、对图像分割实验(实验四)得到的分割结果进行形态学处理,对肺部区域的空洞进行填充。
L=imread('实验四_肺分割后.tif');
model=[0,1,0;1,1,1;0,1,0];  %定义3×3模板
S=myswell(L,model,6);%膨胀
S1=myclose(S,model,5);%闭运算
S2=mycorrode(S1,model,6);%腐蚀
figure,suptitle('肺-形态学处理');%Figure 2
subplot(221),imshow(L),axis on,title('原图'); 
subplot(222),imshow(S),axis on,title('膨胀6次');
subplot(223),imshow(S1),axis on,title('闭运算5次');
subplot(224),imshow(S2),axis on,title('腐蚀6次');

【mycorrode.m】

% 函数mycorrode:根据模板对图像进行腐蚀操作
% 输入参数:I:原图像
%          modelx:模板(对于背景色为黑色)
%          有参数n(n>0:执行n次(递归实现)
%          无参数n:执行一次
% 输出参数:腐蚀后的图像数据OUT
% 使用函数:nargin:判断函数输入参数的数目参数
%         size(x):求矩阵大小
%         zeros():为矩阵分配空间
%         im2bw(x):二值化(即转化为逻辑值)
%         sum():求和
function OUT=mycorrode(I,model,n)
if nargin ==2[x,y]=size(I);      %获取原图像的大小w=(size(model)-1)/2;OUT=im2bw(zeros(x,y));for i=w+1:x-1for j=w+1:y-1if(sum(sum(I(i-w:i+w,j-w:j+w)&model))==sum(model(:)))OUT(i,j)=1;endendend
elseif nargin>2[x,y]=size(I);      %获取原图像的大小w=(size(model)-1)/2;OUT=im2bw(zeros(x,y));for i=w+1:x-1for j=w+1:y-1if(sum(sum(I(i-w:i+w,j-w:j+w)&model))==sum(model(:)))OUT(i,j)=1;endendendn=n-1;if n>0OUT=mycorrode(OUT,model,n);end
end

【myswell.m】

% 函数myswell:根据模板对图像进行膨胀操作
% 输入参数:I:原图像
%          modelx:模板(对于背景色为黑色)
%          有参数n(n>0:执行n次(递归实现)
%          无参数n:执行一次
% 输出参数:膨胀后的图像数据OUT
% 使用函数:nargin:判断函数输入参数的数目参数
%         size(x):求矩阵大小
%         zeros():为矩阵分配空间
%         im2bw(x):二值化(即转化为逻辑值)
%         sum():求和
function OUT=myswell(I,model,n)
if nargin ==2[x,y]=size(I);      %获取原图像的大小w=(size(model)-1)/2;OUT=im2bw(zeros(x,y));for i=w+1:x-1for j=w+1:y-1if(sum(sum(I(i-w:i+w,j-w:j+w)&model))>0)OUT(i,j)=1;endendend
elseif nargin>2[x,y]=size(I);      %获取原图像的大小w=(size(model)-1)/2;OUT=im2bw(zeros(x,y));for i=w+1:x-1for j=w+1:y-1if(sum(sum(I(i-w:i+w,j-w:j+w)&model))>0)OUT(i,j)=1;endendendn=n-1;if n>0OUT=myswell(OUT,model,n);end
end

【myopen.m】

% 函数myclose:根据模板对图像进行开运算
% 输入参数:I:原图像
%          modelx:模板(对于背景色为黑色)
%          有参数n(n>0:执行n次(递归实现)
%          无参数n:执行一次
% 输出参数:开运算后的图像数据OUT
% 使用函数:nargin:判断函数输入参数的数目参数
%         myswell():膨胀
%         mycorrode():腐蚀
function OUT =myopen(I,model,n)
if nargin ==2OUT=mycorrode(I,model);%先腐蚀后膨胀OUT=myswell(OUT,model);
elseif nargin>2OUT=mycorrode(I,model);OUT=myswell(OUT,model);n=n-1;if n>0OUT=myclose(OUT,model,n);end
end

【myclose.m】

% 函数myclose:根据模板对图像进行闭运算
% 输入参数:I:原图像
%          modelx:模板(对于背景色为黑色)
%          有参数n(n>0:执行n次(递归实现)
%          无参数n:执行一次
% 输出参数:闭运算后的图像数据OUT
% 使用函数:nargin:判断函数输入参数的数目参数
%         myswell():膨胀
%         mycorrode():腐蚀
function OUT=myclose(I,model,n)
if nargin ==2OUT=myswell(I,model);%先膨胀后腐蚀OUT=mycorrode(OUT,model);
elseif nargin>2OUT=myswell(I,model);OUT=mycorrode(OUT,model);n=n-1;if n>0OUT=myclose(OUT,model,n);end
end

3.3 实验结果

在这里插入图片描述

图1 指纹形态学去噪
  图1为对有噪声的指纹图像进行一系列的操作过程,比较最后一张结果图与第一张原图,降噪效果还是比较明显的。步骤如下:
  1. 首先对原图膨胀,使得指纹区域的一些黑色的噪声造成的空洞能够被补充;
  2. 然后再通过一系列的开运算使得指纹的一些毛刺消失;
  3. 接下来通过对图像腐蚀和闭运算去除背景区域的一些白色噪声;
  4. 最后再进行一次膨胀操作恢复,使得形态学处理的过程中指纹的面积不发生巨大的改变。
    在这里插入图片描述
图2 实验4-肺形态学处理
  实验4处理后的图像虽然将肺部区域与背景明显分隔开,但肺部区域还有一些明显的黑色部分,通过一系列的膨胀、闭运算、腐蚀操作最终得到白色的肺部区域。

四、实验心得

  1. 了解了形态学的基本理论和方法。通过对于腐蚀、膨胀、开运算、闭运算代码的编写,以及对图片处理的过程中对于他们的作用更加理解。
  2. 对于指纹的处理结果虽然没有完全去除噪声,还使得指纹在某些地方有一些断裂,但相对于原图效果还是很明显的,接下来可使用其他的方法再做进一步的处理。
  3. 图像的形态学处理还有细化、中轴变换、顶帽变换等等,使用这些方法能够更好的处理图像,得到所需要的信息。
文章来源:https://blog.csdn.net/qq_41315788/article/details/114907459
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ppmy.cn/news/531939.html

相关文章

图像处理——数字图像处理

摘要 这里将介绍有关于的图像处理的一些基本的概念。同时主要是的参考了的博客的东西。但是后期本人也将添加有关于的自己本人的理解的一些东西。 1. 基本概念 图像是一个二维亮度函数f(x,y),(x,y)定义了空间坐标,f(x,y)该点的亮度或灰度。…

数字图像处理课程设计(基于matlab的Hough变换检测图像边缘提取,包含完整代码)

基于matlab的图像Hough边缘提取 一、课程设计要求 “0-4房屋图像1.jpg”和“0-5房屋图像2.jpg”是房屋立面的图像。请利用Hough变换检测,计算获得矢量化的房屋边缘特征。 二、设计思路 首先先将彩色图片进行灰度处理,然后通过边缘检测算子,…

图像去雾算法学习

现有的图像采集设备对外界环境的干扰非常敏感,在雾霾环境中,获取的户外图像往往退化严重,主要表现为场景特征信息模糊、对比度低、色彩失真,不利于计算机视觉系统对图像真实特征的提取,从而影响其后续的分析、理解、识别等一系列处理,很大程度上降低了视觉系统的实际应用…

图像处理(1)--数字图像及彩色空间

文章结构 1. 数字图像2. 彩色空间2.1 RGB2.2 CMY和CMYK2.3 HSI2.4 YIQ2.5 YUV2.6 YCbCr 3. 伪彩色图像处理4. 全彩色图像处理5. 彩色变换6. 彩色图像平滑和尖锐化 图像处理系列笔记: https://blog.csdn.net/qq_33208851/article/details/95335809 像素:…

快速入门学习数字图像处理(冈萨雷斯第三版)

一、绪论以及储备知识 1、数字图像处理 何谓数字图像处理?数字图像处理就是指借助于数字计算机来处理图像。因为计算机只能处理离散的数字量,所以一幅要被计算机处理的图像也必须是离散的。这幅图像有很多个元素组成,这些元素就是我们通常所…

计算机视觉基础之数字图像(1)

目录 一、 图像(各种图形和影像的总称)1、像素、分辨率2、灰度、通道、对比度3、RGB模型3、为什么很多图像识别将彩色图像灰度化? 二、 图像的取样与量化三、上采样与下采样1、上、下采样2、常用的插值算法 一、 图像(各种图形和影像的总称) 图像是人类视觉的基础&a…

《数字图像处理》- 1. MATLAB实现图像的傅里叶变换

声明 本文仅在CSDN发布,其他均为盗版。请支持正版! 正版链接:https://blog.csdn.net/meenr/article/details/117605843 用MATLAB实现图像的傅里叶变换 实验1、MATLAB实现图像的傅里叶变换 目录 实验1、MATLAB实现图像的傅里叶变换1. 实验目…

【计算机视觉】数字图像与机器视觉基础

目录 一、位图文件分析1. 什么是位图2. BMP位图文件3. BMP文件结构4. 位图文件头5. 位深度6. 不同位深度图像对比 二、对比不同文件格式的图片文件大小三、基于奇异值分解(SVD)提取图片特征值四、开闭运算检测图像中硬币和细胞的个数1. 检测硬币数量2. 检测细胞数量 五、图片条…