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 + -
显示快捷键?