3.7 数据校验码
校验码的计算方法
校验码的计算方法一、为什么要设置给原代码设置校验码?代码是数据的重要组成部分,它的正确性将直接影响系统的质量。
当人们抄写、录入时,发生错误的可能性很大,如抄写错(把1234写成1235)、易位错(1234记为1243)、隔位易位错(1234记为1432)等等。
因此,为了验证输入代码的正确性,要在代码本体的基础上,再外加校验码(通常算出后置于补在原代码的最后面),使它成为代码的一个组成部分。
二、补上校验码后系统怎么确认其正确与否?(工作原理)校验码是根据事先规定好的数学方法及代码本体计算出来的。
当计算后的自检码输入系统,系统将按照同样的数学方法,也对代码本体进行计算,将它得出的结果与原来计算出来的校验位比较,检验输入的代码是否正确(只要双方一致就说明是正确的)。
三、校验码的生成过程如下:(计算方法)(1)对代码本体的每一位加权求和设代码本体为C1、C2^Cn,权因子为P1、P2^Pn,加权求和:S=ΣCi Pi。
其中权因子可取自然数1,2,3,…,几何级数2,4,8,16,32,…,质数2,3,5,7,11,…,等等。
(2)以模除和得余数R=Smod(M)其中:R表示余数;M表示模数,可取M=10,11,等等。
(3)模减去余数得校验位四、实例:代码本体为123456,权因子为1,7,3,1,7,3,模为10,则:S=ΣCi Pi=1×1+2×7+3×3+4×1+5×7+6×3=81R=S MOD M=81 mod (10)=1校验位为:J=M–R=10—1=9所以自检码为1234569,其中9为校验位。
(这个实例惟一缺的就是公式的规范性,请用课本p154-155的公式然后才算)关键点:P自然数请反过来从7 ――― 1,得出余数后直接用余数作校验位,不要用模10去减它了。
2、原编码: 5 8 9 6 4 3 7权因子: 7 6 5 4 3 2 1乘积之和:S=35 + 48 +45 +24 +12 +6 +7 = 177R= S MOD M = 177 MOD 10 =7J = M – R=10-7=3原代码加校验码:58964377。
第7讲_校验码
S1 P D1 D2 D4 D5 D7 1
S2 P2 D1 D3 D4 D6 D7
S3 P3 D2 D3 D4 D8
S 4 P4 D5 D6 D7 D8
校验得到的结果S4 S3 S2S1的值构成指误字,能反映该12位海 明码出错情况:
jlsheng@
11
指误字(Syndrome Word) ① S4S3S2S1 =0000,表明无错误。 ② S4S3S2S1中只有一位不为0,表明是某一校验位出错,出错 的是该Si对应的Pi位,不需纠正。也可能是3位海明码(包括数 据位和校验位)同时出错,但无法指出是哪3位错。由于多位 代码同时出错的概率比仅一位代码出错的概率小得多,故认为 是一位错。 ③ S4S3S2S1中有两位或三位不为0,表明是一位数据位出错, 出错位的位号由S4~S1这4位的编码值指明(例如, S4~S1 = 1011,则H11位出错),因此可将其纠正过来。或者可能是三 个校验位同时出错,但此种出错的概率极小,故认为是一位 错。
出错位
数据位/校验位
H1 H2 H3 H4 H5 H6 H7 H8 H9 H10 H11 H12
P1 P2 D1 P3 D2 D3 D4 P4 D5 D6 D7 D8
对于推广海明码
S5 P5 D1 D2 D3 D5 D6 D8
S5~S1的值构成指误字,反映该13位海明码出错情况: ① S5S4S3S2S1 =00000,表明无错误。 ② S5S4S3S2S1中只有一位不为0,表明是某一校验位出错,出 错的是该Si对应的Pi位,不需纠正。也可能是3位海明码(包括 数据位和校验位)同时出错,但无法指出是哪3位错。由于多位 代码同时出错的概率比仅一位代码出错的概率小得多,故认为 是一位错。
校验码的原理
校验码的原理
校验码是指在信息传递过程中为了确认数据的正确性和完整性而采用
的一种技术手段。
校验码的原理是基于一定的算法对原始数据进行加
工处理,生成一段特定的代码值,发送方将处理后的数据和代码值一
并发送给接收方。
接收方收到数据后,同样通过相同的算法对接收到
的数据进行处理,生成相应的校验码,然后将生成的校验码与发送方
提供的校验码进行对比,如果两者相同,就说明数据传输的过程中没
有出现错误。
在计算机传输和存储数据时,往往伴随着误码、漏码等问题,这些问
题会导致数据的不完整或者错误。
为了解决这个问题,人们发明了校
验码。
校验码的生成方式具有一定的算法规律,通常采用的是异或、
倒置码、加权和等数学算法。
通过对原始数据进行操作,生成了一段
固定的校验码,将这段校验码与发送方发送的数据一同传输到接收方,接收方通过同样的算法对收到的数据进行加工,得到一个校验码,与
发送的校验码进行对比,如果两个码值一致,就说明数据传输过程中
没有出现问题。
如果校验码不一致,则说明在数据传输或者储存过程
中发生了错误,需要重新传输或者修复数据。
在实际应用中,各种不同的校验码算法被广泛采用,例如CRC校验码、LRC校验码、累加和校验码等等。
校验码技术在数据传输、存储等方
面的应用非常广泛,不仅在计算机领域,而且在通信网络、物联网、车联网等领域中也都有广泛的应用。
总之,校验码是一种验证数据正确性的技术手段,可以有效地避免因数据传输过程中的误码、漏码等问题导致数据的不完整或者错误。
校验码的选择需要根据具体的应用场景进行考虑,选择合适的算法以确保数据传输过程的可靠性。
各种校验码校验算法分析
各种校验码校验算法分析校验码校验算法是一种用于数据传输或存储中验证数据完整性和准确性的技术,它能够检测出数据在传输或存储过程中是否发生了错误或损坏,从而确保数据的可靠性。
在实际应用中,校验码校验算法广泛应用于通信、网络传输、存储和数据处理等领域,其设计和选择对数据可靠性和安全性至关重要。
常见的校验码校验算法包括奇偶校验码、循环冗余校验码(CRC)、校验和、哈希校验码等。
下面将对这几种常见的校验码校验算法进行详细分析:1.奇偶校验码:奇偶校验码是最简单的一种校验码校验算法,它通过检测数据中的奇偶位来判断数据是否正确。
在奇偶校验中,通常规定数据中的位数为偶数个或奇数个,如果数据中出现奇数个1,则在校验位中加上1,使总的1的数量为偶数;如果数据中出现偶数个1,则在校验位中加上0,使总的1的数量仍为偶数。
在数据传输或存储中,接收方会通过比较校验位和数据位的和是否为偶数来判断数据的正确性。
奇偶校验码虽然简单易实现,但只能检测出奇数个错误位(例如一个错误的位),并不能检测出多个错误位或连续错误的情况。
因此,奇偶校验码一般用于对数据传输的基本错误进行检测。
2.循环冗余校验码(CRC):CRC是一种基于多项式除法的校验码校验算法,它通过对数据进行特定的多项式运算来计算出校验码。
接收方在收到数据后,也会对数据进行相同的多项式运算,然后比较计算出的校验码与发送方发送的校验码是否一致,从而判断数据是否正确。
CRC校验码具有较高的检错能力和容错率,能够有效地检测出多个位错误和定位错误的位置,因此广泛应用于计算机网络传输、磁盘存储、通信协议等领域。
3.校验和:校验和是一种简单的校验码校验算法,它通过对数据中所有位进行求和操作来计算出校验码。
接收方在接收到数据后,也会对数据进行相同的求和操作,然后比较计算出的校验和与发送方发送的校验和是否一致,从而判断数据是否正确。
校验和算法比较简单,计算速度较快,但只能检测出简单的错误情况,对于复杂的错误或多位错误检测能力有限。
计算机组成原理校验码
生成多项式应满足以下条件:
生成多项式的最高位和最低位必须为1。 当被传送信息(CRC码)任何一位发生错误
时,被生成多项式做除后应该使余数不为0。 不同位发生错误时,应该使余数不同。 对余数继续做除,应使余数循环。
18
CRC举例
信息码为101,生成多项式为:11101,求 其CRC。
11
海明码举例
例:0100
解题步骤如下:
n=4,k取3即可 I4=0,I3=1,I2=0,I1=0 各个位的排列规则如下:
7
6
5
4
3
2
1
I4
I3
I2
P3
I1
P2
P1
1
P3= I4 ⊕ I3 ⊕ I2 P2= I4 ⊕ I3 ⊕ I1 P1= I4 ⊕ I2 ⊕ I1
8
校验位的确定
第i位
位号
由校验
1
位位号
之和等
2
于i的
3
那些校
验位进
4
行校验。 5
6
7
海明码位 P1 P2 I1 P3 I2 I3 I4
参加检验的校验位
P1 P2 P1、P2 P3 P1、P3 P2、P3 P1、P2、P3
9
校验位Pi的计算公式
校验位Pi的取值等于它所参与检验的各位信 息位的异或值。
根据信息位的位数n确定校验码的位数k 确定校验码的位置 求出校验位的值
6
k与n的关系
2k>=n+k+1
信息位位数n 1~4 5~11
12~26 27~57 58~119
校验位位数k 3 4 5 6 7
77
确定校验码的位置
数据校验码
H11 H10 H9 D6 D5 1 √ √ √ 1 D4 0 √
H8 P4
H7 D3 1 √
H6 D2 1
H5 D1 1 √
H4 P3
H3 D0 0 √ √
H2 P2
H1 P1
√ √
√ √ √ √ √ √
④ 校验位的形成 P1= 第 一 组 中 的 所 有 位 ( 除 P1 外 ) 求 异 或 = D6⊕D4⊕D3⊕D1⊕D0=1⊕0⊕1⊕1⊕0=1 P2= 第 二 组 中 的 所 有 位 ( 除 P2 外 ) 求 异 或 = D6⊕D5⊕D3⊕D2⊕D0= 1⊕1⊕1⊕1⊕0=0 P3= 第 三 组 中 的 所 有 位 ( 除 P3 外 ) 求 异 或 = D7⊕D3⊕D2⊕D1= 0⊕1⊕1⊕1=1 P4= 第 四 组 中 的 所 有 位 ( 除 P4 外 ) 求 异 或 = D7⊕D6⊕D5⊕D4= 0⊕1⊕1⊕0=0
计算机学院
CRC码是用多项式M(x)·xr( M(x)右移r位)除以称为生成 多项式的G(x) (产生校验码的多项式) 所得余数作为校验位。为 了得到r位余数(校验位),G(x)必须是r+1位。 设所得余数表达示为R(x),商为Q(x)。将余数拼接在信息位 左移r位后空出的r位上,就构成这个有效信息的CRC码。 求CRC码的方法: 1。根据 K+r≤2r-1 确定r的位数 2。 选一个r+1位的生成多项式的G(x) 3。 M(x)·xr/G(x)=Q (x)…….R (x) 4. CRC码为 M(x)·xr + R (x)
设R为校验位的位数,则整个码字的位数应满足不等式: +R≤2R-1 设R=3,则23-1=7,N=8+3=11,不等式不满足; 设R=4,则24-1=15,N=8+4=12,不等式满足。~12)为2的权值的那些位,即:20 、 21 、22 、23 的位置作为校验位,记作P1、P2、P3、P4,余下的 为有效信息位。即: 12 D7 11 D6 10 D5 9 D4 8 P4 7 D3 6 D2 5 D1 4 P3 3 D0 2 P2 1 P1
校验码计算方法
校验码的计算方法(1)
1.代码位置序号
代码位置序号是指包括校验码在内的,由右至左的顺序号(校验码的代码位置序号为1)。
2.计算步骤
校验码的计算步骤如下:
a.从代码位置序号2开始,所有偶数位的数字代码求和。
b.将步骤a的和乘以3。
c.从代码位置序号3开始,所有奇数位的数字代码求和。
d.将步骤b与步骤c的结果相加。
e.用大于或等于步骤d所得结果且为10最小整数倍的数减去步骤d所得结果,其差即为所求校验码
的值。
示例:代码690123456789X1校验码的计算见表B.1。
表1 校验码的计算方法
校验码的计算方法(2)
校验码值等于前面所有字节之和的低字节部分
例如:0x68 0x10 0x68 0x68 0x68 0x68 0x68 0x68 0x68。
计算机组成原理中的三种校验方式
为了使一个系统能检查和纠正一个差错, 为了使一个系统能检查和纠正一个差错,码间最小距离必须至 少是“ 。最小距离为3时 或能纠正一个错,或能检二个错, 少是“3”。最小距离为 时,或能纠正一个错,或能检二个错, 但不能同时纠一个错和检二个错。 但不能同时纠一个错和检二个错。编码信息纠错和检错能力的 进一步提高需要进一步增加码字间的最小距离。 进一步提高需要进一步增加码字间的最小距离。
参与的校验位 P1 P2 P2 P3 P3,P1 P3,P2 P3,P2,P1 P4 P4,P1 P4,P2 P4,P2,P1 P4,P3 P4,P3,P1 P4,P3,P2 P4,P3,P2,P1 P1
4,2,1 (7=4+2+1)
• 各校验位形成公式: 各校验位形成公式: P1=D0⊕D1⊕D3⊕D4⊕D6⊕D8⊕D10 (1) P2 =D0⊕D2⊕D3⊕D5⊕D6⊕D9⊕D10 (2) P3=D1⊕D2⊕D3⊕D7⊕D8⊕D9⊕D10 (3) P4=D4⊕D5⊕D6⊕D7⊕D8⊕D9⊕D10 (4) 按上述方式Pi的取值是采用偶校验时的取值 当采用奇校验 的取值是采用偶校验时的取值, 按上述方式 的取值是采用偶校验时的取值,当采用奇校验 则取反。 连同数据位一起形成了海明码的各位。 时,Pi则取反。这样 连同数据位一起形成了海明码的各位。 则取反 这样Pi连同数据位一起形成了海明码的各位 用海名位号改写P4~P1: 用海名位号改写P P1= H3⊕H5⊕H7⊕H9⊕H11 ⊕H13 ⊕H15 P2= H3⊕H6⊕H7⊕H10⊕H11 ⊕H14 ⊕H15 P3= H5⊕H6⊕H7⊕H12 ⊕H13 ⊕H14 ⊕H15 P4= H9⊕H10⊕H11⊕H12⊕H13 ⊕H14 ⊕H15
• 在接收端校验检测: • 偶校验:P=C ⊕ X0 ⊕X1 ⊕…⊕Xn-1 ⊕
校验码
图 1 图 2注意,图8-2的8个码字相互间最少有两bit 的差异。
因此,如果任何信息的一个数位被颠倒,就成为一个不用的码字,接收机能检查出来。
例如信息是1001,误收为1011,接收机知道发生了一个差错,因为1011不是一个码字(表中没有)。
然而,差错不能被纠正。
假定只有一个数位是错的,正确码字可以是1001,1111,0011或1010。
接收者不能确定原来到底是这4个码字中的那一个。
也可看到, 在这个系统中,偶数个(2或4)差错也无法发现。
为了使一个系统能检查和纠正一个差错,码间最小距离必须至少是“3”。
最小距离为3时,或能纠正一个错,或能检二个错,但不能同时纠一个错和检二个错。
编码信息纠错和检错能力的进一步提高需要进一步增加码字间的最小距离。
图8-3的表概括了最小距离为1至7的图3码的纠错和检错能力。
码距越大,纠错能力越强,但数据冗余也越大,即编码效率低了。
所以,选择码距要取决于特定系统的参数。
数字系统的设计者必须考虑信息发生差错的概率和该系统能容许的最小差错率等因素。
要有专门的研究来解决这些问题。
二、奇偶校验奇偶校验码是一种增加二进制传输系统最小距离的简单和广泛采用的方法。
例如,单个的奇偶校验将使码的最小距离由一增加到二。
一个二进制码字,如果它的码元有奇数个1,就称为具有奇性。
例如,码字“10110101”有五个1,因此,这个码字具有奇性。
同样,偶性码字具有偶数个1。
注意奇性检测等效于所有码元的模二加,并能够由所有码元的异或运算来确定。
对于一个n位字,奇性由下式给出:奇性=a0⊕a1⊕a2⊕…⊕a n奇偶校验可描述为:给每一个码字加一个校验位,用它来构成奇性或偶性校验。
例如,在图8-2中,就是这样做的。
可以看出,附加码元d2,是简单地用来使每个字成为偶性的。
因此,若有一个码元是错的,就可以分辨得出,因为奇偶校验将成为奇性。
奇偶校验编码通过增加一位校验位来使编码中1个个数为奇数(奇校验)或者为偶数(偶校验),从而使码距变为2。
校验码(海明码)
校验码(海明码)
海明码⼀般指汉明码,与其他的错误校验码类似,汉明码也利⽤了的概念,通过在后⾯增加⼀些⽐特,可以验证数据的有效性。
利⽤⼀个以上的校验位,汉明码不仅可以验证数据是否有效,还能在数据出错的情况下指明错误位置。
确定校验码的位数x
设数据有n位,校验码有x位。
则校验码⼀共有2x种取值⽅式。
其中需要⼀种取值⽅式表⽰数据正确,剩下2x-1种取值⽅式表⽰有⼀位数据出错。
因为编码后的⼆进制串有n+x位,因此x应该满⾜
2x-1 ≥ n+x
使不等式成⽴的x的最⼩值就是校验码的位数。
在本例中,n=7,解得x=4。
就是说,当n=校验位的值的时候,X等于多少?
题⽬⼀般会说给出⼀定位数的数据。
⾸先根据下⾯这个表格,⼆进制次⽅表。
看看这个位数对应多少次⽅,只能⼤不能⼩
⽐如说32位的校验码。
根据上⾯的公式,2x ≥ 32+1+X ,将位数代⼊到N⾥。
将1移到右边。
简化公式就是:2x ≥ 33+X 根据这个简化公式,其实就可以理解为,2的多少次⽅可以⼤于等于33
根据2次⽅表就可以知道,6个次⽅!!
最后代⼊公式,26 ≥ 33+6 即26 ≥ 39 ,即X=6 就是说需要加⼊6位校验码
遇到此种题⽬,⾸先看给出的信息位是多少,⽐如16,那么2的多少个次⽅可以⽐16⼤?。
2的4次⽅刚好是16,2的5次⽅⽐16⼤。
那么就代⼊公式看看,答案是5次⽅。
excel 字母数字 的校验码计算方法
excel 字母数字的校验码计算方法Excel中的校验码是一个非常有用的功能,它可以帮助我们验证数据的准确性和完整性。
校验码的计算方法是基于字母和数字的组合,通过一定的规则来生成校验码。
在本文中,我将介绍校验码的计算方法,并给出一些实际应用的例子。
我们需要了解校验码的生成规则。
校验码的计算方法有很多种,其中比较常见的有两种:一种是基于模运算的算法,另一种是基于权重的算法。
基于模运算的算法是将字母和数字转换为对应的ASCII码,然后将它们相加,再取模运算的结果作为校验码。
这种算法的优点是简单易懂,计算速度较快。
但是,它的缺点是容易出现冲突,即不同的字母和数字组合可能生成相同的校验码。
基于权重的算法则是给每个字母和数字赋予一个权重,然后将它们相乘再相加,最后取结果的模运算作为校验码。
这种算法的优点是能够保证生成的校验码的唯一性,但计算过程相对复杂一些。
举个例子来说明校验码的计算方法。
假设我们要生成一个包含字母和数字的校验码,其中包含的字符为A、B、C、1、2、3。
我们可以使用基于模运算的算法来计算校验码。
首先,将字母和数字转换为对应的ASCII码,A对应的ASCII码为65,B对应的ASCII码为66,以此类推。
然后,将它们相加,即65+66+67+49+50+51=342。
最后,取342的模运算结果,假设我们取模97,那么342 mod 97=51,所以校验码为51。
校验码的计算方法可以应用于很多实际场景中。
比如,在身份证号码中,最后一位通常是校验码,用于验证身份证号码的合法性。
在银行卡号码中,最后一位也是校验码,用于验证银行卡号码的正确性。
在商品条码中,校验码可以用来检查条码是否输入正确。
除了校验码的计算方法,我们还可以通过校验码来进行数据的验证。
比如,我们可以将校验码与输入的数据进行比较,如果两者不一致,则说明数据输入错误。
这样可以帮助我们减少数据错误带来的麻烦和损失。
总结一下,校验码是一种用于验证数据准确性和完整性的方法,它可以通过一定的规则来生成。
常用校验码(奇偶校验码、海明校验码、CRC校验码)
常⽤校验码(奇偶校验码、海明校验码、CRC校验码)计算机系统运⾏时,各个部之间要进⾏数据交换. 为确保数据在传送过程正确⽆误,常使⽤检验码. 我们常使⽤的检验码有三种. 分别是奇偶校验码、海明校验码和循环冗余校验码(CRC)。
奇偶校验码(Parity Codes)奇偶校验码最简单,但只能检测出奇数位出错. 如果发⽣偶数位错误就⽆法检测. 但经研究是奇数位发⽣错误的概率⼤很多. ⽽且奇偶校验码⽆法检测出哪位出错.所以属于⽆法矫正错误的校验码。
奇偶校验码是奇校验码和偶校验码的统称. 它们都是通过在要校验的编码上加⼀位校验位组成. 如果是奇校验加上校验位后,编码中1的个数为奇数个。
如果是偶校验加上校验位后,编码中1的个数为偶数个。
例:原编码奇校验偶校验0000 0000 1 0000 00010 0010 0 0010 11100 1100 1 1100 01010 1010 1 1010 0如果发⽣奇数个位传输出错,那么编码中1的个数就会发⽣变化. 从⽽校验出错误,要求从新传输数据。
⽬前应⽤的奇偶校验码有3种.⽔平奇偶校验码对每⼀个数据的编码添加校验位,使信息位与校验位处于同⼀⾏.垂直奇偶校验码把数据分成若⼲组,⼀组数据排成⼀⾏,再加⼀⾏校验码. 针对每⼀⾏列采⽤奇校验或偶校验例: 有32位数据10100101 00110110 11001100 10101011垂直奇校验垂直偶校验10100101 10100101 数据00110110 0011011011001100 1100110010101011 1010101100001011 11110100 校验⽔平垂直奇偶校验码就是同时⽤⽔平校验和垂直校验例:奇校验奇⽔平偶校验偶⽔平10100101 1 10100101 0 数据00110110 1 00110110 011001100 1 11001100 010101011 0 10101011 100001011 0 11110100 1 校验我们把传送过来的1100111000逐位相加就会得到⼀个1,应该注意的的,如果在传送中1100111000变成为0000111000,通过上⾯的运算也将得到1,接收⽅就会认为传送的数据是正确的,这个判断正确与否的过程称为校验。
各种校验码校验算法分析
各种校验码校验算法分析校验码是一种用于验证数据完整性和准确性的算法。
在计算机科学中,常见的校验码算法包括纵向冗余校验(VRC),横向冗余校验(HRC),循环冗余校验(CRC),校验和和哈希校验等。
下面将对这些校验码算法进行分析。
VRC是一种最简单的校验码算法,它将数据位分为数据位和校验位两部分。
数据位按照一定的规则进行编码,校验位是根据数据位计算得到的。
当数据接收方收到数据后,它也会按照相同的规则计算校验位,并将计算得到的校验位与发送方传来的校验位进行比较,如果两者一致,则认为数据传输正确。
然而,VRC算法只能检测数据传输中的单比特错误,无法检测到多比特错误。
HRC是一种通过对数据进行按位求和来计算校验位的算法。
它与VRC算法类似,只是校验位的计算方法不同。
与VRC算法相比,HRC算法更加复杂,但也能检测到更多的错误。
然而,HRC算法仍然无法检测到多比特错误。
CRC是一种更为强大的校验码算法,它通过对数据进行除法运算来计算校验位。
CRC算法将数据视为二进制数,将除法运算看作一个模2整除的过程。
发送方在传输数据之前,计算数据的CRC校验位并将其附加在数据末尾。
接收方在接收数据后,也计算接收到的数据的CRC校验位,并与接收到的校验位进行比较。
如果两者一致,则认为数据传输正确。
与VRC和HRC算法相比,CRC算法具有更高的错误检测能力。
校验和是一种将数据按照一定规则进行求和来计算校验位的算法。
校验和算法将数据视为一系列数值,按照一定的规则进行求和,然后将求和结果的低位部分作为校验位。
校验和算法简单易实现,但其错误检测能力有限,无法检测到一些错误。
哈希校验是一种借助哈希函数来计算校验位的算法。
哈希函数将数据映射为一个固定长度的哈希值,该哈希值称为校验值。
发送方在发送数据之前,计算数据的哈希值并将其附加在数据末尾。
接收方在接收数据后,也计算接收到的数据的哈希值,并与接收到的校验值进行比较。
如果两者一致,则认为数据传输正确。
数据校验码
二、 海明校验码
实现方法:在数据中加几个校验位, 实现方法:在数据中加几个校验位,并把数据 的每一个二进制位分配在几个奇偶校验组中。 的每一个二进制位分配在几个奇偶校验组中。当 某一位出错后, 某一位出错后,会引起有关的几个校验组的值发 生变化。 生变化。
问题1:给定数据位如何确定校验位的个数? 1 问题2:校验位和数据位如何排列? 问题3:校验位的值如何确定? 问题4:如何根据海明码判断数据的正确性?
问题1:给定数据位如何确定校验位的个数? 设有R位校验位,则共有 到 个共2 设有 位校验位,则共有0到2R-1个共 R个组合。若 位校验位 个共 个组合。 表示无差错, 个值表示有差错, 用0表示无差错,则剩余 R-1个值表示有差错,并指 表示无差错 则剩余2 个值表示有差错 出错在第几位。差错可能发生在K个数据位中或 个数据位中或R 出错在第几位。差错可能发生在 个数据位中或 个校验位中,检测一位出错并纠错需满足下式: 一位出错并纠错需满足下式 个校验位中,检测一位出错并纠错需满足下式: 2R-1≥R+ K ≥ 如要能检测与自动校正一位错,并发现两位错, 此时校验位的位数r和数据位的位数k应满足下述 关系: 2R-1≥K+R
S5 = P5 + 1 +P2 +P3 +P4 + 1 + 2 + 3 + 4 +D5 + 6 + 7 +D8 P D D D D D D
全为0,则无错误; 如果S 如果 1 ~S4全为 ,则无错误; ,说明有偶数位出错。 若S5 =0 ,S4S3S2S1≠0,说明有偶数位出错。 若S5=1,S4S3S2S1≠0,可根据 4S3S2S1指出的值 , ,可根据S 纠正一位错。 纠正一位错。
数据校验码
数据校验码
③选取一个K+1位的产生多项式G(X),对 M(X)×XK 作模2除。 ④把左移K位以后的待编有效信息与余数 R(X)作模2加减,拼接为CRC码,此时的 CRC码共有N+K位。 M(X)×XK+R(X)=Q(X)×G(X) 例如,选择产生多项式为1011,把4位 有效信息1100编成CRC码。 M(X)=X3+X2=1100 M(X)×X3 =X6+X5=1100000 G(X)=X3+X+1=1011
数据校验码
当整个CRC码被接收后,仍用约定的 多项式G(X)去除,若余数为0表明该代码是 正确的;若余数不为0表明某一位出错,再 进一步由余数值确定出错的位置,以便进 行纠正。 循环冗余校验码编码规律如下: ①把待编码的N位有效信息表示为多项式 M(X)。 ②把M(X)左移K位,得到M(X)×XK ,这 样空出了K位,以便拼装K位余数(即校验 位)。
数据校验码
(2)校验 假设传送后H11(D7)位发生了错误: 1111001101011 出错 检错的过程很简单,只要将接受到的 码字重新进行偶校验: S1=100101=1 S2=101111=1 S3=10111=0 S4=00111=1 S5=1001011=0
数据校验码
(1)编码 一个字节由8位二进制位组成,此时N=8, K=5,故海明码的总位数为13位,可表示为: H13 H12 … H2 H1 五个校验位P5~P1对应的海明码位号应 分别为:H13 、H8 、H4 、H2 、H1 ,除P5 外, 其余四位都满足Pi的位号等于2i-1的关系,而 P5只能放在H13上,因为它已经是海明码的最 高位了。因此,有如下排列关系: P5 D8 D7 D6 D5 P4 D4 D3 D2 P3 D1 P2 P1
数据校验码
06-数据校验码
10
9
8
76
5
4
3
2
1
信1
息
1
0
0
1
01
0
1
1
0
1
1
例2:请分析海明码字110010111SS112==0HH1121⊕⊕是HH33否⊕⊕HH正56⊕⊕确HH77?⊕⊕HH若91⊕ 0⊕有HH111错1 ,请纠错。
解:计算S5S4S3S2S1=?
S3=H4 ⊕ H5⊕H6⊕H7⊕H12 S4=H8 ⊕ H9⊕H10⊕H11⊕H12
假设:
结论:
•H12(D8)出错、S4S3S2S1=? •H11(D7)出错、S4S3S2S1=?
当某个数据位出错时、 S4S3S2S1的值 等于该出错位数据在海明码中的位号。
•H10(D6)出错、S4S3S2S1=?
•H 9(D5)出错、S4S3S2S1=? •H 7(D4)出错、S4S3S2S1=?
则校验得到的结果值S5~S1能反映13位海明码的出错情 况。任何偶数个数出错,S5一定为0,因此可区分两位出 错或一位出错。
用海名位号改写S4~S1:
S1=H1 ⊕ H3⊕H5⊕H7⊕H9⊕H11 S2=H2 ⊕ H3⊕H6⊕H7⊕H10⊕H11 S3=H4 ⊕ H5⊕H6⊕H7⊕H12 S4=H8 ⊕ H9⊕H10⊕H11⊕H12
模2加与模2减的结果相同. (2)模2乘——按模2加求部分积之和。
(3)模2除——按模2减求部分余数。每求一位商
应使部分余数减少一位。上商的原则是: 当部分 余数的首位为1时,商取1;当部分余数的首位为0 时,商取0。当部分的余数的位数小于除数的位数 时,该余数即为最后余数。
CRC码的编码方法:
《数据校验码》课件
数据校验码通过对数据进行处理并产生校验码,用于检测数据传输和存储中 的错误,并确保数据的完整性和正确性。
数据校验码的概述
数据传输
数据校验码保证数据在传输过程中不被损坏或 篡改。
数据存储
数据校验码保证数据在存储设备中的正确性和 完整性。
常见的数据校验码
校验和
将数据进行求和,并将结果作为校验码。 易于实现,但只能检测简单的错误。
原始资料和参考书籍
• 《现代通信原理》(第三版),郭红 钢等。
• 《信息论与编码》(第二版),李舟。
随机循环码
对数据进行异或处理,随机产生一个校验 码。具有一定的安全性,但易于被干扰。
循环冗余校验
通过模2除法对数据进行处理,产生一个 固定长度的校验码。能检测更复杂的错误。
垃圾字符校验
将一个特殊字符赋给数据,将这个字符及 数据一起处理产生校验码。具有一定的稳 定性,但运算次数过多。
校验码的计算方法
不足
• 容易受到攻击和人为干扰 • 不能防止数据本身的错误 • 计算复杂,可能会降低数据传输效率。
随着技术的不断发ቤተ መጻሕፍቲ ባይዱ,人们还在不断探索更好的校验码计算方法和应用场景。
参考文献
相关研究和文献
• Z eng X . and Cao J. (2017) Im proved Checksum A lg orithm s for Personal H ealth Record S ecurity. In: Q u X ., Z ho u L., S u X . (ed s) Co m p uter, Info rm atics, Cybernetics and A pplications. CICA 2017. Co m m unicatio ns in
3.7 数据校验码
D3 D2 D1
P2 P1
计算机学院
③ 分组
H7 H6 H5 H4 H3 H2 H1
第 一 组 ( P1) 第 二 组 ( P2) 第 三 组 ( P3)
D3 0 √ √ √
D2 0 √ √
D1 1 √ √
P3
D0 1 √ √
P2
P1 √
√
√
④ 效验位的形成 P1= D3⊕D1⊕D0= 0⊕1⊕1=0 P2= D3⊕D2⊕D0= 0⊕0⊕1=1 P3= D3⊕D2⊕D1= 0⊕0⊕1=1 所以:信息码0011的海明效验码为:001 1 1 10
计算机学院
(2) 校验位的形成 设有效信息为D7D6D5D4D3D2D1D0,则: 偶校验:在发送端求校验位P= D7⊕D6⊕D5⊕D4⊕D3⊕D2⊕D1⊕D0 奇校验:在发送端求校验位P= D7⊕D6⊕D5⊕D4⊕D3⊕D2⊕D1⊕D0 校验电路如图所示。
计算机学院
(3)校验原理 偶校验在接受端求 P’= D7⊕D6⊕D5⊕D4⊕D3⊕D2⊕D1⊕D0⊕P 奇校验在接受端求 P’= D7⊕D6⊕D5⊕D4⊕D3⊕D2⊕D1⊕D0⊕P 若 P’=0,则无错;若 P’=1,则有错。 校验电路如图所示
计算机学院
D3 D1 (2)海明效验逻辑电路D2 如图所示 =1
H7 0111
D0 =1
H3 0011
=1 无 错 =0 有 错
=1
H6 0110
=1
H5 0101
0000 ( 译 器 电 有 ) 设 码 高 平 效
3: 译 码 器 8
S3
奇 形 线 Βιβλιοθήκη 成 路S2奇 形 线 偶 成 路
S1
奇 形 线 偶 成 路
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
3.7 数据校验码任何一种编码都由许多码字构成,任意两个码字之间会有n位代码不同,n称为它们之间的距离,这些n值中.最小的就是该编码的码距.例如,用四位二进制表示16种状态,则16种编码都用到了,此时码距为1。
若用四个二进制位表示8个状态,就可以只用其中的8种编码,而把另8种编码作为非法编码,此时码距为2。
计算机学院z000 0z001 1z010 1z011 0z100 1z101 0z110 0z111 1计算机学院3.7.1 奇偶校验奇偶校验码的原理是在每组代码中增加一个冗余位,使合法编码的最小码距由1增加到2。
(1) 校验码的构成规则偶校验:每个码字(包括校验位)中1的数目为偶数。
比如1101011 的偶校验码为1101011 1奇校验:每个码字(包括校验位)中1的数目为奇数。
比如1101011 的奇校验码为1101011 0计算机学院(2) 校验位的形成设有效信息为D7D6D5D4D3D2D1D0,则:偶校验:在发送端求校验位P= D7⊕D6⊕D5⊕D4⊕D3⊕D2⊕D1⊕D0奇校验:在发送端求校验位P= D7⊕D6⊕D5⊕D4⊕D3⊕D2⊕D1⊕D0校验电路如图所示。
计算机学院(3)校验原理偶校验在接受端求P’= D7⊕D6⊕D5⊕D4⊕D3⊕D2⊕D1⊕D0⊕P奇校验在接受端求P’= D7⊕D6⊕D5⊕D4⊕D3⊕D2⊕D1⊕D0⊕P若P’=0,则无错;若P’=1,则有错。
校验电路如图所示计算机学院发送端接收端PP’计算机学院(4)局限性奇偶校验码能发现数据代码中奇数个位出错情况,并且不能纠正错误,常用于对存储器数据的检查或者传输数据的检查。
3.7.2 海明码校验海明校验的基本思想是将有效信息按某种规律分成若干组,每组安排一个校验位进行奇偶测试。
计算机学院例求信息码01101110的海明校验码,画出能指出和纠正一位出错位的海明校验逻辑电路。
①确定海明校验位的位数设R为校验位的位数,则整个码字的位数应满足不等式:N=K+R≤2R-1设R=3,则23-1=7,N=8+3=11,不等式不满足;设R=4,则24-1=15,N=8+4=12,不等式满足。
所以R最小取4。
②确定校验位的位置:位号(1~12)为2的权值的那些位,即:20、21、22、23的位置作为校验位,记作P1、P2、P3、P4,余下的为有效信息位。
即:12 11 10 9 8 7 6 5 4 3 2 1D 7D6D5D4P4 D3D2D1P3DP2 P1计算机学院③分组:有4个校验位,将12位分4组,第i位由校验位的位号之和等于i的那些校验位所校验。
如表所示,如:第11位D由P1(位6号为1)、P2(位号为2)、P4(位号为8)所校验,因为1+2+8=11。
校验H12 H11 H10 H9H8 H7 H6H5H4H3H2H1位的D7D6D5D4P4 D3D2 D1 P3D0 P2 P1位号0 1 1 0 1 1 1 0第一组(P1) 1√√√√√√第二组(P2) 2√√√√√√第三组(P3) 4√√√√√第四组(P4) 8√√√√√计算机学院④校验位的形成P1=第一组中的所有位(除P1外)求异或=D 6⊕D4⊕D3⊕D1⊕D=1⊕0⊕1⊕1⊕0=1P2=第二组中的所有位(除P2外)求异或=D 6⊕D5⊕D3⊕D2⊕D= 1⊕1⊕1⊕1⊕0=0P3=第三组中的所有位(除P3外)求异或=D 7⊕D3⊕D2⊕D1= 0⊕1⊕1⊕1=1P4=第四组中的所有位(除P4外)求异或=D 7⊕D6⊕D5⊕D4= 0⊕1⊕1⊕0=0计算机学院为了能检测两个错误,增加一位校验P5,放在最高位。
P5 = D7⊕D6⊕D5⊕D4⊕D3⊕D2⊕D 1⊕D⊕P1⊕P2⊕P3⊕P4= 0⊕1⊕1⊕0⊕1⊕1⊕1⊕0⊕1⊕0⊕1⊕0 = 1【例题答案】信息码0110 1110的海明校验码为:1 0110 0111100 1计算机学院计算机学院(2)校验原理在接收端分别求S 1、S 2、S 3、S 4、S 5。
S 1 = P1⊕D 6⊕D 4⊕D 3⊕D 1⊕D 0S 2 = P2⊕D 6⊕D 5⊕D 3⊕D 2⊕D 0S 3 = P3⊕D 7⊕D 3⊕D 2⊕D 1S 4 = P4⊕D 7⊕D 6⊕D 5⊕D 4S 5 = P5⊕D 7⊕D 6⊕D 5⊕D 4⊕D 3⊕D 2⊕D 1⊕D 0⊕P1⊕P2⊕P3⊕P4计算机学院z 当S 5=1时有一位错:由S 4S 3S 2S 1的二进制编码指出出错位号。
例如S 4S 3S 2S 1=1001 说明第9位出错,将其取反,即可纠错。
z当S 5=0时无错或有偶数个错(两个错的可能性比较大)z当S 4S 3S 2S 1=0000时,接收的数无错,否则有两个错。
z 【例题答案】能指出两个错误并能纠正一位出错位的海明校验逻辑电路如图所示。
计算机学院D 7 D 6 D 5 D 4 D 3 D 2 D 1 D 0 无错 一位错 两位错=1 =1 =1 =1 =1 =1 =1 =1H 12 H 11 H 10 H 9 H 7 H 6 H 5 H 31100 1011 1010 1001 0111 0110 0101 0011 00004:16 译 码 器 (设译码器高电平有效)S 4 S 3 S 2 S 1 S 5 奇偶形成线路 奇偶形成线路 奇偶形成线路 奇偶形成线路 奇偶形成线路 H 12H 11H 10H 9H 8 H 12 H 7 H 6 H 5 H 4 H 11H 10 H 7 H 6H 3H 2 H 11 H 9H 7H 5 H 3 H 1 所有位 校验 H 12 H 11 H 10 H 9 H 8 H 7 H 6 H 5 H 4 H 3 H 2 H 1 位的 D 7 D 6 D 5 D 4 P4 D 3 D 2 D 1 P3 D 0 P2 P1 位号 0 1 1 0 1 1 1 0 第一组(P1) 1 √ √ √ √√ √ 第二组(P2) 2 √ √ √ √ √ √ 第三组(P3) 4 √ √ √ √ √第四组(P4) 8 √ √ √ √ √序号也可以从低到高,如下所示:校验H1H2 H3 H4H5H6H7 H8H9H10H11H12位的P1 P2 D7P3 D6D5D4P4D3D2D1D0位号0 1 1 0 1 1 10 第一组(P1) 1√√√√√√第二组(P2) 2√√√√√√第三组(P3) 4√√√√√第四组(P4) 8√√√√√计算机学院D7D6 D5D4D3D2 D1D0无错一位错两位错=1=1=1=1=1=1=1=1H3H5H6H7H9H10 H11 H12 00110101011001111001101010111100 00004:16译码器 (设译码器高电平有效)S4S3 S2S1 S5奇偶形成线路奇偶形成线路奇偶形成线路奇偶形成线路奇偶形成线路H3H2H1H0H6 H5 H4 H0H3H6H7H10H11H3 H5H7H9H11 所有位计算机学院例题有一个(7,4)码,写出代码0011的海明效验码,画出效验电路解:(1)求信息码001的海明效验码。
①确定海明效验位的位数因为是(7,4)码,所以N=7,K=4,效验位的位数为3。
②确定效验位的位置:位号(1∽7)为2的权值的那些位,即:20、21、22的位置作为效验位,即:7 6 5 4 3 2 1D3D2D1P3 DP2 P1计算机学院计算机学院④效验位的形成P1= D 3⊕D 1⊕D 0= 0⊕1⊕1=0P2= D 3⊕D 2⊕D 0= 0⊕0⊕1=1P3= D 3⊕D 2⊕D 1= 0⊕0⊕1=1所以:信息码0011的海明效验码为:001 1 1 10③ 分组H 7 H 6 H 5 H 4 H 3 H 2 H 1 D 3 D 2 D 1 P3 D 0 P2 P1 0 0 1 1第一组(P1) √ √ √ √ 第二组(P2) √ √ √ √ 第三组(P3) √ √ √ √计算机学院(2)海明效验逻辑电路如图所示D 3 D 2 D 1 D 0 =1无错 =0有错 =1 =1 =1 =1H 7 H 6 H 5 H 30111 0110 0101 0011 00003:8 译 码 器 (设译码器高电平有效)S 3 S 2 S 1 奇偶形成线路 奇偶形成线路 奇偶形成线路H 7 H 6 H 5 H 4 H 7 H 6 H 3 H 2 H 7 H 5 H 3 H 1P 103 习题3.29、 3.30 3.31计算机学院①确定海明校验位的位数设K为有效信息的位数,设r为校验位的位数,则整个码字的位数N应满足不等式:N=K+r≤2r -1若要求海明码能检测出2位错误,则再增加一位校验位。
z ②确定校验位的位置:位号(1~N)为2的权值的那些位,即:20、21、22、…2r-1的位置作为校验位,记作P 1、P 2、…P r ,余下的为有效信息位。
z ③分组:将N位分r组,第i位由校验位号之和等于i的那些校验位所校验。
求海明校验码的步骤z如下所示(k=8):校验H12 H11 H10 H9H8 H7 H6H5H4H3H2H1位的D7D6D5D4P4 D3D2 D1 P3D0 P2 P1位号0 1 1 0 1 1 1 0第一组(P1) 1√√√√√√第二组(P2) 2√√√√√√第三组(P3) 4√√√√√第四组(P4) 8√√√√√计算机学院z④校验位的形成P1=第一组中的所有位(除P1外)求异或P2=第二组中的所有位(除P2外)求异或Pr=第r组中的所有位(除Pr外)求异或z为了能检测两个错误,增加一位校验P r+1,放在最高位。
Pr+1= 所有位(包括P1、P2、…Pr)共N位求异或计算机学院计算机学院(2)校验原理:在接收端分别求S 1、S 2、S 3、…S r S 1 =第一组中的所有位(包括P 1)求异或S 2 =第二组中的所有位(包括P 2)求异或S r =第r组中的所有位(包括P r )求异或S r+1 = P r+1⊕所有位(包括P 1、P 2、…P r )求异或z 当S r +1=1时有一位错:由S r …S 3S 2S 1的二进制编码指出出错位号,将其取反,即可纠错。
z 当S r +1=0时无错或有偶数个错(两个错的可能性比较大): 当S r …S 3S 2S 1=0…000时,接收的数无错,否则有两个错。
z根据此原理,能画出指出两个错误并能纠正一位出错位的海明校验逻辑电路。
数据校验的几个相关的概念z①海明重量:某码字中非零码元的个数,简称为重量。
对二进制码,即码字中1的个数。
z②海明距离:两个码字之间对应位不相同的个数。
z③最小距离:码字集合中,任意两个码字之间的距离的最小值称为最小距离。