热门标签 | HotTags
当前位置:  开发笔记 > 人工智能 > 正文

夜光带你走进通信网络(十三)新的领域

夜光序言:“成长”这两个字真是孤单得连偏旁都不曾拥有~~正文:错误检测网络必须能将数据准确无误地从一个设备传输到另一个设备。但是由于线路噪声在内的多种

夜光序言:


“成长”这两个字真是孤单得连偏旁都不曾拥有~~

 

 

 


 


正文:错误检测

 

网络必须能将数据准确无误地从一个设备传输到另一个设备。但是由于线路噪声在内的多种因素可能使数据在传输中被破坏。对
于可靠传输来说,必须进行错误检测和纠正。

在OSI模型中,错误检测和纠正机制要么在数据链路层实现,要么在传输层实现。

 

在数据传输中,一般会产生三种类型的错误:


• 单比特错误:在数据单元中只有一个比特发生了改变。
• 多比特错误:在数据单元中有两个或两个以上的不连续比特发
生了改变。
• 突发错误:在数据单元中有两个或两个以上连续的比特发生了
改变。

其中,单比特错误最容易发生而突发错误比较不容易发生。

 

 

在数据传输中,错误检测采用了冗余技术,就是在信息中加上附加比特以便于接收端进行错误检测。


在数据通信中采用四种类型的冗余校验技术:


• 垂直冗余校验(VRC),也称为奇偶校验
• 纵向冗余校验(LRC)
• 循环冗余校验(CRC)
• 校验和其中,前三种技术是在物理层实现而被数据链路层使用的;

 

第四种技术主要由网络层或国际互连网所使用,而在传输层实现的。

在垂直冗余校验(VRC)中,在每一个数据单元上都增加一个校验位,从而使得1的总数(包括校验位)对于偶校验来说是偶数,或对于奇校验来说是奇数。垂直冗余校验(VRC)中偶校验的概念垂直冗余校验(VRC)可以检测所有的单比特错误。只有当发生错误的比特个数为奇数个时,它才能检测出多比特和突发错误。

 

纵向冗余校验(LRC)是在两维上的垂直冗余校验(VRC)。它在若干个数据单元后增加了一个冗余单元,冗余单元内的各比特
位是从采用VRC校验的数据单元的各对应位计算得来的。纵向冗余校验(LRC)对于所有在偶数个数据单元的偶数个相同位置发生错误的情况不能检测外,其它的错误都能检测出来。

 

循环冗余校验(CRC)是最有效的一种冗余校验技术。它基于二进制除法来实现。


循环冗余校验(CRC)生成器和校验器通过在数据单元末尾附加一串冗余比特,称作循环冗余码或循环冗余校验余数,使得整个数据单元可以被另一个预定的二进制数所整除。在接收端,用同一个数去除输入的数据单元,如果能整除,就认为没有错误发生,否则拒绝该数据单元。

循环冗余码(CRC)生成器:


二进制除法

具有以下两个特性的CRC码才是合法的:必须比除数至少少一位;在附加到数据串末尾后必须形成可以被除数所整除的比特序列。

CRC生成多项式:
标准多项式


循环冗余校验(CRC)生成器(除数)通常不是由一串0或1来代表的,而是用一个代数多项式代表。

校验和技术是在高层写一种使用的错误检测技术。

数据单元和校验和在发送方,校验和生成器将数据单元细分成大小为n(通常是16)比特的几段。这些分段采用反码加法算法加在一起,使得整个结果仍然是n比特长。该总和(校验和)随后取反并当作冗余位加在原始数据单元的末尾,称作校验和域。

 

在接收方,校验和校验器采用同样的方法分段并相加(包括校验和域在内),结果为全1时表示没有错误发生。

 

可靠性:
校验和检测所有涉及奇数个比特的错误,以及大多数涉及偶数个比特的错误。但是,如果在某一段中的一个或多个比特被破坏,并且在下一个分段中具有相反值的对应位也被破坏,这些列的和将不变因此不能被接收方检测出错误。

 

在数据通信中,错误纠正可以通过两种方式进行。一种方式是当发现错误时,接收方可以让发送方重新发送整个数据单元;另一
种方式是可以采用错误纠正码,即纠错码,自动纠正一些错误。

1. 单比特错误纠正

错误纠正的关键在于发现错误后还能对错误的比特位或比特组进行定位,这就需要更多的冗余位。

如果可传输单元的总比特数是m+r(m位数据r位冗余位),那么r必须能至少代表m+r+1种状态。在这些状态中,一种状态代表
没有错误,其它m+r种状态代表在m+r位每个位置上发生的错误。因此有: 2 r  >= m+r+1

2. 海明码


在海明码中,冗余比特被放在比特位中的2的指数序数处,如1,2,4,8等,每个冗余比特都是一组数据比特的VRC校验位。r 1 是通过所有二进制表示中最低位为1的比特位置计算得到的, r 2 是通过所有二进制表示中次低位为1的比特位置计算得到的,依次类推。

在7位数据序列中,需要4位冗余位。计算这4个冗余比特位的比特组合为:
r 1 :第1,3,5,7,9,11比特
r 2 :第2,3,6,7,10,11比特
r 3 :第4,5,6,7比特
r 4 :第8,9,10,11比特

3. 多比特错误纠正

在互相重叠的数据比特组上计算的冗余位也可以用来纠正多比特错误。但是,纠正这些错误所需要的冗余比特数将大大高于纠正单比特错误的冗余比特数。

 


推荐阅读
  • 深入解析Android自定义View面试题
    本文探讨了Android Launcher开发中自定义View的重要性,并通过一道经典的面试题,帮助开发者更好地理解自定义View的实现细节。文章不仅涵盖了基础知识,还提供了实际操作建议。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文介绍如何利用动态规划算法解决经典的0-1背包问题。通过具体实例和代码实现,详细解释了在给定容量的背包中选择若干物品以最大化总价值的过程。 ... [详细]
  • 本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 深入理解C++中的KMP算法:高效字符串匹配的利器
    本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ... [详细]
  • 探讨一个显示数字的故障计算器,它支持两种操作:将当前数字乘以2或减去1。本文将详细介绍如何用最少的操作次数将初始值X转换为目标值Y。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文探讨如何设计一个安全的加密和验证算法,确保生成的密码具有高随机性和低重复率,并提供相应的验证机制。 ... [详细]
  • 深入解析:手把手教你构建决策树算法
    本文详细介绍了机器学习中广泛应用的决策树算法,通过天气数据集的实例演示了ID3和CART算法的手动推导过程。文章长度约2000字,建议阅读时间5分钟。 ... [详细]
  • 在金融和会计领域,准确无误地填写票据和结算凭证至关重要。这些文件不仅是支付结算和现金收付的重要依据,还直接关系到交易的安全性和准确性。本文介绍了一种使用C语言实现小写金额转换为大写金额的方法,确保数据的标准化和规范化。 ... [详细]
  • 在给定的数组中,除了一个数字外,其他所有数字都是相同的。任务是找到这个唯一的不同数字。例如,findUniq([1, 1, 1, 2, 1, 1]) 返回 2,findUniq([0, 0, 0.55, 0, 0]) 返回 0.55。 ... [详细]
  • 本文探讨了卷积神经网络(CNN)中感受野的概念及其与锚框(anchor box)的关系。感受野定义了特征图上每个像素点对应的输入图像区域大小,而锚框则是在每个像素中心生成的多个不同尺寸和宽高比的边界框。两者在目标检测任务中起到关键作用。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
author-avatar
想太多先生的微博
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有