MATLAB用数学形态学法提取图像边界

MATLAB用数学形态学法提取图像边界

方法一

主要函数:
graythresh() ; im2bw() ; bwperim() ;

代码如下

img=imread('ball.jpg'); %原图像为灰度图
subplot(1,2,1);
imshow(img);
title('原图像');

threshold= graythresh(img);  %使用最大类间方差法找到图片的一个合适的阈值(threshold=0.4745)
img_1=im2bw(img,threshold); %用这个阈值把灰度图像转换为二值图像(像素值>0.4745*255的变为255白,其他的变为0)

img_2=bwperim(img_1); %用bwperim函数查找二值图像的边缘

subplot(1,2,2);
imshow(img_2);
title('边缘提取后的图像')

运行结果
在这里插入图片描述

方法二

主要函数:
entropyfilt() ; bwareaopen() ; rangefilt() ;

代码如下

img=imread('ball.jpg'); 
subplot(2,3,1);
imshow(img);
title('原图像');

img_1 = entropyfilt(img);  %创建纹理图像
img_2 = mat2gray(img_1);  %转化为灰度图像
subplot(2,3,2)
imshow(img_2);  
title('纹理图像');

img_3 = im2bw(img_2,0.7);  %转化为二值图像
subplot(2,3,3);
imshow(img_3);  
title('二值图像');

img_4 = bwareaopen((1-img_3),3000,8); %提取大小球区域纹理
subplot(2,3,4);
imshow(img_4); 
title('不同区域纹理图像');

img_5= rangefilt (img,ones(7));  %rangefilt滤波
subplot(2,3,5); 
imshow(img_5); 
title('滤波后图像');

运行结果
在这里插入图片描述
对函数理解还不够深刻,如有错误望指正!

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LPY。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值