比特在传输过程中可能会产生差错,1可能会变成0,0也可能会变成1,这就是比特差错。比特差错是传输差错中的一种。
通常利用编码技术进行差错控制,主要有两类:自动重传请求ARQ和前向纠错FEC。
因此,差错控制又可分为检错编码和纠错编码。
检错编码都采用冗余编码技术,其核心思想是在有效数据(信息位)被发送前,先按某种关系附加一定的冗余位,构成一个符合某一规则的码字后再发送。当要发送的有效数据变化时,相应的冗余位也随之变化,使得码字遵从不变的规则。接收端根据收到的码字是否仍符合原规则来判断是否出错。
常见的检错编码有奇偶校验码和循环冗余码。
奇偶校验码是奇校验码和偶校验码的统称,是一种最基本的检错码。它由n-1位信息元和1位校验元组成,如果是奇校验码,那么在附加一个校验元后,码长为n的码字中“1”的个数为奇数,这是奇数校验码 ;如果是偶校验码,那么在附加一个校验元以后,码长为n的码字中“1”的个数为偶数。它只能检测奇数位的出错情况,(如果有一组刚好出错,1的奇偶却不变,则无法查清楚是否出错)。
循环冗余码 (Cyclic Redundancy Code, CRC) 又 称多项式码。一个 k 位帧可以视为从 X k − 1 X^{k-1} Xk−1 到 $ X^{0}$ 的 k 次多项式的系数序列, 这个多项式的阶数为 k-1, 例如, 1110011 有 7 位, 表示成多项式是 X 6 + X 5 + X 4 + X + 1 X^{6}+X^{5}+X^{4}+ X+1 X6+X5+X4+X+1
给定一个m bit的帧或报文, 发送器生成一个r bit的序列,称为帧检验序列(FCS) 就是余数。这样所形成的帧将由m+r比特组成。发送方和接收方事先商定一个多项式G(x)(最高位和最低位必须为1),使这个带检验码的帧刚好能被预先确定的多项式G(x)整除。接收方用相同的多项式去除收到的帧,如果无余数,那么认为无差错。
假设一个帧有m位,其对应的多项式为Mx),则计算冗余码的步骤如下:
注意:循环冗余码(CRC)是具有纠错功能的,只是数据链路层仅使用了它的检错功能,检测到帧出错则直接丢弃。
最常见的纠错编码是海明码,其实现原理是在有效信息位中加入几个校验位形成海明码,并把海明码的每个二进制位分配到几个奇偶校验组中。当某一位出错后,就会引起有关的几个校验位的值发生变化,这不但可以发现错位,而且能指出错位的位置,为自动纠错提供依据。
现以数据码 1010 为例讲述海明码的编码原理和过程。
设 n 为有效信息的位数, k 为校验位的位数, 则信息位 n 和校验位 k 应满足
n
+
k
≤
2
k
−
1
n+k \leq 2^{k}-1
n+k≤2k−1 (若要检测两位错, 则需再增加 1 位校验位, 即 k+1 位)
海明码位数为
n
+
k
=
7
≤
2
3
−
1
n+k=7 \leq 2^{3}-1
n+k=7≤23−1 成立, 则 n 、 k 有效。设信息位为
D
4
D
3
D
2
D
1
(
1010
)
D_{4} D_{3} D_{2} D_{1}(1010)
D4D3D2D1(1010) , 共 4 位, 校验位为
P
3
P
2
P
1
P_{3} P_{2} P_{1}
P3P2P1 , 共 3 位, 对应的海明码为
H
7
H
6
H
5
H
4
H
3
H
2
H
1
H_{7} H_{6} H_{5} H_{4} H_{3} H_{2} H_{1}
H7H6H5H4H3H2H1。
规定校验位
P
i
P_{i}
Pi 在海明位号为
2
i
−
1
2^{i-1}
2i−1 的位置上, 其余各位为信息位, 因此有:
P
1
P_{1}
P1 的海明位号为
2
i
−
1
=
2
0
=
1
2^{i-1}=2^{0}=1
2i−1=20=1 , 即
H
1
H_{1}
H1 为
P
1
P_{1}
P1 。
$ P_{2}$ 的海明位号为 $ 2{i-1}=2{1}=2$ , 即
H
2
H_{2}
H2 为
P
2
P_{2}
P2 。
$ P_{3}$ 的海明位号为
2
i
−
1
=
2
2
=
4
2^{i-1}=2^{2}=4
2i−1=22=4 , 即
H
4
H_{4}
H4 为
P
3
P_{3}
P3 。
将信息位按原来的顺序揷入, 则海明码各位的分布如下:
H 7 H 6 H 5 H 4 H 3 H 2 H 1 D 4 D 3 D 2 P 3 D 1 P 2 P 1 \begin{array}{lllllll} H_{7} & H_{6} & H_{5} & H_{4} & H_{3} & H_{2} & H_{1} \\ D_{4} & D_{3} & D_{2} & P_{3} & D_{1} & P_{2} & P_{1} \end{array} H7D4H6D3H5D2H4P3H3D1H2P2H1P1
每个数据位用多个校验位进行校验, 但要满足条件: 被校验数据位的海明位号等于校验该数 据位的各校验位海明位号之和。另外, 校验位不需要再被校验。分组形成的校验关系如下。
校验位 P i P_{i} Pi 的值为第 i 组 (由该校验位校验的数据位) 所有位求异或。 根据(3)中的分组有
P
1
=
D
1
⊕
D
2
⊕
D
4
=
0
⊕
1
⊕
1
=
0
P_{1}=D_{1} \oplus D_{2} \oplus D_{4}=0 \oplus 1 \oplus 1=0
P1=D1⊕D2⊕D4=0⊕1⊕1=0
P
2
=
D
1
⊕
D
3
⊕
D
4
=
0
⊕
0
⊕
1
=
1
P_{2}=D_{1} \oplus D_{3} \oplus D_{4}=0 \oplus 0 \oplus 1=1
P2=D1⊕D3⊕D4=0⊕0⊕1=1
P
3
=
D
2
⊕
D
3
⊕
D
4
=
1
⊕
0
⊕
1
=
0
P_{3}=D_{2} \oplus D_{3} \oplus D_{4}=1 \oplus 0 \oplus 1=0
P3=D2⊕D3⊕D4=1⊕0⊕1=0
所以, 1010 对应的海明码为 1010010(下画线为校验位, 其他为信息位)。
每个校验组分别利用校验位和参与形成该校验位的信息位进行奇偶校验检查, 构成 k 个校验方程:
S 1 = P 1 ⊕ D 1 ⊕ D 2 ⊕ D 4 S 2 = P 2 ⊕ D 1 ⊕ D 3 ⊕ D 4 S 3 = P 3 ⊕ D 2 ⊕ D 3 ⊕ D 4 \begin{array}{l} S_{1}=P_{1} \oplus D_{1} \oplus D_{2} \oplus D_{4} \\ S_{2}=P_{2} \oplus D_{1} \oplus D_{3} \oplus D_{4} \\ S_{3}=P_{3} \oplus D_{2} \oplus D_{3} \oplus D_{4} \end{array} S1=P1⊕D1⊕D2⊕D4S2=P2⊕D1⊕D3⊕D4S3=P3⊕D2⊕D3⊕D4
若 S 3 S 2 S 1 S_{3} S_{2} S_{1} S3S2S1 的值为 “ 000 ”, 则说明无错; 否则说明出错, 且这个数就是错误位的位号, 如 S 3 S 2 S 1 = 001 S_{3} S_{2} S_{1}=001 S3S2S1=001 , 说明第 1 位出错, 即 H 1 H_{1} H1 出错, 直接将该位取反就达到了纠错的目的。