马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?我要加入
x
小弟要做同态滤波复原 同态复原程序已经调试可用,但是如果先把原图像模糊一下之后再调入同态复原程序之后就会出现错误Number of array dimensions must match for binary array op
小弟一直要是因为图像进行模糊处理之后图像维数放生了变化,但是如何才能让模糊之后的图调入复原程序不出错误呢??
下面是程序
首先对图像进行模糊出处理
imori=imread('F:\matlab\toolbox\images\imdemos\girl.bmp');
psf=fspecial('motion',7,0);
I=imfilter(imori,psf,'symmetric')
J = imnoise(I,'gaussian',0,sqrt(0.000001));
figure, imshow(J)
保存模糊图像为girl1.jpg
然后将模糊图像调入复原程序
Img =imread('F:\matlab\toolbox\images\imdemos\girl1.jpg); %读图
%Img =rgb2gray(Img);
%Img =im2uint8(Img);
[M N]=size(Img); %得大小
figure;
imshow(Img); %显示图
Img=double(Img); %转换类型
lnImg = log(1+Img); %取对数
FImg = fft2(lnImg); %傅立叶变换
P =fftshift(FImg); %将频域原点移到图像中心
for i=1:M
for j=1:N
D(i,j)=((i-M/2)^2+(j-N/2)^2); %点(i,j)到频率平面原点的距离
end
end
c=0.65; %锐化参数,可调
Do=200 ; %一般是方差 (滤波器的高通截止频率)
H=(2.0-0.5)*(1-exp(c*(-D/(Do^2))))+0.5; %滤波器函数
hImg=FImg.*H;
gImg=ifft2(hImg); %逆傅立叶变换
Y=exp(gImg); %取指数
G=real(Y);
figure,imshow(uint8((G)));
imwrite(G,'tt.bmp','bmp');
提示错误
Number of array dimensions must match for binary array op.
请哪位高手指点一下 我该怎么办 谢谢各位 |