Pseudo-lover 发表于 2016-3-4 15:51

MATLAB低通滤波器选频实现


MATLAB低通滤波器选频实现
http://s13.sinaimg.cn/mw690/0035H5bGzy6ZDN0IIiMfc&690
http://s5.sinaimg.cn/mw690/0035H5bGzy6ZDN3Gq6U14&690

%频率不同的三个正弦波信号相加,分别输出时域波形和频域频谱 three_cos.m
%设计低通滤波器,改变低通滤波器截止频率,输出不同波形
%1.波形产生程序 three_cos(t);
%2.傅里叶正变换=FFT_SHIFT(t, st);
%3.傅里叶反变换=IFFT_SHIFT(f,Sf);
%4.低通滤波器=RECT_LPF(f,Sf,B);

% Signal
dt=0.01;    %时间采样间隔
T=5;      %信号持续时间
N=floor(T/dt);%点数
t=*dt;   %t

f1=1;f2=5;f3=10; %信号不同频率值
m1=cos(2*pi*f1*t);
m2=cos(2*pi*f2*t);
m3=cos(2*pi*f3*t);
mt1=m1+m2+m3;
=FFT_SHIFT(t,mt1); %2.傅里叶正变换
%输出:f-抽样频率;mt1f-频率;输入:t-时间;mt1-输入波形
fmax=2;   
f=1;f2=5;f3=10; %信号不同频率值
B1=fmax %设置低通滤波器带宽,准备调用低通滤波器
=RECT_LPF(f,mt1f,B1); %低通滤波器滤除高频,由B1决定
=FFT_SHIFT(t,mt1_t); %2.傅里叶正变换

%时域、频域显示
subplot(511);
plot(t,m1);
ylabel('m1(t)');
title('三个不同频率正弦波合成波和频谱');
subplot(512);
plot(t,m2);
ylabel('m2(t)');
subplot(513);
plot(t,m3);
ylabel('m3(t)');
subplot(514);
plot(t,mt1);
ylabel('m(t)');
subplot(515);
plot(f,mt1f);
ylabel('m(f)');
axis([-40,40,0,3]);

figure(2)
subplot(511);
plot(t,m1);
ylabel('m1(t)');
title('低通滤波器选频合成波和频谱');
subplot(512);
plot(t,m2);
ylabel('m2(t)');
subplot(513);
plot(t,m3);
ylabel('m3(t)');
subplot(514);
plot(t,mt1_t);
ylabel('m(t)');
subplot(515);
plot(f,mt1_tf);
ylabel('fmax=2');
axis([-40,40,0,3]);
%=======================================
% 调用函数傅里叶变换
function =FFT_SHIFT(t, st)
%This function is FFT to calculate a signal’s Fourier transform
%Input: t: sampling time , st : signal data. Time length must greater than 2
%output: f : sampling frequency , sf: frequency
%output is the frequency and the signal spectrum
dt=t(2)-t(1);
T=t(end);
df=1/T;
N=length(t);
f=[-N/2:N/2-1]*df;
sf=fft(st);
sf=T/N*fftshift(sf);

% 傅里叶反变换
function=IFFT_SHIFT(f,Sf)
df=f(2)-f(1);
fmax=(f(end)-f(1)+df);
dt=1/fmax;
N=length(f);
t=*dt;
Sf=fftshift(Sf);
st=fmax*ifft(Sf);
st=real(st);

% 赵鸿图-低通滤波器
function =RECT_LPF(f,Sf,B)
df=f(2)-f(1);
fN=length(f);
RectH=zeros(1,fN);
BN=floor(B/df);
BN_SHIFT=[-BN:BN-1]+floor(fN/2);
RectH(BN_SHIFT)=1;
Yf=RectH.*Sf;
=IFFT_SHIFT(f,Yf);

%参考书: 赵鸿图 茅艳   通信原理MATLAB仿真教材. 人民邮电出版社

转自:http://blog.sina.com.cn/s/blog_a8d541800102wc81.html

lbtv 发表于 2017-6-11 09:52

这个低通滤波器相当于把不要的频率直接置零~不会产生频谱泄露?
页: [1]
查看完整版本: MATLAB低通滤波器选频实现