RS编译码理论介绍与MATLAB性能仿真

1.问题描述:

         RS编译码是一种非二进制编译码,RS编译码的码元符号取自伽罗达域GF(2m)。输入的信息可分为k*m比特一组,每组k个符号由m比特组成,而不是二进制BCH码中的一个比特。目前RS编译码中,RS(255,239)编译码被广泛应用于海底光纤通信系统中,该信道编译码包括239个bit信息以及16个校验字节。该码型可以纠正最多8个字节的错误。

        该信道编译码的生成多项式为:

其中信息字节I的表达式为:

        RS译码算法,一般通过Chien搜索算法进行计算错误位置,用Forney算法计算错误值。

 

2.部分程序:

 

clc;
clear;
close all;
warning off;
addpath 'func\'; 

%参数初始化
k            = 239;       
n            = 255;       
Len          = log2(n+1);
Simu_Len     = k;  %仿真的时间长度
Simu_time    = 1;
SNR          = [0:1:9];
TJL          = 5000;
Rs_Encoder   = fec.rsenc(n,k);
Rs_Decoder   = fec.rsdec(Rs_Encoder);

%主体代码
for i = 1:length(SNR)
    i
    Bit_err(i)    = 0; %设置误码率参数
    Num_err       = 0; %蒙特卡洛模拟次数
    Numbers       = 0; %误码率累加器
    while Num_err <= TJL 
          fprintf('Eb/N0 = %f\n', SNR(i));
          Num_err 
          %产生信号
          msg      = (double(rand(1,Simu_Len)>0.5))';
          %编码
          Msg_Enc  = encode(Rs_Encoder,msg);
          %转换为二进制
          Msg_Enc2 = func_dec2bin(Msg_Enc,Len);
          Msg_Enc3 = 2*Msg_Enc2-1; 
          %通过信道
          Msg_Enc4 = awgn(Msg_Enc3,SNR(i),'measured');
        
          %二进制转换为十进制
          Msg_Enc5 = ones(size(Msg_Enc4)); 
          Msg_Enc5(find(Msg_Enc4<=0)) = 0;
          Msg_Enc6 = func_bin2dec(Msg_Enc5,Len);
        
          %译码
          [Msg_Dec,cnumerr,ccode] = decode(Rs_Decoder,Msg_Enc6');
          %计算误码率
          Err                     = biterr(Msg_Dec,msg);
          Num_err                 = Num_err+Err;
          Num_err
          Numbers                 = Numbers+1;
    end  
    Bit_err(i) = Num_err/(length(Msg_Enc3)*Numbers);  
end

%曲线仿真
figure;
semilogy(SNR,Bit_err,'b-o');
xlabel('SNR');
ylabel('BER');
grid on;
save data.mat SNR Bit_err

3.仿真结论:

我们对RS(255,239)编译码以及RS(31,15)两种编译码算法的误码率性能进行仿真分析。

D44

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fpga和matlab

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值