?? fftpro.m
字號:
%用FFT對信號,數(shù)據(jù)點512,進行濾波將頻率為8—15Hz的波濾去。采樣間隔0.02。
%x=0.5*sin(2*pi*3*n*dt)+cos(2*pi*10*n*dt)
dt=0.02;
N=512;
n=0:N-1;
t=n*dt;
f=n/(N*dt);
f1=3;f2=10; %信號的頻率成分
x=.5*sin(2*pi*f1*t)+cos(2*pi*f2*t);
subplot(2,2,1),plot(t,x); %繪制原來的信號
title('原始信號的時間域');xlabel('時間/s');
y=fft(x);
subplot(2,2,2),plot(f,abs(y)*2/N) %繪制原信號的振幅譜
xlabel('頻率/Hz'),ylabel('振幅')
xlim([0 50]);title('原始振幅譜')
f1=8;f2=15; %要濾去頻率的上限和下限
yy=zeros(1,length(y)); %設(shè)置與y相同元素的數(shù)組
for m=0:N-1 %將頻率落在該頻率范圍及其大于Nyquist頻率的波濾去
if(m/(N*dt)>f1&m/(N*dt)<f2)|(m/(N*dt)>(1/dt-f2)&m/(N*dt)<(1/dt-f1))
%小于Nyquist頻率的濾波范圍 %大于Nyquist頻率的濾波范圍,1/dt為一個頻率周期
yy(m+1)=0.; %在此頻率范圍內(nèi)的振幅為 0
else
yy(m+1)=y(m+1); %其余頻率范圍不變
end
end
subplot(2,2,4),plot(f,abs(yy)*2/N)
xlim([0 50]);xlabel('頻率/Hz');ylabel('振幅');
gstext=sprintf('自%4.1f-%4.1fHz的頻率被濾除',f1,f2);
%將濾波范圍顯示作為標(biāo)題
title(gstext)
subplot(2,2,3),plot(t,real(ifft(yy)))
%繪制濾波后的數(shù)據(jù)運用ifft變換回時間域并繪圖
title('通過ifft回到時間域');
xlabel('時間/s');
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -