欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 金融 > BCH码误码率ber性能仿真(MATLAB)

BCH码误码率ber性能仿真(MATLAB)

2025/10/27 4:19:33 来源:https://blog.csdn.net/m0_72904009/article/details/140663164  浏览:    关键词:BCH码误码率ber性能仿真(MATLAB)

BCH码

        不同于奇偶校验码只能检验数据传输是否出错,BCH码可以实现对数据的检验和纠错

        BCH(n,k)中的n代表总码元,k代表有效码元,相应的n-k即代表纠错码元

        本文着重比较分析BCH(255,207),BCH(255,131),BCH(255,87)的性能

仿真图

        BCH(255,207)的码率为207/255=0.81,BCH(255,131)的码率为0.51,BCH(255,87)的码率为0.34,就传输效率来看,BCH(255,207)显著优于其他两者

        但是就误码率分析,BCH(255,87)显著优于其他两者,当信噪比为7时,BCH(255,87)的误码率甚至接近于10^-4,这是因为BCH的纠错码元数为255-87=168,多于其余二者

MATLAB代码(版本为2024a)

clc;
clear all;
close all;
warning off;SNR  = [0:1:8];
count = 800;
N    = 255; 
K    = [207,131,87];
for m = 1:length(K)
Bit_err=zeros(1,9);
for i = 1:length(SNR)disp(['当前进度:',num2str((i+m*9-9)/27*100),'%'])Num_err       = 0; Numbers       = 0; while Numbers <= count message    = randi([0,1],1,K(m));msg        = gf(message);BCHcode_gf = bchenc(msg,N,K(m));BCHcode_double=zeros(1,N);for code_j=1:Nif BCHcode_gf(1,code_j)==1BCHcode_double(1,code_j)=1;endendBCH_receive = awgn(BCHcode_double,SNR(i),'measured');receive_decoded  = zeros(1,N);for hard_j=1:Nif BCH_receive(hard_j)>0.5receive_decoded(hard_j)=1;endendreceive_decoded=gf(receive_decoded);BCHdecode = bchdec(receive_decoded,N,K(m));BCHdecode_double = zeros(1,K(m));for gf_to_double_j=1:K(m)if BCHdecode(gf_to_double_j)==1BCHdecode_double(gf_to_double_j)=1;endendErr = biterr(BCHdecode_double,message);Num_err = Num_err + Err;Numbers = Numbers + 1;endBit_err(i) = Num_err/(length(message)*Numbers);
endif m==1figure;semilogy(SNR,Bit_err,'b-o');xlabel('SNR');ylabel('BER');grid on;elseif m==2hold onsemilogy(SNR,Bit_err,'r-s');elseif m==3hold onsemilogy(SNR,Bit_err,'g-d');legend('BCH(255,207)','BCH(255,131)','BCH(255,87)');end
end

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词