差错控制(检错、纠错)

2023-10-09 02:10
文章标签 纠错 差错控制 检错

本文主要是介绍差错控制(检错、纠错),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

差错的由来

概括来说,传输中的差错都是由于噪声引起的。

(全局性)1.由于线路本身电气特性所产生的随机噪声(热噪声),是信道固有的,随机存在的。

解决方法:提高信噪比来减少或避免干扰

(局部性)2.外界特定的短暂原因所造成的冲击噪声,是产生差错的主要原因。

解决方法:通常利用编码技术来解决

差错的分类

位错【比特位出错,1变0,0变1】

帧错【丢失,重复,失序】

链路层为网络层提供服务:无确认无连接服务,            有确认无连接服务有确认面向连接服务  

                                          通信质量好,有线传输链路                        通信质量差的无线传输链路   ze

数据链路层的差错控制

差错控制(比特错)可分为

检错编码:奇偶校验码、循环冗余码CRC

纠错编码:海明码

冗余编码:

在数据发送之前,先按某种关系附加上一定的冗余位,构成一个符合某一规则的码字后再发送。当要发送的有效数据变化时,相应的冗余位也随之变化,使码字遵从不变的规则。接收端根据收到码字是否符合原规则,从而判断是否出错。

注:

数据链路层编码和物理层的数据编码与调制不同。物
理层编码针对的是单个比特,解决传输过程中比特的
同步等问题,如曼彻斯特编码。而数据链路层的编码
针对的是一组比特,它通过冗余码的技术实现一组二
进制比特串在传输过程是否出现了差错。

检错编码--奇偶校验码

例题:

如果一个字符s的ASCII编码从低到高依次为1100101,采用奇校验,在下述收到的传输后字符中,哪种错误不能检测?

A. 11000011         B.11001010         C.11001100         D.11010011

解:

D:“1”的个数为奇数,而原传输数据的“1”的个数也为奇数,错误不能检测出。

奇偶校验码特点:

        只能检查出奇数个比特错误,检错能力为50%。

校验原理及奇偶校验码_进击的炸酱面的博客-CSDN博客_奇校验码和偶校验码怎么求

检错编码--CRC循环冗余码

最终发送的数据:要发送的数据 + 帧检验序列FCS

计算冗余码:

(1)加0        假设生成多项式G(x)的阶为r,则加r个0.

(2)模2除法 数据加0后除以多项式余数为冗余码/FCS/CRC检验码的比特序列。

 例:

要发送的数据是1101 0110 11,采用CRC校验,生成多项式是10011,那么最终发送的数据应该是?

则最终发送的数据:1101011011 1110

接收端检错过程

把收到的每一个帧都除以同样的除数,然后检查得到的余数R。

1.余数为0,判定这个帧没有差错。

2.余数不为0,判定这个帧有差错(无法确定到位),丢弃。

FCS的生成以及CRC检验都是由硬件实现,处理狠迅速,因此不会延误数据的传输。

注:

在数据链路层仅仅使用循环元余检验CRC差错检测技术,只能做到对帧的无差错接收,即“凡是接收端数据
链路层接受的帧,我们都能以非常接近于1的概率认为这些帧在传输过程中没有产生差错”,接收端丢弃的帧虽然曾收到了,但是最终还是因为有差错被丢弃。
“凡是接收端数据链路层接收的帧均无差错”
“可靠传输”:数据链路层发送端发送什么,接收端就收到什么。
链路层使用CRC检验,能够实现无比特差错的传输,但这还不是可靠传输。

纠错编码--海明码

海明码:发现双比特错,纠正单比特错。

工作原理:动一发而牵全身

 1.确定校验码位数r

 例:要发送的数据为101101

数据的位数为6,满足不等式的最小r为4

也就是D=101101的海明码应该有6+4=10位

其中原数据6位,校验码4位

2.确定校验码和数据的位置

假设这4位校验码分别为P1、P2、P3、P4(放在2^{n}的位置);数据从左到右为D1、D2、D3....D6(按序把空填满)

3.求出校验码的值

校验位为 1,2,4,8 即 0001,0010,0100,1000

方法:

对于 数据位1,二进制表示为0001,将数据位的二进制表示中第一个比特位含有1(XXX1)的原数据位与P1进行异或运算,令其异或运算结果为0.

则可逆推出校验码P1的实际值

则可知 101101的海明码为0010011101

4.检错并纠错

假设第五位出错,因此接收到的数据位0010111101

令所有要校验的位异或运算

 

 将异或所得结果倒序排列得到0101 其对应十进制数为5 即发生错误的位

这篇关于差错控制(检错、纠错)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

通信工程学习:什么是FEC前向纠错

FEC:前向纠错        FEC(Forward Error Correction,前向纠错)是一种增加数据通信可信度的技术,广泛应用于计算机网络、无线通信、卫星通信等多种数据传输场景中。其基本原理和特点可以归纳如下: 一、FEC前向纠错的基本原理        FEC技术通过在发送端对原始数据添加冗余信息(即纠错码),使得接收端在接收到数据后,即使部分数据在传输过程中发生错误

【C++】【C++ Premier 习题集 P75页程序纠错没成功!欢迎指教】

平时练习发现这个问题,记录一下。 在C++ primer 书中,直接在常量表达式中使用strlen函数,然而实际上常量表达式只允许一个确定的值。所以在实际应用时无法通过IDE的命令行检查。【据说新标准允许了,可我的VS2012依然不允许,ORZ】大家可以看到,我特意又试了一下将函数调用单独拿出出来赋值给length,这下躲避了函数调用的问题,可IDE仍然检查不通过,为什么呢?因为le

FEC 向前纠错编码

随写,看的有点杂,简单记一下。 应该叫ReedSolomon FEC RS算法简单来讲就是,根据已有数据,构造模型,然后根据模型判纠错? 简单来讲,两点确定一条直线,直线直线上的点都会满足 y = kx + b 这个模型。 在传输场景/数据保存场景,给了两条数据 可以确定是否是正确的,而仅仅发送一条数据是无法判断的。然后发送三条数据可有判断第三条是否在这个模型上。但是一般传输数据,还会携带冗余

28.建议和纠错

创建ByteBuf建议 特别说明: 之前创建的ByteBuffer都是: ByteBuf buffer = ByteBufAllocator.DEFAULT.buffer(10); //默认获取的是直接内存  这样创建只是自己写一些测试练习使用。 真正项目开发中,还是建议在handler中的创建:在服务端发送数据给客户端的时候。 @Overridepublic void chan

深入理解网络传输协议——差错控制

1. 差错控制 差错控制(error control)包括对损坏、丢失以及重复的数据报进行检测的机制。差错控制还包括在检测到错误之后的纠错机制。因特网的网络层不提供真正意义上的差错控制机制。 从表面上看网络层好像是不需要差错控制的,因为每个数据报在到达终点之前都要穿过多个网络,而控制这些网络(局域网或广域网)行为的数据链路层已经使用了差错控制机制。换言之,既然在数据链路层已经实施了逐跳的差错控

RFID期末复习 | 防碰撞算法 | 信源编码 | 差错控制 | 系统调制 | S50卡 | 无源标签 | 工作频率 | 自动识别

防碰撞算法 ALOHA算法 ALOHA算法是一种随机接入方法,其基本思想是采取标签先发言的方式,当标签进入读写器的识别区域内时就自动向读写器发送其自身的ID号,在标签发送数据的过程中,若有其他标签也在发送数据,将会发生信号重叠,从而导致冲突。读写器检测接收到的信号有无冲突,一旦发生冲突,读写器就发送命令让标签停止发送,随机等待一段时间后再重新发送以减少冲突。 纯ALOHA算法 在纯ALOH

文本审核纠错

探索高效文本审查利器:Word Checker-CSDN博客 GitHub - shibing624/pycorrector: pycorrector is a toolkit for text error correction. 文本纠错,实现了Kenlm,T5,MacBERT,ChatGLM3,LLaMA等模型应用在纠错场景,开箱即用。 231112-中文错别字识别与纠正问题的大模型与

划重点来了,计算机组成原理之计算机存储介绍与汉明码纠错

存储器   1. 分类 (1)按存储介质分类: 存储介质是能寄存”0“或"1"两种代码的物质或元器件。 包括半导体器件,磁性材料,光盘等。 半导体存储器:半导体器件组成的存储器。断电后数据会丢失,易失性存储器。 磁表面存储器:在金属或塑料基体的表面涂的一层磁性材料。按载磁体形状不同,分为磁盘磁带,磁鼓。 磁芯存储器:硬磁材料做成的环形器件 。 光盘存储器:激光在介质上读写。

杰发科技AC7801——支持的纠错功能

1. 复位寄存器保留复位类型 低压检测复位(LVD Reset) 集成了一个低压保护系统,以便在电源电压发生变化期间保护存储器内容和控制 MCU 系统状态。该系统由上电复位(POR)电路和 LVD 电路组成,LVD 可以配置为不同的复位基准,可以是高电平(VLVDH) 或低电平(VLVDL)。 ECC 2 bit 错误复位(2 Bit Error Reset) 配置 RESET_CTRL[

中文纠错实战

假设有这么一个场景,医生开处方的时候,可能写错药品和疾病名称,需要程序自动化纠错 例如:曲米新乳膏和二甲双瓜和双黄连     曲米新乳膏 ==> 曲咪新乳膏     二甲双瓜 ==> 二甲双胍     怎么做呢? 直觉告诉我们,应该有一个数据源,包含所有的药品疾病名称。 1、数据抓取       寻医问药 http://www.xywy.com/     丁香园 http://