差错控制
数据在存储和传输的过程中可能会发生错误,可以使用差错控制减少错误。
差错控制是在数字通信中使用编码方法对传输过程中的错误进行检查和纠正,确保数字信号传输的准确性。
- 数据校验码
能够自动发现错误,或者纠正错误的数据编码,又称检错纠错码
- 码距
任意两个码字之间最少变化的二进制位数称为码距,例如用4位二进制码表示16种状态(8421码),两个码字之间的最少变化的二进制位为1(0000 和0001 只需要变化一位)
- 码距太短的编码不能作为数据校验码,因为当在数据传输中一个bit位出错就变成了另一个码字,不具有发现错误的能力。
-
码距和检错误纠错
-
在一个码组内为了检测e个误码 要求最小码距满足 d≥e+1
-
在一个码组内为了纠正t个误码 要求最小码距满足 d≥2t+1
一、奇偶校验码
一种码距为2简单的校验码,由码距和检错纠错关系我们可得 2≥e+1 所以e≤1,那么使用奇偶校验码可以检查出一位的错误,不能纠正错误。
- 常用于存储器读取检查,ASCII字符传送检查
- 实现方法
校验位形成
- 由若干有效信息位加上一个值为0或1的二进制校验位组成校验码,在加入校验位后通过统计校验码中所包含的1的数量为奇数还是偶数分为奇校验和偶校验。
校验检测
-
奇校验中的1位数最为奇数个则信息正确,否则错误。偶校验同理。
-
多重奇偶校验
由于奇偶校验码只能发现一位出错,当两位同时出错时就又回归正确,在横向位置和纵向位置同时设置校验码,这样即使同一行或列同时出现错误也能够发现。(电路是具有一定可靠性的,所以同时出现3位错误几乎不可能出现)
二、汉明码
一种多重奇偶校验码,在有效的信息位中加入几个校验位形成校验码,使码距均匀的拉大,把汉明码每一个校验位均匀的分配道多个校验组中,当一位发生错误,多校验组收到影响,不仅可以实现检测,还可以实现纠错。
1.冗余位
校验位数K和有效信息位数N应满足以下公式
2.校验码形成
若汉明码最高位索引为m,最低位为1
-
m=
校验位和信息位数量之和 -
校验位被放置在汉明码中位置为
假设给定有效信息码为
- 加入校验位占位
| D/P | |||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 索引 | 12 | 11 | 10 | 9 | 7 | 6 | 5 | 3 | 13 | ||||
| 值 | 1100 | 1011 | 1010 | 1001 | 1000 | 0111 | 0110 | 0101 | 0100 | 0011 | 0010 | 0001 | 1101 |
- 校验位值
在校验位加入后,我们确定每一个检验组的组成,将 中所对应的 信息位中索引值二进制中 位为划分为一组,通过异或运算求的对应值
则
由于找不到匹配的值,我们发现不同信息位出现的次数不一致,我们将出现次数少的信息项运算得到
每个信息项都关联3个校验组,当一位出现错误时会牵动3个校验组,提高了检错效率
三、Cyclic Redundancy Check(CRC)
循环冗余校验
通过除法运算建立有效信息位和校验位之间的约束关系。
-
有效信息为
- M(X)
-
生成多项式
-
发送方和接收方约定一致
-
G(X)
-
位数为
-
除法均位模2除法
- 校验码生成 1
- 校验码生成 2
- 校验成功
- 校验失败
当校验码和生成式的模2除法结不能整除时说明数据出错
- 多项式转换
| 1 | 0 | 1 | 0 | 0 | 1 |
则
意为这一位在给定的多项式中是否存在,存在则为1不存在则为0