关于图像处理,利用sobel算子边缘检测的Matlab程序

ps=imread('14.jpg');%读取图像subplot(1,3,1)imshow(ps);title('原图像');ps=rgb2gray(ps);[m,n]=... ps=imread('14.jpg'); %读取图像
subplot(1,3,1)
imshow(ps);
title('原图像');
ps=rgb2gray(ps);
[m,n]=size(ps); %用Sobel微分算子进行边缘检测
pa = edge(ps,'sobel');
subplot(1,3,2);
imshow(pa);
title('边缘检测得到的图像');
ps=double(ps);
for i=1:256
for j=1:256
if pa(i,j)==1
res(i,j)= g(i,j);
else
res(i,j)=ps(i,j);
end
end
end
res=uint8(res);
subplot(1,3,3);
imshow(res);
title('增强后的图像')
imwrite(res,'222.jpg');

才学的这个,不怎么会,这是别人的程序,res(i,j)= g(i,j); 这里出错了,没有定义g,边缘检测图像和原图像都可以显示,增强后的不能显示。我想问下该如何修改?
我基本一点都不会,为了做毕业设计没办法。我意思就是如何简单的改动一下这个程序?不添加额外的东西,就用sobel算子
展开
 我来答
adam2030
推荐于2016-09-05 · TA获得超过268个赞
知道答主
回答量:128
采纳率:0%
帮助的人:95.9万
展开全部
这很明显啊,你没有定义g函数。看你程序的意思是先检测出边缘,因为边缘中的线都是白色的,然后就是用for 和 if语句把边缘经过处理,也就是将边缘中白色点变为g,这就要看你具体想以何种方式增强了,如果是对数变换的话,你可以先让g(:,:)=log((ps(:,:))+1)(将这条语句放在for语句的上面);这样增强的结果就是扩展低值灰度,压缩高值灰度,当然了,还有很多其它增强方法,你可以具体再找找图像增强这方面的资料。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式