www.pudn.com > mentos_fs.rar > PrimePe_iw.m


%计算经过卷积编码和交织之后的误码率,检测内编码和交织的抗早性能,加高斯噪声及突发干扰 
function [sig_err_rate2]=PrimePe_iw(snr_in_dB) 
% snr_in_dB=0; 
%噪声功率 
E=1; 
snr=10^(snr_in_dB/10); 
sgma=sqrt((E/snr)/2); 
%桢个数 
N=10; 
%突发间隔 
N_Interval=80; 
%突发长度 
N_Length=10; 
%信息序列 
signal=round(rand(1,N*267));      %内编码器输入序列,一级189bit,二级78bit 
 
in_en_sig=zeros(1,N*456);         %初始化卷积编码器输出矩阵 
in_de_sig=zeros(1,N*267);         %初始化卷积译码器输出矩阵 
 
inter=zeros(1,N*456+456);         %初始化交织器输出矩阵 
counter=zeros(1,N*456+456);       %初始化去交织输出矩阵 
 
for n=0:N-1   %对每桢进行编码 
  %内编码 
  in_en_sig(n*456+1:n*456+456)=T_FS_IN_EN(signal(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); 
 
% %加高斯燥声 
% in_en_sig=2*in_en_sig-1; 
% in_en_sig=sign(in_en_sig+sgma*randn(size(in_en_sig))+eps); 
% in_en_sig=(in_en_sig+1)/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)); 
% in_de_sig(n*267+1:n*267+267)=T_FS_IN_DE(in_en_sig(n*456+1:n*456+456)); 
end 
%验证 
sig_err_rate2=(length(find(signal~=in_de_sig)))/length(signal)   %误码率