matlab请指教,关于求图像梯度

2024-12-28 14:03:20
推荐回答(2个)
回答1:

求梯度时,已经转成了double了,所以结果要转回unit8  程序修改后

clear all

close all

I = imread('1灰度图.jpg'); 

hy = fspecial('sobel');

hx = hy';

Iy = imfilter(double(I), hy, 'replicate');

Ix = imfilter(double(I), hx, 'replicate');

gradmag = sqrt(Ix.^2 + Iy.^2);


figure('units', 'normalized', 'position', [0 0 1 1]);

subplot(1, 2, 1); imshow(I,[]), title('灰度增强图');


subplot(1, 2, 2); imshow(gradmag/255,[]), title('梯度幅值图像');

imwrite(gradmag,'2梯度幅值图像.jpg')%保存图像为文件

回答2:

你必须将gradmap转换成图像数据,好像是mat2img(gradmap),具体的函数我记不大清楚了,你查查帮助。