帶阻濾波器對周期性噪聲消除matlab實現


添加周期噪聲

 

 參考:https://blog.csdn.net/nanhuaibeian/article/details/90343860

t=imread('luna.jpg');
[m,n]=size(t);
t_1=t;
for i=1:m
for j=1:n
t_1(i,j)=t(i,j)+40*sin(40*i)+40*sin(40*j);
end
end
imshow(t),title('原圖');
figure,imshow(t_1),title('加入周期噪聲后');

 對周期噪聲的濾波處理

I=imread('lena.jpg');
I=rgb2gray(I);
[m,n]=size(I);
J=I;
for i=1:m
    for j=1:n
        J(i,j)=I(i,j)+40*sin(20*i)+40*sin(20*j);%增加周期性噪聲
    end
end
IF=fftshift(fft2(I));
JF=fftshift(fft2(J));
IF=log(1+abs(IF));
JF=log(1+abs(JF));
figure(1)
subplot(121)%顯示頻譜
imshow(IF,[])
subplot(122)
imshow(JF,[])
%高斯帶阻濾波器構造
fbrf=ones(m,n);
for i=1:m
    for j=1:n
        fbrf(i,j)=1-exp(-0.5*(((i-m/2)^2+(j-n/2)^2-90^2)/(sqrt(i.^2+j.^2)*5))^2);%20為帶阻中心,5為帶寬
    end
end
 H=fbrf;
%頻率域濾波
f=fftshift(fft2(J));
out=f.*H;%頻率域濾波
out=ifft2(ifftshift(out));
out=abs(out);
out=out/max(out(:));%歸一化【0,1】
figure(2)
subplot(121)
imshow(out,[]);
subplot(122)
imshow(J,[])

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM