孙微涛 张志宝 罗文峰 汪 帆
(中国人民解放军63788部队 渭南 714000)
频率是信号的一个重要参量,在信息对抗中,测定截获信号的频率是基本任务之一,因此快速、高精度是频率估计的基本要求[1]。国内外许多学者对正弦信号频率估计问题做了研究。Abatzoglou[2]提出利用最大似然估计(Maximum Likelihood,ML)算法或ML改进算法估计正弦信号频率,估计误差逼近克拉美罗下限(Cramer-Rao Low Bound,CRLB),因此是最优估计,但这些算法复杂度高、计算量大,难以实现实时处理,限制了其进一步应用[3]。
直接采用DFT谱估计法进行正弦波信号频率估计,计算量小(借助FFT),因而在工程上得到了广泛应用。但DFT中存在能量泄露和栅栏效应,使得这种方法具有很大的误差,并且算法精度在很大程度上依赖于采样长度N。多位学者对正弦波信号频率估计问题作了进一步研究,相继提出了多种频率估计算法。例如Rife算法[4]、Quinn算法[5]、能量重心矫正法[6]、牛顿迭代法[7]、频率校正复比值法[8]、加三角窗的频谱校正算法[9]和三次插值频率估计算法及其改进算法[10]等一系列算法,其中Rife算法因为算法简单且易于实现而被广泛应用于信号处理领域。文献[11]对Rife算法进行了分析,指出Rife算法在被估计信号频率位于量化频率点附近且信噪比较低时,算法的频率估计误差比较大。为此,本文利用频谱细化的方法,提出一种改进的Rife频率估计算法。另外,为了消除Rife算法在信噪比较低时因为插值方向错误而增加的频率估计误差,本文提出对被估计信号进行加窗处理(非矩形窗)的方法对算法进行进一步的修正。理论分析和仿真实验证明了算法的可行性和有效性。
单一频率实正弦信号表示为
式中:a、f0和θ0分别为正弦信号的幅度、频率和初相。按等间隔Δt=T/N对x(t)在[ ]0,T 区间内进行采样,得到长度为N的序列x(n),x(n)的N点DFT记为 X(k),鉴于实序列的DFT对称性,只考虑离散频谱的正频率成份,有
取其中的最大谱线值记作X(k0)。Rife算法主要是利用DFT谱中最大谱线与次大谱线的比值求解相对频率偏差δ(-0.5~0.5),对FFT算法进行修正,其计算公式为
式中:Δf=1/T,为Rife算法的频率分辨率;正负号根据次大谱线的位置确定。
对Rife算法原理的分析可得Rife算法的频率估计计算公式为
在合适的信噪比条件下,如果信号的实际频率f处于其DFT谱中最大谱线与次大谱线之间的中心区域时,Rife算法的估计性能比较好,频率估计的误差远小于直接使用DFT算法。反之,如果信噪比较低且信号频率 f十分接近其DFT谱中最大谱线的位置时,频率估计误差有可能大于直接使用DFT算法。Rife算法的这一特性可以总结为:当信号频率 f很接近最大谱线与次大谱线中点时,次大谱线的幅度|与最大谱线 | X(k0)|的幅度很接近,此时Rife算法具有较高的估计精度,如图1所示。
图1 信号频率位于最大谱线与次大谱线的中心区域
当信号频率 f很接近最大谱线时,即次大谱线的幅度 | X(k0+r)|很小,此时Rife算法的估计精度比较低,如图2所示。
图2 信号频率远离最大谱线与次大谱线的中心区域
由图2和图3可知,采样信号DFT谱中的最大谱线和次大谱线都在sinc函数的主瓣内。在没有噪声干扰时,信号DFT谱中的次大谱线的幅度永远大于第一旁瓣内的谱线幅度,因此不会出现插值方向错误的情况。但是当有噪声干扰时,当相对频率偏差δ的绝对值较小时,有可能出第一旁瓣内的谱线幅度大于主瓣内次大谱线幅度的情况,从而造成频率插值方向相反,产生较大的频率估计误差。
文献[11]给出了Rife算法频率估计的总误差
式中erfc()为补误差函数。Rife算法的频率估计均方根误差为
从第2节的分析可知,当信号频率 f位于其DFT谱中两根最大谱线之间的中心区域时,Rife算法的估计性能很高;但当信号频率 f靠近其DFT谱中最大谱线时,算法估计性能急剧下降。针对Rife算法的这一特性,本文提出利用频谱细化的方法对信号次大谱线的位置进行搬移,从而使信号频率 f始终位于其DFT谱中两根最大谱线之间的中心区域。该算法的基本思想是:定义(k0+1/3,k0+2/3)为离散频率点k0和k0+1之间的中心区域,设由Rife算法得到的频率估计值为 f̂,判断 f̂是否位于DFT谱中最大谱线和次大谱线之间的中心区域,如果是,则将 f̂作为最后的频率估计值,否则对信号DFT谱进行适当的细化,使信号的估计频率 f̂始终位于其DFT谱中两根最大谱线的中心区域,这样就可以保证Rife算法一直具有较高的估计精度。
假设信号采样序列x(n)经FFT运算法以后的频谱 X(k)为
求得最大谱线的位置k0和信号频率的粗略估计 k0Δf,根据式(3)计算信号频率估计值 f̂。因为始 终 有满 足≤2/3⋅Δf,则认为信号频率估计值 f̂位于其DFT谱中最大谱线与次大谱线之间的中心区域,此时 f̂可作为信号频率的最终估计值。反之,则需要进行修正。
由FFT变换后的幅度谱曲线可知,利用频谱细化的方法可以求出X(k0±0.5)。假设次大谱线位于最大谱线的左侧,则利用 X(k0-0.5)和X(k0)估计信号的实际频率。若X(k0)≥X(k0-0.5),则
若 X(k0)<X(k0-0.5),则
由式(8)或式(9)求得信号频率的估计值 f̂,如果满足1/3频率估计的最终值,否则还需要对 X(k0-0.5)和X(k0)之间的信号在进行细化,直至求得的信号频率的估计值
为了消除Rife算法由于插值方向错误而增大的频率估计误差,本文提出在对信号进行DFT变换之前对信号进行加窗(非矩形窗)处理。对信号进行加窗处理之后可以使信号DFT谱的主瓣宽度变宽,从而使主瓣内可以包含更多谱线,同时也使得位于最大谱线两侧的次大谱线和第三大谱线更容易区分,从而避免出现插值方向错误的情况。
改进Rife算法的算法流程图如图3所示。
图3 改进Rife算法流程图
具体的算法步骤如下。
1)对采样信号x(n)进行加窗处理并做FFT运算,得 X(k);
2)对 X(k)进行模运算,并求其最大值X(k0);
3)利用Rife算法求得信号频率的估计值 f̂;
4)计算信号频率估计值 f̂与信号频率粗略估计值 k0fs/N差值的绝对值 dif。若1/3⋅Δf<dif≤2/3⋅Δf ,转向步骤6),否则继续步骤5);
5)当次大谱线位于最大谱线的左侧时,进行一次频谱细化得 X(k0-0.5/i),其中i为频谱细化的次数(i=1,2,……)。再次利用Rife算法对信号进行频率估计,求得信号频率的估计值 f̂。当次大谱线位于最大谱线的右侧时,进行一次频谱细化得 X(k0+0.5/i),其中i为频谱细化的次数(i=1,2,……)。再次利用Rife算法对信号进行频率估计,求得信号频率的估计值 f̂,转向步骤4);
6)此时由改进Rife算法得到的信号频率估计值 f̂即为信号最终的估计频率。
设仿真信号为
式中:w(t)是均值为0、方差为σ2的高斯白噪声。信号的信噪比定义为 SNR=a2/σ2。采样频率fs=200kHz,采样间隔 Δt=5×10-6s,样本点数N=1024。设载波频率 f0=fs/4=50kHz,令fi=f0+δ⋅Δf,将 δ在区间[0,0.5]上均匀分成20个频率点,对每个分点进行500次蒙特卡洛模拟。实正弦信号的频率估计方差下限(即CRLB)为[12]
在信噪比SNR分别为2、0、-2 dB的条件下分别使用Rife算法和改进Rife算法对上述仿真信号进行频率估计,各算法的估计均方误差曲线如图4所示。
从图4可以看出:当信号的次大谱线幅度比较小,即相对频率偏差δ比较小时,Rife算法的频率估计误差比较大;改进Rife算法在较宽信噪比条件下,无论相对频率偏差δ取-0.5~0.5之间的任何值,该算法都能准确地估计信号的频率。可见:不管在估计的精度还是稳定性上,本文提出的改进Rife算法都明显优于Rife算法。
为了检验算法的抗噪能力,在信噪比范围-5dB~5dB,频率 f0=30kHz的条件下,对每个信噪比独立试验200次,得到2种算法的频率估计均方误差(Mean Square Error)曲线如图5所示。
图4 Rife算法和改进Rife算法在不同信噪比下的估计均方误差曲线
图5 2种算法频率估计均方误差曲线
从图5可以看出:Rife算法在信噪比较低时,估计性能明显下降;而本文提出的改进Rife算法在很宽的信噪比范围内估计误差都比较小且与CRLB十分接近。因此,改进Rife算法的抗噪能力相比于Rife算法有了较大提高。另外本文对各个频点的频谱细化次数做了统计,并计算出其平均值i=0.4382。从计算结果来看,改进Rife算法的计算量相比于Rife算法增加的并不是很多。
Rife算法是一种常用的基于FFT插值的频率估计算法,具有计算速度快、实时性能好、利于硬件实现等特点,在工程领域得到了广泛的应用。本文在对Rife算法进行分析基础上提出了一种改进Rife频率估计算法。仿真结果表明本算法准确有效,能够效地提高Rife算法的频率估计精度和稳定性,估计误差接近CRLB;且算法简单、计算量小、能够较好的解决传统频率估计算法在估计精度和计算量上的矛盾,具有较大的工程应用价值。
[1]万灵达,杨晓光.一种基于FFT的高精度频率估计算法[J].电子科技,2010,23(10):79-81.WAN Lingda,YANG Xiaoguang.A high-accuracy frequency estimation algorithm based on FFT[J].Electronic Science&Technology,2010,23(10):79-81.
[2]王宏伟,赵国庆,齐飞林.一种实时精确的正弦波频率估计算法[J].数据采集与处理,2009,24(2):208-211.WANG Hongwei,ZHAO Guoqing,QI Feilin.Real-time and accurate single frequency estimation approach[J].Journal of Data Acquisition&processing,2009,24(2):208-211.
[3]齐国清.利用FFT相位差校正信号频率和初相位估计的误差分析[J].数据采集与处理,2003,18(1):7-11.QI Guoqing.Error analysis of frequency and phase estimations based on phase difference of segmented FFTs[J].Journal of Data Acquisition&processing,2003,18(1):7-11.
[4]D.Rife,R.Boorstyn.Single tone parameter estimation from discrete-time Observations[J].IEEE Trans.on Information Theory,1974,20(5):591-598.
[5]B.G.Quinn,P.Kootsookos.Threshold behavior of the maximum likelihood estimator of frequency[J].IEEE Trans.on Signal Processing,1994,42(11):3291-3294.
[6]丁康,江利旗.离散频谱的能量重心校正法[J].振动工程学报,2001,14(3):354-358.DING Kang,JIANG Liqi.Energy centrobaric correction method for discrete spectrum[J].Journal of Vibration Engineering,2001,14(3):354-358.
[7]邓振淼,刘渝.正弦波频率估计的牛顿迭代方法初始值研究[J].电子学报,2007,1(1):104-107.DENG Zhenmiao,LIU Yu.The starting point problem of sinusoid frequency estimation based on Newton's method[J].Acta Electronica sinica,2007,1(1):104-107.
[8]陈奎孚,王建立,张森文.频谱校正的复比值法[J].振动工程学报,2008,21(3):314-318.CHEN Kuifu,WANG Jianwen,ZHANG Senwen.Spectrum correction based on the complex ratio of discrete spectrum around the main-lobe[J].Journal of Vibration Engineering,2008,21(3):314-318.
[9]张强,张频,张明童.加三角窗的频谱校正[J].振动与冲击,2009,28(2):96-98.ZHANG Qiang,ZHANG Pin,ZHANG Mingtong.Spectrum correction with a Triangular Window[J].Journal of Vibration and Shock,2009,28(2):96-98.
[10]胡东,李东生.三次插值频率估计估计的改进算法[J].计算机工程与应用,2010,46(24):154-156.HU Dong,LI Dongsheng.Improved algorithm of cubic interpolated frequency estimation[J].Computer Engineering and Applications,2010,46(24):154-156.
[11]齐国清,贾欣乐.插值FFT估计正弦信号频率的精度分析[J].电子学报,2004,32(4):625-629.QI Guoqing,JIA Xinle.Accuracy analysis of frequency estimation of sinusoid based on interpolated FFT[J].Acta Electronica sinica,2004,32(4):625-629.
[12]刘银恩.高精度频率估计算法研究[D].南京:南京理工大学,2007.LIU Yinen.Research on high precision frequency estimation algorithm[D].Nanjing:Nanjing University of Science and Technology,2007.