白话海明码

本文深入浅出地介绍了海明校验码的基本概念、工作原理及其在数据传输中的纠错功能。通过一个具体的示例详细阐述了如何构造和计算海明码,包括确定校验码长度、插入校验位和计算校验值的过程。此外,还探讨了奇偶校验的概念以及校验位的定位规则,有助于读者从逻辑到代码层面理解海明码的实现。

定义

海明校验码(又称汉明码)是一种特殊的(n,k)线性纠错码,由 Richard Hamming 于 1950 年提出,故以发明人命名。海明码具有检错和纠错双功能,它基于奇偶校验原理,能检查2位错误,但只能纠正1位错误。当有多位错码时,它就不适用了。

原理

基于重叠奇偶校验的概念:将原始数据位分成若干个重叠的组,每组设一位奇偶校验位。由于组间有重叠,因此每位原始数据从属于多于一个组。而且每位原始数据的从属关系是不一样的,纠错时,根据哪些组的奇偶校验位出错,就可以唯一地确定是哪一位数据出错。将该位取反就完成了纠错。
总结一 奇偶校验
奇偶校验就是在原始的二进制串中加入0或1,使得串中的1的总数为奇数或偶数,称为奇偶校验。
总结二 海明码校验位的值就是所有被检验位置的1的奇偶结果,偶数为0,奇数为1,也就是所有被校验位置的异或值。
总结三 校验位的位置是固定的,遵循2^n规则,如1,2,4,8,16…
总结四 校验码的长度n遵循:(假设数据为m位二进制)2^n >= n+m+1
总结五 被校验位的位置是校验位的位置的1的匹配位。若校验位位置为1,校验长度为3,那么匹配表达式为将二进制补全到校验长度。1 = 01 = 001 ==> xx1,此时,带校验码的串中所有符合xx1的数据位置都是被校验位。

示例

假设我们传输1001这一串数据,现在要对其做海明码,保证传输结果在接收时可检验是否正确。那步骤如下:

1、确定校验码长度

套入我们上述总结中的2^n >= n+m+1,m=4,解一元方程,n的最小值为3,所以,校验码长度为n=3.

2、扩容

将数据存放总长度扩容为 n+m,也就是

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值