rx_init_viterbi.m

来自「全部的译码器的程序是用matlab编程的」· M 代码 · 共 26 行

M
26
字号
function rx_init_viterbi

global sim_consts;
global prev_state;
global prev_state_outbits;

sim_consts = struct( 'ConvCodeGenPoly', [1 0 1 1 0 1 1;1 1 1 1 0 0 1 ]);%定义卷积编码器的生成矩阵
prev_state = zeros(64, 2);
prev_state_outbits = zeros(64, 2, 2);

for state = 0:63
   state_bits = (fliplr(kron(dec2bin(state,6),1))~=48);%移位寄存器的状态
   input_bit= state_bits(1)
   for transition = 0:1
      prev_state_bits = [state_bits(2:6) transition];%上一级的移位寄存器的状态
      prev_state(state+1,transition+1) = base2dec(fliplr(prev_state_bits)+48,2);%用来存储上一级移位寄存器状态
      
      %第一个生成器的输出码字
      prev_state_outbits(state+1, transition+1, 1) = 2*(rem(sum(sim_consts.ConvCodeGenPoly(1,:).* ...
         [input_bit prev_state_bits ]),2)) - 1;
     %第二个生成器的输出码字
      prev_state_outbits(state+1, transition+1, 2) = 2*(rem(sum(sim_consts.ConvCodeGenPoly(2,:).* ...
         [input_bit prev_state_bits]),2)) - 1;
   end
end

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?