基于OFDM的通信链路误码率matlab仿真,采用多径信道,卷积编码,16QAM

154 阅读3分钟

1.算法描述

        在通信系统中,信道所能提供的带宽通常比传送一路信号所需的带宽要宽得多。如果一个信道只传送一路信号是非常浪费的,为了能够充分利用信道的带宽,就可以采用频分复用的方法。

       OFDM主要思想是:将信道分成若干正交子信道,将高速数据信号转换成并行的低速子数据流,调制到在每个子信道上进行传输。正交信号可以通过在接收端采用相关技术来分开,这样可以减少子信道之间的相互干扰(ISI) 。每个子信道上的信号带宽小于信道的相关带宽,因此每个子信道上可以看成平坦性衰落,从而可以消除码间串扰,而且由于每个子信道的带宽仅仅是原信道带宽的一小部分,信道均衡变得相对容易。

        OFDM技术是HPA联盟(HomePlug Powerline Alliance)工业规范的基础,它采用一种不连续的多音调技术,将被称为载波的不同频率中的大量信号合并成单一的信号,从而完成信号传送。由于这种技术具有在杂波干扰下传送信号的能力,因此常常会被利用在容易受外界干扰或者抵抗外界干扰能力较差的传输介质中。

 

       在通信系统中,信道所能提供的带宽通常比传送一路信号所需的带宽要宽得多。如果一个信道只传送一路信号是非常浪费的,为了能够充分利用信道的带宽,就可以采用频分复用的方法。

 

       OFDM主要思想是:将信道分成若干正交子信道,将高速数据信号转换成并行的低速子数据流,调制到在每个子信道上进行传输。正交信号可以通过在接收端采用相关技术来分开,这样可以减少子信道之间的相互干扰(ISI) 。每个子信道上的信号带宽小于信道的相关带宽,因此每个子信道上可以看成平坦性衰落,从而可以消除码间串扰,而且由于每个子信道的带宽仅仅是原信道带宽的一小部分,信道均衡变得相对容易。

 

        OFDM技术是HPA联盟(HomePlug Powerline Alliance)工业规范的基础,它采用一种不连续的多音调技术,将被称为载波的不同频率中的大量信号合并成单一的信号,从而完成信号传送。由于这种技术具有在杂波干扰下传送信号的能力,因此常常会被利用在容易受外界干扰或者抵抗外界干扰能力较差的传输介质中。

 

       一个OFDM符号之内包含多个经过相移键控(PSK)或者正交幅度调制(QAM)的子载波。

 

       一旦要把传输的比特分配到各个子载波上,某一种调制模式则将他们映射为子载波的幅度和相位,通常采用等效基带信号来描述OFDM的输出信号:

95f5c90f3134cb6ee99aef1e8358a9e4_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png  

       其中信号的实部和虚部分别对应OFDM的同相和正交分量,在实际系统可以分别与对应的c o s coscos分量和s i n sinsin分量相乘。

1066d39815e5f2a9e2767d90d182cfe4_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png

2.仿真效果预览

matlab2022a仿真结果如下:

aef19d8fb5c9c5d679ed5316a7c227f3_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png

850d5100b9d1ff5ec861c6aabb18a194_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png 3.MATLAB核心程序 `Assuming the channel response is invariant during one frame

pilot_sym = pilot_generator(128);               % Generate the pilot symbols, all in BPSK modulation

pilot_syms=pilot_sym';

pilot_syms=pilot_syms(:)';

idx=0;

for snr = 0:4:40

    idx=idx+1;

    nframe = 0;

    nerror = 0;

    while nframe < frame_num

        nframe

 

        info_bits = round(rand(1, N_DBPF));     % Generate the information bites randomly

        tail = zeros(1,6);                      % Tail bits for convolutional encoder

        info_bits = [info_bits tail];           % Append the tail bits to the infomation bits

        trl = poly2trellis(7,[133 171]);        % Trellis structure of convolutional encoder,

                                                % Constraint length K = 7,generator polynomial in octal g0 = 133, g1 = 171

        code_bits = convenc(info_bits, trl);    % Convolutional encoder,rate R = 1/2

        TX = tx_16qam_mod(code_bits); % 16-QAM modulation

        figure(1)

        a=real(TX);

        b=imag(TX);

        plot(a,b,'bx')

        pilot_num = 1;               % The start number of the cyclic pilot symbols

        tx = tx_fre_to_time(TX,N_SPF,pilot_syms,pilot_num);    % Serial to parallel,Add pilot symbols, IFFT ( Oversampling),Add cyclic prefix                                      

 

        temp_channel = channel_response(:,nframe+1).'; % Channel response at the current frame

        ry = channel_multipath(tx,temp_channel);      % Multi-path channel

        ry = awgn(ry,snr);                            % Add addictive white gaussian noise

 

        [RY,R_pilot] = ry_time_to_fre(ry,N_SPF,temp_channel); % Recover the time signal to frequency symbols of each subcarrier and Channel Equalization

        figure(2)

        a=real(RY);

        b=imag(RY);

        plot(a,b,'bx')

        axis([-2 2  -2 2]);

        hold on

        Rcode_bits = ry_16qam_demod(RY);                        % Demodulate the received symbols

        dec_bits = ry_sovadec(Rcode_bits, trl, N_DBPF,N_DBPF);  % Soft output viterbi decoding, out = ln( p(info_bits(i)=1)/p(info_bits(i)=0));

     

        for i = 1:N_DBPF

            if dec_bits(i) >= 0

                hard_det(i) = 1;                                % hard_det refers to the hard decision   

            else

                hard_det(i) = 0;

            end

            if hard_det(i) ~= info_bits(i)

                nerror = nerror+1;

            end

        end

        nframe = nframe + 1;

    end

    BER(idx) = nerror/(frame_num * N_DBPF);

end`