形态学操作实现

数学形态学的基本思想是用具有一定形态的结构元素去度量和提取图像中的对应形状以达到对图像分析和识别的目的。数学形态学的基本运算有四个:腐蚀、膨胀、开和闭。基于这些基本运算还可以推导和组合成各种数学形态学实用算法。本实验分别实现针对二值图像和灰度图像的四种形态学操作。

一、二值图像的腐蚀、膨胀、开、闭操作

实验结果:

二、灰度图像的腐蚀、膨胀、开、闭操作

实验结果:

代码:(下载链接)

%本实验完成对二值图像和灰度图像的腐蚀、膨胀、开、闭操作
close all;
clear all;
grayI = imread('rice.png');
binI=im2bw(grayI,0.5);%转二值图
se = [0,1,0;1,1,1;0,1,0]; %结构元
binIerode  = myimerode(binI,se,'binary');
binIdilate = myimdilate(binI,se,'binary');
binIopen   = myimopen(binI,se,'binary');
binIclose  = myimclose(binI,se,'binary');
grayIerode = myimerode(grayI,se,'gray');
grayIdilate= myimdilate(grayI,se,'gray');
grayIopen  = myimopen(grayI,se,'gray');
grayIclose = myimclose(grayI,se,'gray');
figure;
subplot(2,3,1);imshow(binI);title('原始二值图');
subplot(2,3,2);imshow(binIerode);title('腐蚀结果');
subplot(2,3,3);imshow(binIdilate);title('膨胀结果');
subplot(2,3,4);imshow(binIopen);title('开结果');
subplot(2,3,5);imshow(binIclose);title('闭结果')
figure;
subplot(2,3,1);imshow(grayI);title('原始灰度图');
subplot(2,3,2);imshow(uint8(grayIerode));title('腐蚀结果');
subplot(2,3,3);imshow(uint8(grayIdilate));title('膨胀结果');
subplot(2,3,4);imshow(uint8(grayIopen));title('开结果');
subplot(2,3,5);imshow(uint8(grayIclose));title('闭结果');
 
View Code
function O=myimclose(I,se,type)
%%闭操作
%I:输入图像(二值或灰度)
%se:结构元
%type:图像类型(gray、binary)
%O:闭操作结果
O=myimerode(myimdilate(I,se,type),se,type);
View Code
function O=myimopen(I,se,type)
%开操作
%I:输入图像(二值或灰度)
%se:结构元
%type:图像类型(gray、binary)
%O:开操作结果
O=myimdilate(myimerode(I,se,type),se,type);
View Code
function O=myimerode(I,se,type)
%%腐蚀操作
%I:输入图像(二值或灰度)
%se:结构元
%type:图像类型(gray、binary)
%O:腐蚀操作结果
O=zeros(size(I));
[r,c]=size(I);
[m,n]=size(se);
lm=floor((m-1)/2);
ln=floor((n-1)/2);
rm=m-lm-1;
rn=n-ln-1;
orgm=lm+1;%结构元原点
orgn=ln+1;
if(strcmp(type,'binary'))%二值图像
    for i=1:r
        for j=1:c
            indexr=max(1,i-lm):min(r,i+rm);%边界处理
            indexc=max(1,j-ln):min(c,j+rn);
            if(sum(sum(se(indexr-i+orgm,indexc-j+orgn)&I(indexr,indexc)))==sum(sum(se(indexr-i+orgm,indexc-j+orgn))))
                O(i,j)=1;
            end
        end
    end
end
if(strcmp(type,'gray'))%灰度图像
    I=double(I);
    for i=1:r
        for j=1:c
            indexr=max(1,i-lm):min(r,i+rm);%边界处理
            indexc=max(1,j-ln):min(c,j+rn);
            O(i,j)=min(min(I(indexr,indexc)-se(indexr-i+orgm,indexc-j+orgn)));
        end
    end
end
View Code
function O=myimdilate(I,se,type)
%%膨胀操作
%I:输入图像(二值或灰度)
%se:结构元
%type:图像类型(gray、binary)
%O:膨胀操作结果
se=reflect(se);%结构元反射
O=zeros(size(I));
[r,c]=size(I);
[m,n]=size(se);
lm=floor(m/2);%区别于erode
ln=floor(n/2);
rm=m-lm-1;
rn=n-ln-1;
orgm=lm+1;%结构元原点
orgn=ln+1;
if(strcmp(type,'binary'))%二值图像
    for i=1:r
        for j=1:c
            indexr=max(1,i-lm):min(r,i+rm);%边界处理
            indexc=max(1,j-ln):min(c,j+rn);
            if(sum(sum(se(indexr-i+orgm,indexc-j+orgn)&I(indexr,indexc)))>=1)
                O(i,j)=1;
            end
        end
    end
end
if(strcmp(type,'gray'))%灰度图像
    I=double(I);
    for i=1:r
        for j=1:c
            indexr=max(1,i-lm):min(r,i+rm);%边界处理
            indexc=max(1,j-ln):min(c,j+rn);
            O(i,j)=max(max(I(indexr,indexc)+se(indexr-i+orgm,indexc-j+orgn)));
        end
    end
end

function newse=reflect(se)
%%结构元反射操作
%se:输入结构元
%newse:反射后结构元
[m,n]=size(se);
newse=zeros(m,n);
for i=1:m
    for j=1:n
        newse(i,j)=se(m+1-i,n+1-j);
    end
end
View Code

 

转载于:https://www.cnblogs.com/luo-peng/p/5612449.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在C++ OpenCV中,形态学操作是一种图像处理技术,用于改变图像的形状和结构。形态学操作通常用于图像分割、去噪、边缘检测等应用中。 在进行形态学操作之前,我们需要获取图像的结构元素。结构元素类似于卷积核,它定义了形态学操作的形状和大小。在OpenCV中,我们可以使用getStructuringElement()函数来获取特定形状和大小的结构元素\[2\]。 getStructuringElement()函数的使用方式如下: ``` Mat element = getStructuringElement(shape, size); ``` 其中,shape参数指定结构元素的形状,可以是矩形、椭圆或十字形。size参数指定结构元素的大小。 获取到结构元素后,我们可以将其用于后续的形态学操作,例如腐蚀、膨胀、开运算、闭运算等。这些操作可以通过调用morphologyEx()函数来实现\[3\]。 morphologyEx()函数的使用方式如下: ``` morphologyEx(src, dst, op, kernel, anchor, iterations, borderType, borderValue); ``` 其中,src参数是输入图像,dst参数是输出图像,op参数指定形态学操作的类型,kernel参数是结构元素,anchor参数是结构元素的锚点,iterations参数是操作的迭代次数,borderType参数是边界处理方式,borderValue参数是边界像素的值。 通过使用getStructuringElement()函数获取结构元素,并结合morphologyEx()函数进行形态学操作,我们可以实现各种图像处理任务。 #### 引用[.reference_title] - *1* *2* [C++ opencv 图像形态学、膨胀、腐蚀、闭、开、顶帽、黑帽](https://blog.csdn.net/HWWH520/article/details/125015959)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [opencv c++ 图像形态学操作](https://blog.csdn.net/lucust/article/details/128207799)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值