基于OFDM的IEEE802.11a系统仿真

Posted 一只学习的猫

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于OFDM的IEEE802.11a系统仿真相关的知识,希望对你有一定的参考价值。

1 前言

1998年IEEE802.11组织将OFDM作为了物理层标准。
接下来首先介绍IEEE802.11的OFDM技术标准的详细情况,然后给出一个简化的IEEE802.11a OFDM系统的仿真,在仿真中暂不考虑扰码和卷积编码等。OFDM系统物理层采用802.11a系统物理层参数,1个长训练符号+6个OFDM符号构成1帧,设置信道为瑞利衰落信道,最大多普勒频移为100Hz,仿真信噪比Eb/N0为0~30db,选择QPSK调制和16QAM调制,比较接收端采用理想信道估计和利用训练符号进行信道估计时的误比特率性能。

2 IEEE802.11的OFDM技术

IEEE802.11a OFDM系统的主要参数如下表:
在这里插入图片描述

3 单径信道下的IEEE802.11a系统仿真

3.1 参数设置

Nsp=52;             %系统子载波数(不包括直流载波)
Nfft=64;            % FFT 长度
Ncp=16;             % 循环前缀长度
Ns=Nfft+Ncp;        % 1个完整OFDM符号长度
noc=53;             % 包含直流载波的总的子载波数
Nd=6;               % 每帧包含的OFDM符号数(不包括训练符号)
M1=4;               % QPSK调制
M2=16;              % 16-QAM调制
sr=250000;          % OFDM符号速率
EbNo=0:2:30;      	% 归一化信噪比
Nfrm=10000;                         % 每种信噪比下的仿真帧数
ts=1/sr/Ns;                         % OFDM符号抽样时间间隔
t=0:ts:(Ns*(Nd+1)*Nfrm-1)*ts;       % 抽样时刻
fd=100;                             % 最大多普勒频移
h=rayleigh(fd,t);                   % 生成单径Rayleigh衰落信道

%训练符号频域数据,采用802.11a中的长训练符号数据
Preamble=[1 1 -1 -1 1 1 -1 1 -1 1 1 1 1 1 1 -1 -1 1 1 -1 1 -1 1 1 1 1 ...
    1 -1 -1 1 1 -1 1 -1 1 -1 -1 -1 -1 -1 1 1 -1 -1 1 -1 1 -1 1 1 1 1];
Preamble1=zeros(1,Nfft);
Preamble1(2:27)=Preamble(27:end);                   % 训练符号重排后的数据
Preamble1(39:end)=Preamble(1:26);
preamble1=ifft(Preamble1);                          % 训练符号时域数据
preamble1=[preamble1(Nfft-Ncp+1:end) preamble1];    % 加入循环前缀

程序说明:
生成单径的瑞利衰落信道的采样周期和信号的采样周期一致。

3.2 不同信噪比下的系统仿真

for ii=1:length(EbNo)
    
    %**************************发射机部分 *****************************
    msg1=randsrc(Nsp,Nd*Nfrm,[0:M1-1]);         % QPSK信息数据
    msg2=randsrc(Nsp,Nd*Nfrm,[0:M2-1]);         % 16-QAM信息数据
    data1=pskmod(msg1,M1,pi/4);                 % QPSK调制
    data2=qammod(msg2,M2)/sqrt(10);             % 16-QAM调制并归一化

    data3=zeros(Nfft,Nd*Nfrm);                  % 根据FFT要求,对数据重排
    data4=zeros(Nfft,Nd*Nfrm);

    data3(2:27,:)=data1(27:end,:);
    data3(39:end,:)=data1(1:26,:);

    data4(2:27,:)=data2(27:end,:);
    data4(39:end,:)=data2(1:26,:);
        
    clear data1 data2;                          % 清除不需要的临时变量

    data3=ifft(data3);                          % IFFT变换
    data4=ifft(data4);

    data3=[data3(Nfft-Ncp+1:end,:);data3];      % 加入循环前缀
    data4=[data4(Nfft-Ncp+1:end,:);data4];

    spow1=norm(data3,'fro').^2/(Nsp*Nd*Nfrm);   % 计算数据符号能量
    spow2=norm(data4,'fro').^2/(Nsp*Nd*Nfrm);
        
    data5=zeros(Ns,(Nd+1)*Nfrm);                % 加入训练符号
    data6=data5;
    for indx=1:Nfrm
        data5(:,(indx-1)*(Nd+1)+1)=preamble1.';
        data5(:,(indx-1)*(Nd+1)+2:indx*(Nd+1))=data3(:,(indx-1)*Nd+1:indx*Nd);
            
        data6(:,(indx-1)*(Nd+1)+1)=preamble1.';
        data6(:,(indx-1)*(Nd+1)+2:indx*(Nd+1))=data4(:,(indx-1)*Nd+1:indx*Nd);
    end
        
    clear data3 data4
        
    data5=reshape(data5,1,Ns*(Nd+1)*Nfrm);              % 并串变换    
    data6=reshape(data6,1,Ns*(Nd+1)*Nfrm);
      
    sigma1=sqrt(1/2*spow1/log2(M1)*10.^(-EbNo(ii)/10)); % 根据EbNo计算噪声标准差
    sigma2=sqrt(1/2*spow2/log2(M2)*10.^(-EbNo(ii)/10));
        
        
    for indx=1:Nfrm
        dd1=data5((indx-1)*Ns*(Nd+1)+1:indx*Ns*(Nd+1)); % 当前帧的发射数据
        dd2=data6((indx-1)*Ns*(Nd+1)+1:indx*Ns*(Nd+1));
          
        hh=h((indx-1)*Ns*(Nd+1)+1:indx*Ns*(Nd+1));      % 当前帧对应的信道参数 
        
        % 信号通过单径Rayleigh衰落信道,并加入高斯白噪声
        r1=hh.*dd1+sigma1*(randn(1,length(dd1))+j*randn(1,length(dd1)));   
        r2=hh.*dd2+sigma2*(randn(1,length(dd2))+j*randn(1,length(dd2)));
            
        r1=reshape(r1,Ns,Nd+1);                         % 串并变换
        r2=reshape(r2,Ns,Nd+1);

        r1=r1(Ncp+1:end,:);                             % 移除循环前缀
        r2=r2(Ncp+1:end,:);            

           
        %%%%%%%%%%%%%%% 理想信道估计 %%%%%%%%%%%%%%%%%%%%%%%%%   
        hh=reshape(hh,Ns,Nd+1);                     % 信道参数数据重排
        hh=hh(Ncp+1:end,:);
        x1=r1(:,2:end)./hh(:,2:end);                % 理想信估计结果
        x2=r2(:,2:end)./hh(:,2:end);

        x1=fft(x1);                                 % fft运算
        x2=fft(x2);

        x1=[x1(39:end,:);x1(2:27,:)];               % 数据重排
        x2=[x2(39:end,:);x2(2:27,:)];

        x1=pskdemod(x1,M1,pi/4);                    % 数据解调
        x2=qamdemod(x2*sqrt(10),M2);
        [neb1(indx),temp]=biterr(x1,msg1(:,(indx-1)*Nd+1:indx*Nd),log2(M1)); % 统计一帧中的错误比特数
        [neb2(indx),temp]=biterr(x2,msg2(:,(indx-1)*Nd+1:indx*Nd),log2(M2));
            
        %%%%%%%%%%%%%% 根据训练符号进行的信道估计 %%%%%%%%%%%%%%%%%%%%%%%  

        R1=fft(r1);                                 % fft运算
        R2=fft(r2);

        R1=[R1(39:end,:);R1(2:27,:)];               % 数据重排
        R2=[R2(39:end,:);R2(2:27,:)];
       
        HH1=(Preamble.')./R1(:,1);                  % 信道估计
        HH2=(Preamble.')./R2(:,1);                   
        
        HH1=HH1*ones(1,Nd);                         % 根据信道估计结果进行信道补偿
        HH2=HH2*ones(1,Nd);

        x3=R1(:,2:end).*HH1;                        
        x4=R2(:,2:end).*HH2;

        x3=pskdemod(x3,M1,pi/4);                    % 数据解调
        x4=qamdemod(x4.*sqrt(10),M2);        

         [neb3(indx),temp]=biterr(x3,msg1(:,(indx-1)*Nd+1:indx*Nd),log2(M1)); % 统计一帧中的错误比特数
         [neb4(indx),temp]=biterr(x4,msg2(:,(indx-1)*Nd+1:indx*Nd),log2(M2));
   end
   ber1(ii)=sum(neb1)/(Nsp*log2(M1)*Nd*Nfrm);     % 理想信道估计的误比特率
   ber2(ii)=sum(neb2)/(Nsp*log2(M2)*Nd*Nfrm);

   ber3(ii)=sum(neb3)/(Nsp*log2(M1)*Nd*Nfrm);     % 根据训练符号信道估计的误比特率
   ber4(ii)=sum(neb4)/(Nsp*log2(M2)*Nd*Nfrm);
            
end

程序说明:

  1. 关于计算噪声标准差的推导:
    在这里插入图片描述
  2. 信号通过单径瑞利衰落信道,并叠加高斯白噪声
    因为是单径信道,因此直接将信号矢量与信道矢量对应相乘,再叠加高斯白噪声。即:
r1=hh.*dd1+sigma1(randn(1,length(dd1))+j*randn(1,length(dd1)));   
r2=hh.*dd2+sigma2(randn(1,length(dd2))+j*randn(1,length(dd2)));

3.3 不同信噪比下的系统性能

程序如下:

semilogy(EbNo,ber1,'-ro',EbNo,ber3,'-rv',EbNo,ber2,'-r*',EbNo,ber4,'-rd')
grid on
title('OFDM系统误比特率性能')
legend('QPSK理想信道估计','QPSK训练符号信道估计','16-QAM理想信道估计','16-QAM训练符号信道估计')
xlabel('信噪比(EbNo)')
ylabel('误比特率')

仿真结果如下:
在这里插入图片描述
从上述仿真结果可以看到,理想的信道估计性能要优于利用训练符号进行信道估计的性能,这是因为信道在1帧的时间内,并不是不变的(有多谱勒频移),所以利用训练符号得到的信道估计值进行信道均衡,不可避免的会产生误差。

4 多径信道下的IEEE802.11a系统仿真

4.1 参数设置

OFDM系统参数和第2节的参数设置相同,只是信道由单径信道变为了2径信道。

Nsp=52;             %系统子载波数(不包括直流载波)
Nfft=64;            % FFT 长度
Ncp=16;             % 循环前缀长度
Ns=Nfft+Ncp;        % 1个完整OFDM符号长度
noc=53;             % 包含直流载波的总的子载波数
Nd=6;               % 每帧包含的OFDM符号数(不包括训练符号)
M1=4;               % QPSK调制
M2=16;              % 16-QAM调制
sr=250000;          % OFDM符号速率
EbNo=0:2:30;      	% 归一化信噪比
Nfrm=10000;                         % 每种信噪比下的仿真帧数
ts=1/sr/Ns;                         % OFDM符号抽样时间间隔
t=0:ts:(Ns*(Nd+1)*Nfrm-1)*ts;      % 抽样时刻
fd=100;                             % 最大多普勒频移
h=rayleigh(fd,t);                   % 生成单径Rayleigh衰落信道
h1=sqrt(2/3)*h;
h2=sqrt(1/3)*rayleigh(fd,t);
h2=[zeros(1,4) h2(1:end-4)];
%训练符号频域数据,采用802.11a中的长训练符号数据
Preamble=[1 1 -1 -1 1 1 -1 1 -1 1 1 1 1 1 1 -1 -1 1 1 -1 1 -1 1 1 1 1 ...
    1 -1 -1 1 1 -1 1 -1 1 -1 -1 -1 -1 -1 1 1 -1 -1 1 -1 1 -1 1 1 1 1];
Preamble1=zeros(1,Nfft);
Preamble1(2:27)=Preamble(27:end);                   % 前导重排后的数据
Preamble1(39:end)=Preamble(1:26);
preamble1=ifft(Preamble1);                          % 训练符号时域数据
preamble1=[preamble1(Nfft-Ncp+1:end) preamble1];    % 加入循环前缀

程序说明:
对于生成的2径信道,时延分别为0和20e-8s(对应延迟4个采样点),并且第2径平均功率比第1径低3dB。

4.2 不同信噪比下的系统仿真

for ii=1:length(EbNo)
     %**************************发射机部分 *****************************
    msg1=randsrc(Nsp,Nd*Nfrm,[0:M1-1]);         % QPSK信息数据
    msg2=randsrc(Nsp,Nd*Nfrm,[0:M2-1]);         % 16-QAM信息数据

    data1=pskmod(msg1,M1,pi/4);                 % QPSK调制
    data2=qammod(msg2,M2)/sqrt(10);             % 16-QAM调制并归一化

    data3=zeros(Nfft,Nd*Nfrm);                  % 根据FFT要求,对数据重排
    data4=zeros(Nfft,Nd*Nfrm);

    data3(2:27,:)=data1(27:end,:);
    data3(39:end,:)=data1(1:26,:);

    data4(2:27,:)=data2(27:end,:);
    data4(39:end,:)=data2(1:26,:);
        
    clear data1 data2;                           % 清除不需要的临时变量

    data3=ifft(data3);                          % IFFT变换
    data4=ifft(data4);

    data3=[data3(Nfft-Ncp+1:end,:);data3];      % 加入循环前缀
    data4=[data4(Nfft-Ncp+1:end,:);data4];

    spow1=norm(data3,'fro').^2/(Nsp*Nd*Nfrm);   % 计算符号能量
    spow2=norm(data4,'fro').^2/(Nsp*Nd*Nfrm);
        
    data5=zeros(Ns,(Nd+1)*Nfrm);                % 加入训练符号
    data6=data5;
    for indx=1:Nfrm
        data5(:,(indx-1)*(Nd+1)+1)=preamble1.';
        data5(:,(indx-1)*(Nd+1)+2:indx*(Nd+1))=data3(:,(indx-1)*Nd+1:indx*Nd);
         
        data6(:,(indx-1)*(Nd+1)+1)=preamble1.';
        data6(:,(indx-1)*(Nd+1)+2:indx*(Nd+1))=data4(:,(indx-1)*Nd+1:indx*Nd);
    end
        
    clear data3 data4;                                  % 清除不需要的临时变量
        
    data5=reshape(data5,1,Ns*(Nd+1)*Nfrm);               % 并串变换    
    data6=reshape(data6,1,Ns*(Nd+1)*Nfrm);
        
    data51=zeros(1,length(data5));
    data61=zeros(1,length(data6));
    data51(5:end)=data5(1:end-4);
    data61(5:end)=data6(1:end-4);
       
    sigma1=sqrt(1/2*spow1/log2(M1)*10.^(-EbNo(ii)/10)); % 根据EbNo计算噪声标准差
    sigma2=sqrt(1/2*spow2/log2(M2)*10.^(-EbNo(ii)/10));

    for indx=1:Nfrm
        dd1=data5((indx-1)*Ns*(Nd+1)+1:indx*Ns*(Nd+1));
        dd2=data6((indx-1)*Ns*(Nd+1)+1:indx*Ns*(Nd+1));
        dd3=data51((indx-1)*Ns*(Nd+1)+1:indx*Ns*(Nd+1));
        dd4=data61((indx-1)*Ns*(Nd+1)+1:indx*Ns*(Nd+1));
            
        hh=h((indx-1)*Ns*(Nd+1)+1:indx*Ns*(Nd+1));      % 当前帧的单径信道参数
        hh1=h1((indx-1)*Ns*(Nd+1)+1:indx*Ns*(Nd+1));    % 当前帧的2径信道参数
        hh2=h2((indx-1)*Ns*(Nd+1)+1:indx*Ns*(Nd+1));
            
        % 信号通过单径衰落信道,并加入高斯白噪声
        r1=hh.*dd1+sigma1*(randn(1,length(dd1))+j*randn(1,length(dd1)));   
        r2=hh.*dd2+sigma2*(randn(1,length(dd2))+j*randn(1,length(dd2)));
            
        % 信号通过2径衰落信道,并加入高斯白噪声
        r11=hh1.*dd1+hh2.*dd3+sigma1*(randn(1,length(dd1))+j*randn(1,length(dd1)));   
        r21=hh1.*dd2+hh2.*dd4+sigma2*(randn(1,length(dd2))+j*randn(1,length(dd2)));   

        r1=reshape(r1,Ns,Nd+1);                     % 串并变换
        r2=reshape(r2,Ns,Nd+1);

        r11=reshape(r11,Ns,Nd+1);
        r21=reshape(r21,Ns,Nd+1);

        r1=r1(Ncp+1:end,:);                         % 移除循环前缀
        r2=r2(Ncp+1:end,:);            

        r11=r11(Ncp+1:end,:);  
        r21=r21(Ncp+1:end,:);
            
        R1=fft(r1);                                 % fft运算
        R2=fft(r2);

        R11=fft(r11);
        R21=fft(r21);

        R1=[R1(39:end,:);R1(2:27,:)];               % 数据重排
        R2=[R2(39:end,:);R2(2:27,:)];
        R11=[R11(39:end,:);R11(2:27,:)];
        R21=[R21(39:end,:);R21(2:27,:)];
          
        HH1=(Preamble.')./R1(:,1);                  % 信道估计
        HH2=(Preamble.')./R2(:,1);                   
        
        HH11=(Preamble.')./R11(:,1);            
        HH21=(Preamble.')./R21(:,1); 
            
        HH1=HH1*ones(1,Nd);
        HH2=HH2*ones(1,Nd);
        HH11=HH11*ones(1,Nd);
        HH21=HH21*ones(1,Nd);        
            
        x1=R1(:,2:end).*HH1;                        % 信道补偿
        x2=R2(:,2:end).*HH2;
        x3=R11(:,2:end).*HH11;                      
        x4=R21(:,2:end).*HH21;
        
        x1=pskdemod(x1,M1,pi/4);                    % 数据解调
        x2=qamdemod(x2.*sqrt(10),M2);
            
        x3=pskdemod(x3,M1,pi/4);                  
        x4=qamdemod(x4.*sqrt(10),M2);        

        [neb1(indx),temp]=biterr(x1,msg1(:,(indx-1)*Nd+1:indx*Nd),log2(M1)); % 统计一帧中的错误比特数
        [neb2(indx),temp]=biterr(x2,msg2(:,(indx-1)*Nd+1:indx*Nd),log2(M2));
        [neb3(indx),temp]=biterr(x3,msg1(:,(indx-1)*Nd+1:indx*Nd),log2(M1)); 
        [neb4(indx),temp]=biterr(x4,msg2(:,(indx-1)*Nd+1:indx*Nd),log2(M2));
    end
    ber1(ii)=sum(neb1)/(Nsp*log2(M1)*Nd*Nfrm);     % 理想信道估计的误比特率
    ber2(ii)=sum(neb2)/(Nsp*log2(M2)*Nd*Nfrm);

    ber3(ii)=sum(neb3)/(Nsp*log2(M1)*Nd*Nfrm);     % 非理想信道估计的误比特率
    ber4(ii)=sum(neb4)/(Nsp*log2(M2)*Nd*Nfrm);           
end

程序说明:
信道通过2径信道时并叠加高斯白噪声的代码:

r11=hh1.*dd1+hh2.*dd3+sigma1*(randn(1,length(dd1))+j*randn(1,length(dd1)));   
        r21=hh1.*dd2+hh2.*dd4+sigma2*(randn(1,length(dd2))+j*randn(1,length(dd2)));   

4.3 不同信噪比下的系统性能

semilogy(EbNo,ber1,'-ro',EbNo,ber3,'-rv',EbNo,ber2,'-r*',EbNo,ber4,'-rx')
grid on
title('OFDM系统误比特率性能')
legend('QPSK 单径信道','QPSK 2径信道','16-QAM 单径信道','16-QAM 2径信道')
xlabel('信噪比(EbNo)')
ylabel('误比特率')

在这里插入图片描述
从上述仿真结果可以看到,系统在单径和2径信道下的性能接近,说明只要信道最大延迟不超过循环前缀的长度,在解调过程中就不会产生码间串扰。

5 总结

以上主要介绍了基于OFDM的IEEE802.11a系统的matlab仿真。

参考:
《详解Matlab/Simulink通信系统建模与仿真》

以上是关于基于OFDM的IEEE802.11a系统仿真的主要内容,如果未能解决你的问题,请参考以下文章

WiFi识别基于simulink建模实现IEEE802.11g 标准WiFi信号识别算法仿真

基于simulink的WiMax通信系统仿真,包括RS编译码,卷积编译码,OFDM,输出星座图和频谱图

WLAN802.11

现代通信基于OFDM通信系统仿真matlab源码

现代通信基于matlab OFDM通信系统仿真含Matlab源码 1005期

OFDM频域同步基于OFDM数字电视地面广播系统中频域同步技术matlab仿真