海明码的思想经常用到,有必要进行深入学习。
首先,海明码是一种可以纠正一位错误的二进制编码。一种编码的纠错能力取决于该编码的码距,下面介绍码距。
如图1所示的一个编码系统,用三位二进制来表示八个不同信息。在这个系统中,两个码字之间不同的位数从1到3不等,但最小值为1,故这个系统的码距为1。如果任何码字中一位或多位出了差错,结果这个码字就不能与其它码字区分。例如,如果传送信息001,而被误收为011,因011仍是表中的合法码字,接收方仍将认为011是正确的信息。但是,如果用四个二进数字来编8个码字,那么在码字间的最小距离可以增加到2,如图2的表中所示。
图1 图 2
注意,图2的8个码字相互间最少有两位的差异。因此,如果任何码字的一个数位出差错,就成为一个不用的码字,就能检查出来。例如信息是1001,误收为1011,接收方知道发生了一个差错,因为1011表中没有,不是一个码字。然而,差错不能被纠正。因为,正确码字可以是1001,1111,0011或1010。接收方不能确定原来到底是这4个码字中的哪一个。同时, 在这个系统中,偶数个(2位或4位)差错也无法发现。
为了使一个系统能纠正一位差错,码距最小是3。最小距离为3时,或能纠正一位错,或能检测二位错,但不能同时纠正一位错并检测二位错。编码信息纠错和检错能力的提高需要进一步增大编码系统的码距。图3的表概括了编码系统的码距为1至7时,码的纠错和检错能力。
r2=k3+k2+k1;r1=k3+k2+k0; r0=k3+k1+k0.其中+代表异或。
其中s2,s1,s0称为校正因子。若没有错,三个校正因子都为0,若不全为0,则有错误发生,错误的位置在S=S2 S1 S0。