数字信号处理实验DFT分析连续信号频谱Word文档格式.docx
《数字信号处理实验DFT分析连续信号频谱Word文档格式.docx》由会员分享,可在线阅读,更多相关《数字信号处理实验DFT分析连续信号频谱Word文档格式.docx(18页珍藏版)》请在冰豆网上搜索。
w=(-ws/2+(0:
L-1)*ws/L)/(2*pi);
plot(w,abs(X));
ylabel('
幅度谱'
);
title('
矩形窗截断'
b)使用hamming窗截断
%数据的长度
f2=120;
wh=(hamming(N))'
;
x=x.*wh;
幅度'
xlabel('
频率'
hamming窗口截断'
)
c)使用blackman截断
wh=(blackman(N))'
blackman窗口截断'
二、
a)矩形窗截断:
f=cos(2*pi*f1*t)+0.2*cos(2*pi*f2*t);
F=fftshift(fft(f,L));
hd=plot(w,abs(F));
使用矩形窗截断'
当采样点增加到300时对应的频谱图:
旁瓣高频十分多无法找的0.2*cos(2*pi*f2*t)的幅度低的无法分辨;
b)Hamming窗截断
x=cos(2*pi*f1*t)+0.2*cos(2*pi*f2*t);
使用hamming截断'
c)使用blackman截断
使用blackman截断'
使用hamming和blackman截断可以清楚的分辨120hz低幅度的分量;
总结:
由于矩形窗在两端变化太陡所以高频分量多,使幅度低的频率局部无法再频谱图分辨出来,所以在时域用该选取变化相对平缓的窗口函数,来防止;
选择适宜DFT参数的原那么:
1、抽样频率/时间间隔
2、
时域抽样点数或抽样时间
矩形窗时取c=1,哈明窗时取c=2
3、DFT点数
思考题
(1)既然可以直接计算FT,为什么利用DFT分析连续信号谱?
答:
根据定义是可以根据傅里叶变换的定义直接计算连续信号的傅里叶变换,但是定义区间是无限长,这在计算上是不可实施的,无论是人工计算还是通过计算机进行计算。
而DFT是有限长的序列的傅里叶变换,在计算机上容易实现。
再者,在数字信号处理中,希望能够利用数字方法直接计算常见的四种信号的频谱函数,这是需要的时域信号为有限长,其频谱也为有限项。
因此常常利用DFT对序列进行频谱分析。
(2)在利用DFT分析连续信号频谱时,会出现哪些误差?
如何克服或减弱?
A.混叠现象:
对于带限连续信号,只要提高抽样频率使之满足时域抽样定理;
对于非带限信号,可以根据实际情况对其进行低通滤波,使之成为带限信号。
工程中的信号一般都不是带限信号,连续信号在抽样前通常都进过一个低通滤波器〔即抗混叠滤波器〕进行低通滤波,以减少混叠误差,提高频谱分析精度。
B.泄漏现象:
在选择矩形窗口的长度时,适当增加窗的长度,可以提高频谱分辨率,但是不能减小旁瓣引起的频谱泄露,因此可以选择旁瓣幅度很小甚至为零的非矩形窗对信号进行加窗处理,就可以降低频谱泄露。
C.栅栏现象:
改善栅栏现象最常用的方法是在离散序列之后补零,得到一个比原有序列更长的序列,这样就可以增加频谱图中的很多细节,降低栅栏现象。
(3)在利用DFT分析连续信号频谱时,如何选择窗函数?
在用DFT分析连续信号频谱时,选择窗函数一般首选矩形窗,因为对信号进行加窗处理的目的是去截断信号,故一般情况下选择矩形窗就可以了。
但是在对频谱分析精度要求高和重要的频率点上的幅度较小的情况下,就要合理选择非矩形窗,选择旁瓣幅值小甚至为零的非矩形窗以满足要求,提高频谱分析精度。
(4)假设截短信号造成泄漏而导致频谱分辨率下降,可否通过在截短序列后补零得到改善?
可以对于序列补0后可以提高频谱的分辨率。
(5)窗函数对频谱分辨率有何影响吗?
怎样提高频谱分辨率?
窗函数对频谱分析精度的影响主要是有窗函数的主瓣宽度和旁瓣幅度影响的。
具体而言是:
主瓣宽度越窄,精确度越高;
旁瓣幅度越小,精确度越高。
因此要想提高频谱分析精度,就必须选择适宜的窗函数,应该使所选窗函数的长度尽量长,这样就可以减小窗函数主瓣的宽度;
此外尽量选那么旁瓣幅度较小甚至为零的窗函数,这样也可以减小频谱泄露,提高频谱分子精度。
(6)如何选择取样频率?
抽样频率应满足抽样定理即:
抽样的最小频率要大于被测信号最高频率的2倍才能保证不发生频谱的混叠。
(7)既然频谱分辨率与信号采集时间成反比,是否意味着在实际中频谱分辨率可以很容易实现?
采集的时间t=nT又根据
当采样的时间变长时采样的点数N会增多使计算量变大,可见频率分辨率的增加时运算量会增多。
(8)讨论补零对计算结果的影响。
在有限长的序列X[k]后面补零对DTFT没有影响,但使DFT的抽样点增多得到可以得到更多的频谱细节提高频谱分辨率。
课后习题:
M2-1
x=[1,-3,4,2,0,-2];
h=[3,0,1,-1,2,1];
的循环卷积
程序:
%6点循环卷积Yc1
N1=6;
Xm=fft(x,N1);
Hm=fft(h,N1);
Y=ifft(Xm.*Hm)
运算结果:
Y=
与手算结果相同。
k=1:
6;
stem(k,Y)
axis([010,-2020])
k'
Y'
循环卷积'
M2-2:
n=1018;
k1=0:
1023;
k2=0:
5;
x=cos(pi*k1/2)
h=power(3,k2)%3的k2次幂
y=conv(x,h)
l=length(y)
stem(0:
l-1,y)
直接卷积'
对于长序列使用分段卷积的两种方法:
1序列输入局部
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
29;
a=length(x)
b=length(h)
y=overlap_add(x,h,6)
figure
stem(1:
a+b-1,y)
使用重叠相加法30点'
figure
y=overlap_save(x,h,6)
使用重叠保存法30点'
2利用FFT循环卷积计算线性卷积的子函数
functiony=lin_conv(x1,x2,L)
%利用FFT循环卷积计算线性卷积
y1=fft(x1,L);
y2=fft(x2,L);
Yk=y1.*y2;
y=ifft(Yk);
end
3重叠相加法实现长短序列的线性卷积
functiony=overlap_add(x,h,M)
%x为较长的输入序列,h为较短的系统函数,M为分段大小
%---------前期处理-------------------
N=length(h);
%序列h(n)的长度
Lx=length(x);
%序列x(n)的长度
ifN>
M%算法要求N<
=M
M=N+1;
L=M+N-1;
%用每段循环卷积计算线性卷积所需点数
T=ceil(Lx/M);
%分段数,ceil向上取整
t=zeros(1,N-1);
%缓存序列初始化
x=[x,zeros(1,(T+1)*M-Lx)];
%最后一个缺乏M的分段补零
y=zeros(1,(T+1)*M);
%生成输出序列y(n)
%-------------核心算法--------------------
fori=0:
T
xi=i*M+1;
x_seg=x(xi:
xi+M-1);
%低点数计算时的分段x(n)
y_seg=lin_conv(x_seg,h,L);
%计算i分段和h的循环线性卷积
y_seg(1:
N-1)=y_seg(1:
N-1)+t(1:
N-1);
%与前一段卷积的后N-1位重叠相加
t(1:
N-1)=y_seg(M+1:
L);
%缓存序列更新
y(xi:
xi+M-1)=y_seg(1:
M);
%每卷积一段输出M个点
end
y=y(1:
Lx+N-1);
%最终输出序列
4重叠保存法实现长短序列的线性卷积
functiony=overlap_save(x,h,M)
T;
x_seg=[t,x(xi:
xi+M-1)];
t=x_seg(M+1:
M+N-1);
%线性卷积
xi+M-1)=y_seg(N:
X序列取1024点太密取30点观察,两种方法何志杰进行卷积的结果一样。
体会:
通过这次的上机仿真加深了对于课本知识的理解,同时也对运算的过程有了更加清晰的认识。
通过小组的合作也提高了自己的合作能力,加深了小组成员之间的感情。