奇偶校验码 、循环冗余校验码(CRC)、 海明码

2024-02-25 14:58

本文主要是介绍奇偶校验码 、循环冗余校验码(CRC)、 海明码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在计算机运行时,为保证二进制数据在传输时准确无误,通常利用校验码来检测并纠错传输的数据。所谓码距就是任意合法编码之间至少有多少个二进制位不同。例如: 码距位1的“8 1 4 2” 码对应的二进制分别是 1000,0001,0100,0010. ,当其中一个编码二进制位发生了变化,还是满足码距为1的合法编码。所以,单纯靠码距并不能检验出传输内容中的错误。

一、奇偶校验码

 在编码中增加一位校验位来使编码中的1的个数为奇数或者为偶数,从而使码距变为2.奇校验就是加上校验位来使编码中的1的个数为奇数,偶校验就是加上校验位来使编码中的1的个数为偶数。

例如  对于编码8,对应的原字节流 是   00001000  .在顶部加上校验位,奇校验的话字节流就成了 0 00001000  ,

原码0 00001000编码正确
其中一个bit传输错误0 00001010不满足1的个数为奇数
其中两个bit传输错误0 00101010编码正确,满足1的个数为奇数
其中三个bit传输错误0 00001111不满足1的个数为奇数

对于偶校验

  

原码1 00001000编码正确
其中一个bit传输错误1 00001010不满足1的个数为偶数
其中两个bit传输错误1 00101010编码正确,满足1的个数为偶数
其中三个bit传输错误1 00001111不满足1的个数为偶数

所以奇偶校验码,不能检测偶数个bit传输错误的情况,也不能对错误bit进行纠正。

二、循环冗余校验码(CRC)

        CRC采用生成多项式对源码进行校验,在源码的尾数加上校验位。在校验计算中,采用源码和比多项式码少一位的零码组成,对多项式码进行模2运算,就是异或。得到的余数就是校验位。

 例如生成多项式式   X^4+X^3+0*X^2+X+1 对应的多项式编码码   11011.为五位,那么在校验过程中对原报文加上四个零,然后进行模2运算得到最终的余数。就是校验码。发送的最终报文就是:

110010101010011 

        

三、海明码

 海明码在数据之中的特定位置上插入k个校验位。数据位数为n。那么海明码的总位数就是n+k

插入的个数满足     2^k -1 >= n+k   

1)插入的校验位Pi   = 2^(i-1)位置,即海明码的 1,2,4,8,16,32.....bit位 

2)对海明码bit的下标分别转成二进制数,再把校验位对应的海明码bit,的零替换成通配符得到分组。

例如  8 位的数据为,4位的校验位

校验位下标零替换成通配符1****1****1****1
海明码H12H11H10H9H8H7H6H5H4H3H2H1
数据位D/校验位PD7D6D5D4P4D3D2D1P3D0P2P1
  • 满足****1的的海明码下标分别是  H1,H3,H5,H7,H9,H11 ,所以对应的 P1,D0,D1,D3,D4,D6 为一组
  • 满足***1*的的海明码下标分别是 H2,H3,H6,H7,H10,H11,所以对应的 P2,D0,D2,D3,D5,D6 为一组
  • 同理 P3,D1,D2,D3,D7为一组
  • P4,D4,D5,D6,D7为一组

3)对每个分组分别作亦或运算⊕ ,本别道道检验结果Gi  ,当偶校验时,每个检验结果都为0,则无异常;当奇校验时,每个检验结果都为1,则无异常.

4)如果Gi不为全0时,对应的十进制数则说明海明码对应的下标出错。取反可纠正。

例如:1001001110序列,10位

1)需插入4个校验位,海明码共14位,海明码对应的内容如下表

校验位下标零替换成通配符*1*****1*****1*****1
海明码H14H13H12H11H10H9H8H7H6H5H4H3H2H1
数据位D/校验位PD9D8D7D6D5D4P4D3D2D1P3D0P2P1
奇校验10010001110000
偶校验10010011111010
实际接收到的值10010011011010

2)分组

   P1,D0,D1,D3,D4,D6,D8 为一组;

  P2,D0,D2,D3,D5,D6,D9为一组;

  P3,D1,D2,D3,D7,D8,D9为一组;

  P4,D4,D5,D6,D7,D8,D9为一组;

4)求P的值,假如是偶校验    //1001001110

   P1=D0⊕D1⊕D3⊕D4⊕D6⊕D8 =0  ⊕1  ⊕1 ⊕ 0 ⊕ 1⊕ 0 =1

  P2=D0⊕D2⊕D3⊕D5⊕D6⊕D9 =0  ⊕1  ⊕1 ⊕ 0 ⊕ 1⊕ 1 =0

  P3=D1⊕D2⊕D3⊕D7⊕D8⊕D9 = 1⊕1  ⊕1 ⊕ 0 ⊕0⊕ 1 =0

 P4 = D4⊕D5⊕D6⊕D7⊕D8,⊕D9 = 0⊕0  ⊕1 ⊕ 0 ⊕0⊕ 1 =0

3)对实际接收到的值作亦或  ,

G1 = P1⊕D0⊕D1⊕D3⊕D4⊕D6⊕D8 =1 ⊕0  ⊕1  ⊕1 ⊕ 0 ⊕ 1⊕ 0 = 0

G2 = P2⊕D0⊕D2⊕D3⊕D5⊕D6⊕D9 = 0⊕0  ⊕0  ⊕1 ⊕ 0 ⊕ 1⊕ 1 = 1

G3 =P3⊕D1⊕D2⊕D3⊕D7⊕D8⊕D9 = 0⊕1⊕0  ⊕1 ⊕ 0 ⊕0⊕ 1 =1

G4 = P4 ⊕D4⊕D5⊕D6⊕D7⊕D8,⊕D9 =0⊕0⊕0  ⊕1 ⊕ 0 ⊕0⊕ 1 =0

所以 对应的 G4 G3 G2 G1 的值收 0110 真值为6 ,以为着H6传输发生错误,即D2发生错误,取反修正即可。

这篇关于奇偶校验码 、循环冗余校验码(CRC)、 海明码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/745833

相关文章

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

poj3750约瑟夫环,循环队列

Description 有N个小孩围成一圈,给他们从1开始依次编号,现指定从第W个开始报数,报到第S个时,该小孩出列,然后从下一个小孩开始报数,仍是报到S个出列,如此重复下去,直到所有的小孩都出列(总人数不足S个时将循环报数),求小孩出列的顺序。 Input 第一行输入小孩的人数N(N<=64) 接下来每行输入一个小孩的名字(人名不超过15个字符) 最后一行输入W,S (W < N),用

校验码:奇偶校验,CRC循环冗余校验,海明校验码

文章目录 奇偶校验码CRC循环冗余校验码海明校验码 奇偶校验码 码距:任何一种编码都由许多码字构成,任意两个码字之间最少变化的二进制位数就称为数据检验码的码距。 奇偶校验码的编码方法是:由若干位有效信息(如一个字节),再加上一个二进制位(校验位)组成校验码。 奇校验:整个校验码中1的个数为奇数 偶校验:整个校验码中1的个数为偶数 奇偶校验,可检测1位(奇数位)的错误,不可纠错。

react笔记 8-17 属性绑定 class绑定 引入图片 循环遍历

1、绑定属性 constructor(){super()this.state={name:"张三",title:'我是一个title'}}render() {return (<div><div>aaaaaaa{this.state.name}<div title={this.state.title}>我是一个title</div></div></div>)} 绑定属性直接使用花括号{}   注

Spring是如何解决循环依赖?

现象解释: 在Spring框架中,循环依赖(Circular Dependency)是指两个或多个Bean之间相互依赖,形成了一个循环。例如,Bean A依赖于Bean B,而Bean B又依赖于Bean A。Spring通过多种机制解决循环依赖问题,具体来说,主要有以下几种方式: 1.三级缓存机制 Spring容器在实例化Bean时使用了三级缓存来解决循环依赖,主要涉及三个缓存结构: 一级

FPGA开发:条件语句 × 循环语句

条件语句 if_else语句 if_else语句,用来判断是否满足所给定的条件,根据判断的结果(真或假)决定执行给出的两种操作之一。 if(表达式)语句; 例如: if(a>b) out1=int1; if(表达式)         语句1; else         语句2; 例如: if(a>b)out1=int1;elseout1=int2; if(表达式1) 语句1; els

shell循环sleep while例子 条件判断

i=1# 小于5等于时候才执行while [ ${i} -le 5 ]doecho ${i}i=`expr ${i} + 1`# 休眠3秒sleep 3doneecho done 参考 http://c.biancheng.net/cpp/view/2736.html

checksum 与 CRC的不同之处

实际应用: CRC:在外发电压时,在报文的最后两个字节做了CRC计算。 checksum : 在按键状态外发,在报文的最后一个字节做了checksum计算。 它们的共同之处:目的都是为了数据的错误检测功能。 只是在算法的复杂度上有较大的区别: 总的来说,CRC算法更复杂,可检测的错误也比较丰富。 CRC与checksum的计算方式都是固定的吗? 在实际应用中,并没有通知对方,所用

【语音告警】博灵智能语音报警灯JavaScript循环播报场景实例-语音报警灯|声光报警器|网络信号灯

功能说明 本文将以JavaScript代码为实例,讲解如何通过JavaScript代码调用博灵语音通知终端 A4实现声光语音告警。主要博灵语音通知终端如何实现无线循环播报或者周期播报的功能。 本代码实现HTTP接口的声光语音播报,并指定循环次数、播报内容。由于通知终端采用TTS语音合成技术,所以本次案例中无需预先录制音频。 代码实战 为了通过JavaScript调用博灵语音通知终端,实现HT

【JavaScript】在循环内使用闭包

================== 基本循环语句 ==================for (var i = 0; i < 5; i++) {console.log(i);}console.log(i);//这个大家应该很快就知道了,012345================== setTimeout与var语句的for循环 ==================for (var i