📄 primepe_eiw.m
字号:
%计算在高斯噪声及突发错误干扰下编码系统误码率
function [sig_err_rate3]=PrimePe_eiw(snr_in_dB)
echo off
close all
% snr_in_dB=0;
%噪声功率
E=1;
snr=10^(snr_in_dB/10);
sgma=sqrt((E/snr)/2);
%桢个数
N=30;
%突发间隔
N_Interval=80;
%突发长度
N_Length=10;
%信息序列
signal=round(rand(1,N*260));
%初始化
ex_en_sig=zeros(1,N*267);
in_en_sig=zeros(1,N*456);
in_de_sig=zeros(1,N*267);
ex_de_sig=zeros(1,N*260);
inter=zeros(1,N*456+456);
counter=zeros(1,N*456+456);
for n=0:N-1
%编码
%外编码
ex_en_sig(n*267+1:n*267+189)=T_FS_EX_EN(signal(n*260+1:n*260+182));
ex_en_sig(n*267+190:n*267+267)=signal(n*260+183:n*260+260);
%内编码
in_en_sig(n*456+1:n*456+456)=T_FS_IN_EN(ex_en_sig(n*267+1:n*267+267));
end
%交织
inter=INTER_WEAVE_8(in_en_sig);
%加高斯燥声
inter=2*inter-1;
inter=sign(inter+sgma*randn(size(inter))+eps);
inter=(inter+1)/2;
%加突发噪声
Noise=BurstNoise(N_Interval,N_Length,length(inter));
inter=mod(inter+Noise,2);
%去交织
counter=COUNTER_WEAVE_8(inter);
for n=0:N-1
%译码
%内译码
in_de_sig(n*267+1:n*267+267)=T_FS_IN_DE(counter(n*456+1:n*456+456));
%外译码
ex_de_sig(n*260+1:n*260+182)=T_FS_EX_DE(in_de_sig(n*267+1:n*267+189));
ex_de_sig(n*260+183:n*260+260)=in_de_sig(n*267+190:n*267+267);
end
%验证
sig_err_rate3=(length(find(signal~=ex_de_sig)))/length(signal) %系统误码率
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -