十四、差错控制(检错编码)

1、差错从何而来

\qquad 概括地来说,传输中的差错都是由于噪声引起的。
\qquad 全局性: 由于线路本身电气特性所产生的随机噪声(热噪声),是信道固有的,随时存在的。针对这种噪声的解决办法:提高信噪比来减少或者避免干扰,对传感器下手。
\qquad 局部性: 外界特定的短暂原因造成的冲击噪声,是产生差错的主要原因。解决办法:通常利用编码技术来解决。
差 错 { 位 错 , 比 特 位 出 错 , 1 变 成 0 , 0 变 成 1 帧 错 以 发 送 三 个 帧 【 # 1 】 − 【 # 2 】 − 【 # 3 】 为 例 , { 丢 失 , 收 到 【 # 1 】 − 【 # 3 】 重 复 , 收 到 【 # 1 】 − 【 # 2 】 − 【 # 21 】 − 【 # 3 】 失 序 , 收 到 【 # 1 】 − 【 # 3 】 − 【 # 2 】 差错\begin{cases} 位错,比特位出错,1变成0,0变成1\\ \underset{以发送三个帧【\#1】-【\#2】-【\#3】为例}{帧错},\begin{cases} 丢失,收到【\#1】-【\#3】\\ 重复,收到【\#1】-【\#2】-【\#21】-【\#3】\\ 失序,收到【\#1】-【\#3】-【\#2】 \end{cases} \end{cases} 10,01#1#2#3帧错#1#3#1#2#21#3#1#3#2 \qquad 数据链路层为网络层提供服务,在通信质量好,有线传输链路采用无确认无连接服务,在通信质量差的无线传输链路采用有确认无连接服务和有确认面向连接服务

2、数据链路层的差错控制

\qquad 首先说明数据链路层的编码和物理层的数据编码与调制不同。物理层编码针对的是单个比特,解决传输过程中比特的同步等问题,如曼彻斯特编码。而数据链路层的编码针对的是一组比特,它通过冗余码的技术实现一组二进制比特串在传输过程中是否出现了差错。
\qquad 冗余编码是指,在数据发送之前,先按照某种关系附加上一定的冗余位,构成一个符合某一规则的码字后在发送。当要发送的有效数据变化时,相应的冗余位也会随之变化,使得码字遵从不变的规则。接收端根据收到的码字是否仍符合原规则,从而判断是否出错。
\qquad 数据链路层的差错控制主要针对比特错
差 错 控 制 b i t 错 , { 检 错 编 码 , { 收 到 【 # 1 】 − 【 # 3 】 循 环 冗 余 码 C R C 纠 错 编 码 , 海 明 码 \underset{bit错}{差错控制},\begin{cases} 检错编码, \begin{cases} 收到【\#1】-【\#3】\\ 循环冗余码CRC \end{cases}\\ 纠错编码,海明码\\ \end{cases} bit差错控制{#1#3CRC

2.1 奇偶校验码

在这里插入图片描述
\qquad 奇偶校验码只能检查出奇数个比特错误,检错能力为50%。

2.2 CRC循环冗余码

\qquad CRC循环冗余码的简单思想如下图所示。
在这里插入图片描述
\qquad 下面以一个例子说明发送端生成最终发送的数据的方法:
在这里插入图片描述
\qquad 接收端检错过程中,将受到的每一个帧都除以相同的除数,然后检查得到的余数R,若余数为0则判定这个帧没有差错,接收;若余数不为0,则判断这个帧有差错,但无法确定到位,丢弃。FCS的生成以及接收端CRC检验都是由硬件实现,处理很迅速,因此不会延误数据的传输。
\qquad 凡是接收端数据链路层接收的帧均无差错,但数据链路层使用CRC检验,虽然能够实现无比特差错的传输,但还不是可靠传输可靠传输指数据链路层发送端发送什么,接收端就接收什么。

2.3 纠错编码,海明码

\qquad 海明码:可以发现双比特错,纠正单比特错。其工作原理是:动一发而牵全身。海明码的工作流程如下图所示:
在这里插入图片描述

2.3.1 确定校验码的位数 r r r

\qquad 计算校验码的位数 r r r需要通过海明不等式来实现:
2 r ≥ k + r + 1 2^r \geq k+r+1 2rk+r+1 \qquad 其中, r r r表示冗余信息为, k k k表示信息位。下面通过一个例子说明怎样求解校验码的位数:
在这里插入图片描述

2.3.2 确定校验码和数据的位置

\qquad 首先将校验码放在2的几次方的位置,之后将数据按序吧剩余的空格填满。
在这里插入图片描述

2.3.3 求出校验码的值

\qquad 求校验码的方法是:令所有要校验的位异或=0。 下面是上图求校验码的过程:
在这里插入图片描述
\qquad 所以数据101101对应的海明码即:0010011101。

2.3.4 检错并纠错

\qquad 检错的方式为:令所有要校验的位异或运算,若为0说明没问题,若为1说明有问题。之后将校验位反序输出十进制数字,即为出错的位的位置。
在这里插入图片描述

THE END

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Dragon Fly

多谢老板赏钱[抱拳抱拳抱拳]

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值