于是,当K逐渐增大时,这个滤波器将逐渐接近于陷波滤波器,并且去掉F(0,0>点,将会产生只有平均值为0的图像,所以,存在一个K值,使得经过K次高通滤波之后就会产生一副像素不变的图像。DXDiTa9E3d
因为u,v都是整数,对于上式第二个条件只需要对于所以的u,v 不全为0,我们希望滤波器对于所有的值都是能1,于是要求指数部分对于所以u,v不全为0的地方滤波效果接近于0,也就是说此时的K就是我们所要的最小值。RTCrpUDGiT
4.22
答:将会比原来的图像的
F(0,0>代表相应图像的平均值)小,因此,我们看到的右图中的F(0,0>更低,同理其他地方也会比原来对应的地方灰度值小,并且覆盖一个很窄范围的值,所以右图中的整体对比度比原图低;5PCzVD7HxA
课外编程
任务:对一幅灰度图像,
(1> 计算并画出此图像的中心化频率谱。
(2> 分别用低通滤波和高通滤波对此图像进行频域处理。
(2> 用拉普拉斯算子对此图像锐化。
1.matlab代码如下:
clear。
clc。
Data=imread('C:\Users\Administrator\Desktop\ex.JPG'>。xHAQX74J0X
DataGray=rgb2gray(Data>。
figure(1>,imshow(Data>。
title('原始图像'>。
%**************计算并画出此图像的中心化频率谱************* Data1=double(DataGray>。
FFT2=fft2(Data1>。
FFTcenter=fftshift(FFT2>。%频谱中心化
FFT2abs=abs(FFT2>。
FFTresult=256*log2(FFT2abs/max(max(FFT2abs>>+1>。
figure(2>,subplot(1,2,1>。
imshow(FFTresult>,title('原图频谱'>。
FFTc_abs=abs(FFTcenter>。
FFTc_result=256*log2(FFTc_abs/max(max(FFTc_abs>>+1>。LDAYtRyKfE
subplot(1,2,2>。
imshow(FFTc_result>,title('中心化频谱'>。
%*******分别用低通滤波和高通滤波对此图像进行频域处理**** [m,n]=size(FFTcenter>。
x_center=round(m/2>。
y_center=round(n/2>。
d=10。%半径取10
LF=FFTcenter。
HF=FFTcenter。
%**************低通滤波器*************
fori=1:m。
for j=1:n
distance=sqrt((i-x_center>^2+(j-y_center>^2>。if distance<=d
flag=1。
else
flag=0。
end
LF(i,j>=flag*FFTcenter(i,j>。
end
end
%逆变换转换成对应图像
LF=uint8(real(ifft2(ifftshift(LF>>>>。
figure(3>,subplot(1,2,1>。imshow(LF>。
title('低通滤波后图像'>。
%**************高通滤波器*************
fori=1:m。
for j=1:n
distance=sqrt((i-x_center>^2+(j-y_center>^2>。if distance>d
flag=1。