计算机组成原理中的三种校验方式

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

码距为1码制,即不能查错也不能纠错。
码距越大的码制,查错、纠错能力越强。
1 奇偶校验法
奇偶校验法是计算机中广泛采用的检查传输数据准 确性的方法。奇偶校验法的原理是: 在每组数据信息上附加一个校验位,校验位的取值 (0或1)取决于这组信息中‘1’的个数和校验方式(奇 或偶校验)。 如果采用奇校验,则这组数据加上校验码位后数据 中‘1’的个数应为奇数个。奇校验位形成公式:
即:
H15 H14 H13 H12 H11 H10 H9 H8 H7 H6 H5 H4 H3 H2 H1 D10 D9 D8 D7 D6 D1 P3 D0 P2 P1 D5 D4 P4 D3 D2
海明码的每一位用多个校验位一起进行校验, 被校验的位号等于校验它的各校验位位号和; 各校验位的值为它参与校验的数据位的异或。
k 位(信息位) R 位(校验位)
数据位k与校验位r的对应关系:
2r≥k+r+1 (3.18)(一位出错并纠错) r(最小) 2 3 4 5 6
k 1 2~4 5~11 12~26 27~57
2r-1≥k+r
(3.19) (一位出错并纠错并发现两位错) 码距为4
由3.19式计 算可得
2、编码规则 若海明码的最高位号为 m,最低位号为 1,即: HmHm-1…H2H1,则此海明码的编码规律: (1) 校验位与数据位之和为 m ,每个校验位 Pi 在 海明码中被分在位号 2i-1 的位置,其余各位为数据 位,并按从低向高逐位依次排列的关系分配各数据 位。 (2) 海明码的每一位码 Hi( 包括数据位和校验位 本身 ) 由多个校验位校验,其关系是被校验的每一 位位号要等于校验它的各校验位的位号之和。这样 安排的目的 , 是希望校验的结果能正确反映出出错 位的位号。
计算机中的数据校验方法
采用冗余校验方法: 即在基本的有效数据外,再扩充部分 位,增加部分(冗余部分)被称为校验位。 将校验位与数据位一起按某种规则编码, 写入存储器或向外发送。当从存储器读出或 接收到外部传入的代码时,再按相应的规则 进行判读。若约定的规则被破坏,则表示出 现错误。根据错误的特征进行修正恢复。
1、纠查一位错的编码方法
(以四个校验位进行说明)
wenku.baidu.com
四个校验位最多可以校验11位数据。设: D10D9D8D7D6D5D4D3D2D1D0为11个数据位, P4P3P2P1分别为四个校验码,则编码规则是: ‐ 海明码的总位数H等于数据位与校验位之和;
‐ 每个校验位Pi排放在2i-1的位置,如P4排放
在第24-1=8位,其余数据位依序排列。
例如:八位信息‘10101011’中共有5个‘1’, 附加校验位后变为九位。 若采用奇校验,则附加的校验位应取‘0’值, 保证1的个数为奇数个即 0 10101011 ; 若采用偶校验则附加的校验位应取‘1’值即 1 10101011 。 奇偶校验的特点:
1、奇偶校验法可检出数据传送过程中奇数个 数位出错的情况; 2、实际中两位同时出错的概率极低,奇偶校 验法简便可靠易行,但它只能发现错误,却不知
错在何处,因而不能自动纠正。
为了使一个系统能检查和纠正一个差错,码间最小距离必须至
少是“3”。最小距离为3时,或能纠正一个错,或能检二个错,
但不能同时纠一个错和检二个错。编码信息纠错和检错能力的 进一步提高需要进一步增加码字间的最小距离。
• 码能力 • 码距 检错 纠错 1 2 0 1 0 0
码距越大,纠错能力越强,但数据
冗余也越大,即编码效率低了。所
以,选择码距要取决于特定系统的 参数。
3
4 5
2或1
2加1 2加2
6
7
3加2
3加3
2

海明码校验方法
海明码是一种比较常用的纠错码,它实际上是
一种多重奇偶校验码。其基本思想是将被检验 码分成多个组,每组配备一个奇偶校验位完成 该组的奇偶校验位的功能。当被校验码中某一 位出错时,将会有相关的多个小组出现奇偶校
验错,根据这些组的出错情况便可将错误定位
到某一位上从而即可纠正过来。
◇强调指出:海明码校验方法以奇偶校验法为基础, 其校验位不是一个而是一组。海明码校验方法能 够检测出具体错误并纠正。

海明码的最低目标是能纠正一位错,因此要求
海明码的码距大于或等于3。
海明校验码是Richard Hamming于1950年提出的,目前仍 广泛使用的一种编码方法。 1、原理 ( 1 )特点:能检测出两位同时出错、亦能检测出一位出错 并能自动纠错。 (2)实现原理: 在k个数据位之外加上r个校验位,从而形成一个k十r位 的新码字,当某一位出错后,就会引起相关的几个校验位 的值发生变化,从而达到检错、纠错的目的。
几个名词概念:
码字:由若干代码组成的一个字。
如8421码中6(0110),7(0111)
码距:一种码制中任意两个码字间的最小距离。
距离:两个码字之间不同的代码个数。
8421码中,最小的码字间的距离为1,如0000和 0001、0010和0011等;最大码字间的距离为4, 如0111和1000。所以8421码制的码距为1。
H9 H10 H11 H12 H13
P4
D4 D5 D6 D7 D8
8
8,1 (8=8+1) 8,2 (10=8+2) 8,2,1 (11=8+2+1) 8,4 (12=8+4) 8,4,1 (13=8+4+1)
P4
P4,P1 P4,P2 P4,P2,P1 P4,P3 P4,P3,P1
C =X0 ⊕X1 ⊕…⊕Xn-1 如果采用偶校验,则这组数据加上校验码位后数据 中‘1’的个数应为偶数个。偶校验位形成公式: C =X0 ⊕X1 ⊕…⊕Xn-1
• 在接收端校验检测:
• 偶校验:P=C ⊕ X0 ⊕X1 ⊕…⊕Xn-1
• 奇校验:P=C
⊕ X0 ⊕X1 ⊕…⊕Xn-1
• 若P=0则无错或有偶数位错,若P=1则有奇数位 错
海明码位号 H1 P1
参与校验的校验位位号 1
参与的校验位 P1
H2
H3 H4 H5 H6 H7
P2
D0 P3 D1 D2 D3
2
2,1 4 4,1 4,2 (5=4+1) (6=4+2) (3=2+1)
P2
P2 P3 P3,P1 P3,P2 P3,P2,P1 P1
4,2,1 (7=4+2+1)
H8
相关文档
最新文档