奇偶校验码 、循环冗余校验码(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

相关文章

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

C语言 while循环1

在C语言里有3种循环:while循环    do  while 循环    for循环 while语句 //while语法结构while(表达式)循环语句; 比如在屏幕上打印1-10 在while循环中 break用于永久的终止循环 在while循环中,continue的作用是跳过本次循环 continue后边的代码,直接去判断部分,看是否进行下一次循环 //getcha

Linux网络编程之循环服务器

1.介绍 Linux网络循环服务器是指逐个处理客户端的连接,处理完一个连接后再处理下一个连接,是一个串行处理的方式,比较适合时间服务器,DHCP服务器.对于TCP服务器来说,主要阻塞在accept函数,等待客户端的连接。而对于UDP服务器来说,主要阻塞在recv函数. 2.循环服务器模型 TCP循环服务器: 算法如下:          socket(...);

nlp基础-文本预处理及循环神经网络

1 认识文本预处理 1 文本预处理及其作用 定义:文本送给模型之前,提前要做的工作 作用:指导模型超参数的选择 、提升模型的评估指标 举个例子: 思路常识,打造成 X Y关于Y:10分类标签是否均衡关于X:数据有没有脏数据 数据长度(512)样本不够! 文本预处理 工作 结束 的标志:准备出来X和Y 能送给模型 2 文本预处理的主要环节 1 文本处理的基本方法 分词:按照一定规

初步组装的杂合基因组如何去冗余

redundans的目标是辅助杂合基因组的组装,输入文件可以是组装的contig,测序文库以及额外的参考基因组,最后用于搭建出scaffold级别的纯合基因组组装结果。包括如下几个步骤: 从头组装: 它会调用Platanus、SSPACE3进行组装去冗余: 从最初组装中去除冗余的序列scaffolding: 利用双端测序将contig进行搭接gap closing: 即填补scaffold中的N

fot循环语句

概念: 循环是一种重复执行一段代码的结构,只要满足循环的条件,会一种执行这个代码。 循环条件:在一定范围内,按照指定的次数来执行循环 循环体:在指定的次数内,执行的命令序列。只要条件满足,循环体会被一直执行。 循环和遍历: 遍历指的是对数据结构中每个元素进行一次访问的过程,通常和循环一起使用。 访问的目的就是为了执行特定的操作 循环是操作,遍历就是输出 循环的作用: 1)*重

用for和while循环求e的值[e=1+1/1!+1/2!+1/3!+1/4!+1/5!+...+1/n!]

/*编写程序,根据以下公式求e的值。要求用两种方法计算:1)for循环,计算前50项2)while循环,直至最后一项的值小于10-4e=1+1/1!+1/2!+1/3!+1/4!+1/5!+...+1/n!*/#include<stdio.h>//=====================================================//用for求e的值doubl

利用一个正则表达式的一个例子来讲解Java中的两种for循环。

package 正则表达式;public class Rudolph {public static void main(String[] args) {// TODO Auto-generated method stubString[] str = new String[]{"Rudolph","[rR]udolph","[rR][aeiou][a-z]ol.*","R.*"};for(Strin

RNN循环卷积神经网络

1.定义 RNN (Recurrent Neural Network,RNN)循环卷积神经网络,用于处理序列数据。 序列数据:按照一定的顺序排列的数据,可以是时间顺序、空间顺序、逻辑顺序。 eg:电影、语言 2.特点 传统神经网络模型无法处理可变长度的输入。 传统神经网络模型 传统神经网络模型无法处理可变长度的输入,但是RNN通过循环的方式对当前输入和历史输入进行处

求13x+12y=100;x+45=90的解,找到一个满足的解就行(break跳出循环)

#include<stdio.h>#include<stdlib.h>//break语句不能用在循环语句和switch语句之外的语句int main(){//x>0,y>0 ,求:x,y 且是整数 //13x+12y=100:即13i+12j=100,即12j=100-13ifor(int i=0;i<100;i++){printf("%d\n",i);if((100-13*i)%12==