海明码简介
海明码是由Richard Hanming于1950年提出的,它具有一位纠错能力。
海明码的计算
设欲检测的二进制代码为n位,为使其具有纠错能力,需要添加k位检测位,组成n+k位的代码。为了能准确对错误定位以及指出代码没错,新添加的检测位数k应满足:2k ≥ n+k+1
由此关系可求得不同代码长度n所需要检测位的位数k。
海明码的编码规则如下:
设k个校验位为Pk,Pk-1,·····,P1, n个数据位为 Dn-1,Dn-2,·····,D1,D0,对应的海明码为Hn+k,Hn+k-1,······,H1,那么
(1)Pi在海明码的第2i-1位置,比如P1,21-1=1,所以在H1的位置。
(2)海明码中的任何一位都是由若干个校验位来校验的。其对应关系如下:被校验的海明位的下标等于所有参与校验该为的校验位的下标之和,而校验位由自身校验。比如H12,下标为12,等于8+4,所以是海明码的第8、第4位校验位来检测的。
举例
对于8位的数据位,进行海明校验需要4个校验位(2k ≥ n+k+1,24 ≥ 8+4+1)。令数据位为D7,D6,D5,D4,D3,D2,D1,D0,校验位为P4,P3,P2,P1,形成的海明码为H

详解&spm=1001.2101.3001.5002&articleId=115606013&d=1&t=3&u=e07072df4f2549768acdb70b7c1d2151)
2万+

被折叠的 条评论
为什么被折叠?



