matlab 维纳滤波器算法实现

matlab 维纳滤波器算法实现维纳滤波器算法实现matlab

Function Code

function aOut = WienerFilter(aIn,k,a,b,T)
%这仅仅是一个维纳滤波器
%k(默认为0.001)--->加到Huv2所有项上的一个规定常数,根据情况选择大小
%a(默认为0.1)--->x方向最大移动量(运动模糊图片)
%b(默认为0.1)--->y方向最大移动量(运动模糊图片)
%T(默认为1)--->移动到最大所需的时间
%aOut--->输出图像

%输入参数接收及预定义
if nargin == 1
    k = 0.005;
    a = 0.1;
    b = 0.1;
    T = 1;
elseif nargin == 2
    a = 0.1;
    b = 0.1;
    T = 1;
elseif nargin == 3
    b = 0.1;
    T = 1;
elseif nargin == 4
    T = 1;
end

%读入退化图像并进行图像预处理
a1 = double(aIn);
% figure,imshow(a1,[])%-------------图像---------------

%生成退化图像频谱图Guv(禁止填充)
[ra,ca] = size(a1);
[X,Y] = meshgrid(0:ca-1,0:ra-1);
Guv = fft2(a1.*(-1).^(X+Y));
% figure,imshow(log(abs(Guv)+1),[])%-------------图像---------------

%生成退化传递函数Huv
uaPvb = (Y-floor(ra/2)).*a+(X-floor(ca/2)).*b+eps;
Huv = T.*sin(pi.*uaPvb).*exp(-1j.*pi.*uaPvb)./(pi.*uaPvb);
Huv2 = abs(Huv).*abs(Huv);

%估计函数公式
Fuv = (Huv2./(Huv2+k)./Huv).*Guv;

%将得到的估计函数进行逆傅里叶变换
FxyShift = ifft2(Fuv);
Fxy = real(FxyShift).*(-1).^(X+Y);
% figure,imshow(Fxy,[])%-------------图像---------------
aOut = Fxy;
end

Demo Code

clear
close all

aIn3 = imread("paper3.jpg");
aIn2 = imread("paper2.jpg");
aIn1 = imread("paper1.jpg");

a3 = double(aIn3);
a2 = double(aIn2);
a1 = double(aIn1);

k3 = 0.001;
k2 = 0.0001;
k1 = 0.00001;

a = 0.1;
b = 0.1;
T = 1;

aOut3 = WienerFilter(a3,k3,a,b,T);
aOut2 = WienerFilter(a2,k2,a,b,T);
aOut1 = WienerFilter(a1,k1,a,b,T);

figure
subplot(231),imshow(a3,[]),title("严重噪声")
subplot(232),imshow(a2,[]),title("中度噪声")
subplot(233),imshow(a1,[]),title("轻微噪声")
subplot(234),imshow(aOut3,[]),title("k = "+string(k3))
subplot(235),imshow(aOut2,[]),title("k = "+string(k2))
subplot(236),imshow(aOut1,[]),title("k = "+string(k1))

Figure

说明:由于屏幕大小限制,噪声图像缩小后更加模糊

1、k3 = 0.05;k2 = 0.005;k1 = 0.001;

在这里插入图片描述

2、k3 = 0.01;k2 = 0.01;k1 = 0.008;

在这里插入图片描述

3、k3 = 0.1;k2 = 0.1;k1 = 0.1;

在这里插入图片描述

4、k3 = 0.001;k2 = 0.0001;k1 = 0.00001;

在这里插入图片描述

Conclusion

k值的过于增大,噪声明显被抑制,但是图像会变得更加模糊!

k值过于减小,会加强噪声,使噪声放大!

需要多次实验才能找到适合的k值!

今天的文章matlab 维纳滤波器算法实现分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:http://bianchenghao.cn/5882.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注