赞
踩
巴特沃斯滤波器是一种常用于图像处理的滤波器,它在频域中的传递函数具有更加平滑的过渡,相对于理想滤波器来说,巴特沃斯滤波器可以更好地控制截止频率和滤波器的阶数。下面是巴特沃斯滤波器的不同类型的原理简介:
巴特沃斯低通滤波器通过在频域中滤除高频成分来实现图像的平滑。其传递函数为:
其中D(u,v) 是频域中点 (u,v) 到中心的距离,D0 是截止频率,n 是滤波器的阶数。
巴特沃斯高通滤波器通过滤除低频成分来增强图像中的细节和边缘。其传递函数为:
其中D(u,v) 是频域中点 (u,v) 到中心的距离,D0 是截止频率,n 是滤波器的阶数。
巴特沃斯带通滤波器保留图像中一定频率范围内的成分,同时滤除低频和高频成分。其传递函数为:
其中D(u,v) 是频域中点(u,v) 到中心的距离,D0 和 D1 是两个截止频率,n 是滤波器的阶数。
巴特沃斯带阻滤波器与带通滤波器相反,它滤除一定频率范围内的成分,同时保留低频和高频成分。其传递函数为:
其中D(u,v) 和 D0、D1 同上,n 是滤波器的阶数。
2.实现代码
- clear
- clc
- I = imread('1.jpg'); % 读入图像
- I = rgb2gray(I);
- I=im2double(I);
- M=2*size(I,1); %滤波器的行数
- N=2*size(I,2); %滤波器的列数
- u=-M/2:(M/2-1);
- v=-N/2:(N/2-1);
- [U,V]=meshgrid(u, v);
- D=sqrt(U.^2+V.^2);
- D0=50; %截止频率
- n=6; %滤波器的阶数
- H=1./(1+(D./D0).^(2*n)); %设计巴特沃斯滤波器
- J=fftshift(fft2(I, size(H, 1), size(H, 2))); %空域转换到频域
- K=J.*H; %滤波处理
- L=ifft2(ifftshift(K)); %傅里叶反变换
- L=L(1:size(I,1), 1:size(I, 2)); %改变图像大小
-
- % 显示原始图像和滤波后的图像
- figure;
- % 显示原始图像
- subplot(221);
- imshow(I);
- title('原始图像');
- % 显示滤波后的图像
- subplot(222);
- imshow(L);
- title('滤波后的图像');
- % 显示原始图像的频域
- subplot(223);
- imagesc(log(1 + abs(J)));
- title('原始图像的频域');
- % 显示滤波后图像的频域
- subplot(224);
- imagesc(log(1 + abs(K)));
- title('滤波后图像的频域');
- clear
- clc
- I = imread('1.jpg'); % 读入图像
- I = rgb2gray(I);
- I=im2double(I);
- M=2*size(I,1); %滤波器的行数
- N=2*size(I,2); %滤波器的列数
- u=-M/2:(M/2-1);
- v=-N/2:(N/2-1);
- [U,V]=meshgrid(u, v);
- D=sqrt(U.^2+V.^2);
- D0=50; %截止频率
- n=6; %滤波器的阶数
- H=1./(1+(D0./D).^(2*n)); %设计巴特沃斯滤波器
- J=fftshift(fft2(I, size(H, 1), size(H, 2))); %空域转换到频域
- K=J.*H; %滤波处理
- L=ifft2(ifftshift(K)); %傅里叶反变换
- L=L(1:size(I,1), 1:size(I, 2)); %改变图像大小
-
- % 显示原始图像和滤波后的图像
- figure;
- % 显示原始图像
- subplot(221);
- imshow(I);
- title('原始图像');
- % 显示滤波后的图像
- subplot(222);
- imshow(L);
- title('滤波后的图像');
- % 显示原始图像的频域
- subplot(223);
- imagesc(log(1 + abs(J)));
- title('原始图像的频域');
- % 显示滤波后图像的频域
- subplot(224);
- imagesc(log(1 + abs(K)));
- title('滤波后图像的频域');
- clear
- clc
- I = imread('1.jpg'); % 读入图像
- I = rgb2gray(I);
- I=im2double(I);
- M=2*size(I,1); %滤波器的行数
- N=2*size(I,2); %滤波器的列数
- u=-M/2:(M/2-1);
- v=-N/2:(N/2-1);
- [U,V]=meshgrid(u, v);
- D=sqrt(U.^2+V.^2);
- D0=50; %截止频率
- D1=60;
- n=6; %滤波器的阶数
- H=1./(1+(D.*(D1-D0)./(D.^2-D0*D1)).^(2*n)); %设计巴特沃斯滤波器
- J=fftshift(fft2(I, size(H, 1), size(H, 2))); %空域转换到频域
- K=J.*H; %滤波处理
- L=ifft2(ifftshift(K)); %傅里叶反变换
- L=L(1:size(I,1), 1:size(I, 2)); %改变图像大小
-
- % 显示原始图像和滤波后的图像
- figure;
- % 显示原始图像
- subplot(221);
- imshow(I);
- title('原始图像');
- % 显示滤波后的图像
- subplot(222);
- imshow(L);
- title('滤波后的图像');
- % 显示原始图像的频域
- subplot(223);
- imagesc(log(1 + abs(J)));
- title('原始图像的频域');
- % 显示滤波后图像的频域
- subplot(224);
- imagesc(log(1 + abs(K)));
- title('滤波后图像的频域');
- clear
- clc
- I = imread('1.jpg'); % 读入图像
- I = rgb2gray(I);
- I=im2double(I);
- M=2*size(I,1); %滤波器的行数
- N=2*size(I,2); %滤波器的列数
- u=-M/2:(M/2-1);
- v=-N/2:(N/2-1);
- [U,V]=meshgrid(u, v);
- D=sqrt(U.^2+V.^2);
- D0=50; %截止频率
- D1=60;
- n=6; %滤波器的阶数
- H=1./(1+(D0*D1./(D.^2-D0*D1)).^(2*n)); %设计巴特沃斯滤波器
- J=fftshift(fft2(I, size(H, 1), size(H, 2))); %空域转换到频域
- K=J.*H; %滤波处理
- L=ifft2(ifftshift(K)); %傅里叶反变换
- L=L(1:size(I,1), 1:size(I, 2)); %改变图像大小
-
- % 显示原始图像和滤波后的图像
- figure;
- % 显示原始图像
- subplot(221);
- imshow(I);
- title('原始图像');
- % 显示滤波后的图像
- subplot(222);
- imshow(L);
- title('滤波后的图像');
- % 显示原始图像的频域
- subplot(223);
- imagesc(log(1 + abs(J)));
- title('原始图像的频域');
- % 显示滤波后图像的频域
- subplot(224);
- imagesc(log(1 + abs(K)));
- title('滤波后图像的频域');
在这些公式中,阶数 n 的选择会影响滤波器的频率响应曲线的陡峭程度。较大的 n 会导致更陡峭的过渡,但也可能引入一些振铃效应。
最后:
如果你想要进一步了解更多的相关知识,可以关注下面公众号联系~会不定期发布相关设计内容包括但不限于如下内容:信号处理、通信仿真、算法设计、matlab appdesigner,gui设计、simulink仿真......希望能帮到你!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。