hammingdecod.m

来自「下面这个是汉明码编译码的matlab程序」· M 代码 · 共 21 行

M
21
字号
function g=hammingdecod(R)
H=[1 1 1 0 1 0 0 ;0 1 1 1 0 1 0;1 1 0 1 0 0 1];
R=input('输入接收序列R=');
S=mod(R*H',2);  %计算R的伴随式
m=0;
for i=1:1:7
if S==H(:,i)'
   m=1;
   E=dec2bin(2^(7-i),7);  %计算R的错误图样
   fprintf('错误出现在第%1.0f位\n',i);
   break;
end
end
if m==0
    disp('接收到的码字无错误。');
    E=dec2bin(0,7);
end
    a=mod(R-E,2); %计算原发送码序列
   disp('原发送码字为:');
   disp(a)
  

⌨️ 快捷键说明

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