YunSDR通信小课堂-27
第11讲 802.11a OFDM基带接收端载波频率同步算法设计与验证
OFDM技术是同时在多个重叠子信道上传输信号的,为了正确接收,必须严格保证子载波之间的正交性,但是由于多普勒频移和收发晶振的不完全相同,往往存在一定的载波频率偏差,这将破坏子载波之间的正交性,且这种频差对相位的影响还具有累加性。因此,为了保证OFDM性能,必须进行载波频率同步。在802.11a中前导允许接收机在实际信息分组部分尚未到达之前,采用最大似然算法估计频率偏移并进行修正。因此,载波同步是利用训练信息完成的。对于802.11a,不管是长训练符号还是短训练符号均满足这种需求。
11.1 实验目的
学习IEEE802.11a的接收端频偏估计算法,使用Matlab编程语言实现IEEE802.11a基带接收端得的频偏估计算法并验证。通过理论研究,频偏模拟以及实际频偏估计等实验结果的对比,深刻理解频偏的影响以及OFDM系统的频偏敏感特性。
11.2 实验条件
YunSDR平台一套,Matlab软件环境,WiFi频段天线。
11.3 实验要求
使用Matlab搭建IEEE802.11a基带发送端,首先验证OFDM系统的理论抗频偏特性,其次通过模拟频偏来验证理论数据的极限值;最后通过YunSDR将基带信号经过射频发射出去并使用另一台YunSDR(或者一台YunSDR自发自收)进行接收,进行频偏估计,将实际频偏估计值与理论值比较,验证算法的正确性。
11.4 实验原理
IEEE 802.1la WLAN系统的频率同步估计可以从时域上进行估计也可以从频域上进行估计,这种方法要求训练序列至少有两个连续重复的符号,这一点在IEEE 802.1laWLAN系统中其前导部分无论是长、短训练序列都可以满足要求。
在本系统中,我们从时域进行频偏估计,先用短训练序列进行粗频偏估计校正,再用长训练序列进行细频偏估计校正,两种频偏估计的方法类似,这里我们只介绍粗频偏估计。
原理:设s(m,n)(n=1,2…N)表示发送端IFFT变换之后第m个OFDM符号的第n个子载波上采样值,r(m,n)(n=l,2… N)表示接收端FFT变换之前第m个OFDM符号的第n个子载波上的采样值,N为两个连续符号相同采样点之间的延时,Ts为采样时间,f1为发送载波频率,f2为接收载波频率。
其中angle()表示求复数的相角运算。
EEE802.1la系统中,短训练序列符号取样时问为50ns,延时N=16,则可以估计的最大频率误差fmax=1/(2*N*Ts)=1/(2*16*50*10^(-9)),如果使用长训练序列,那么它和短训练序列的唯一区别就是N=64,则长训练序列可以估计的最大频率误差为156.2kHz。虽然用短训练序列进行频偏估计误差比较大,但是其可以估计的范围比较大,这就是我们为什么要先用短训练序列进行粗频偏估计再用长训练序列进行细频偏估计的原因。
11.5 参考设计
此系统的频偏估计分为粗频偏估计与精频偏估计,分别利用了短训练序列和长训练序列,所以理论抗频偏性能分别为20MHz/32=625KHz和20MHz/128=156KHz;但是两种频偏估计的算法一致,只是因为训练序列的长度不同而导致频偏估计的范围不同,这里先使用粗频偏估计估算出大范围的频率偏差,然后用精频偏估计进行小范围的频率偏差的估计。图11-1为两种频偏估计所采用的算法框架图:
以下Matlab程序为粗频偏估计的代码片段,与框架图算法保持一致。
D = 16;
phase = rxsignal(1:16).*conj(rxsignal(17:32));
% add all estimates
phase = sum(phase, 2);
freq_est = -angle(phase) / (2*D*pi/20000000);
radians_per_sample = 2*pi*freq_est/20000000;
siglen=length(rxsignal(1,:));
time_base=0:siglen-1;
correction_signal=exp(-j*radians_per_sample*time_base);
原文地址:https://blog.csdn.net/V3_Bs/article/details/144760467
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!