4-28.m

来自「经典数字信号处理滤波器的源代码 重点是利用巴特沃斯模拟滤波器转而设计其它数字滤」· M 代码 · 共 26 行

M
26
字号
%例程4-28实现Butterworth高通滤波器

D = imread('rice.png');
figure, imshow(D),
D=double(D);
F=fft2(D);        %傅立叶变换
F=fftshift(F);    %转换数据矩阵
[N1,N2]=size(F);
n=2;
d0=4;
n1=fix(N1/2);
n2=fix(N2/2);
for i=1:N1
for j=1:N2
       d =sqrt((i-n1)^2+(j-n2)^2);
       h=1/(1+(d0/d)^(2*n));     %计算高通转换函数
       FD(i,j)=h*F(i,j);        %高通滤波
end
end
FD=ifftshift(FD);
FD=ifft2(FD);
FD=real(FD);
FD=100*FD;                        %拉升图像灰度范围
FD=uint8(FD);
figure,imshow(FD)

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?