【计算机网络】第三章——差错检测

2024-05-25 10:20

本文主要是介绍【计算机网络】第三章——差错检测,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

个人主页:兜里有颗棉花糖
欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创
收录于专栏【计算机网络】
本专栏旨在分享学习计算机网络的一点学习笔记,欢迎大家在评论区交流讨论💌

目录

  • 一、比特差错
  • 二、奇偶校验
  • 三、循环冗余检验——CRC(Cyclic Redundancy Check)重点
    • 生成多项式
      • 练习1
      • 练习2
  • 四、总结

一、比特差错

比特差错:

在这里插入图片描述

如下图所示,比特流在传输过程中由于受到各种干扰,就可能出现比特差错(或误码)。
在这里插入图片描述

误码率:
在这里插入图片描述

比特在传输过程中由于误码出现了错误,那么接收方的数据链路层通过什么方法可以知道比特出现了错误呢?我们可以使用差错检错码来对比特进行检查。

差错检测码:

在这里插入图片描述

我们拿以太网版本2的MAC帧格式来进行举例:帧尾中包含了一个长度为4字节的帧检测序列FCS字段(其作用就是让接收方的数据链路层检查帧在传输过程中出现了误码)
在这里插入图片描述

我们再拿点对点协议PPP帧的格式:帧尾中也包含了两字节的帧检测序列FSC片段(其作用也是接收方的数据链路层检查帧在传输过程中出现了误码)。
在这里插入图片描述

二、奇偶校验

奇偶校验:

在这里插入图片描述
我们依然进行举例说明:

  • 下面是一个待发送的数据,假设收发双方采用奇校验,那么在数据后面添加的校验位应该为比特1,使得比特1的总数为奇数,假设传输过程中产生了1为误码,我们用红色表示。接收方对受到的比特流进行奇校验,发现比特1的总数为偶数而不是奇数,因此就知道传输过程中发生了误码。所以,采用奇校验的话,如果比特1的数目的奇性发生改变的话,此时可以检测出错误。

在这里插入图片描述

  • 但是如果传输过程中产生了两位误码,接收方对受到的比特流进行奇校验,发现比特1的总数为奇数,此时就认为比特流传输过程中没有发生误码。所以,采用奇校验,如果比特1的奇性不改变,此时就无法检测出错误。

在这里插入图片描述

  • 现在我们假设收发双方规定使用偶校验,那么在数据后面添加的校验位应该为比特0,使得比特1的总数为偶数。假设比特流传输过程中产生了一位误码,接收方对受到的比特流进行偶校验,发现比特1的总数是奇数而不是偶数,就知道比特流传输过程中发生了误码。所以,采用偶校验的话,如果比特1的数量的偶性发生改变的话,此时可以检查出错误。但是如果比特流传输过程中产生了2位误码,接收方对接收到的比特流进行偶校验,发现比特1的总数位偶数,此时就会误认为没有发生误码。因此采用偶校验,如果比特1的数量的偶性如果不改变的话,此时就检查不出错误。

在这里插入图片描述

现在对上述过程进行总结:

  • 如果有奇数个位发生误码,奇偶性发生变化,可以检查出错误
  • 如果有偶数个位发生误码,奇偶性不发生变化,不能检查出错误(漏检)(因为每个误码会对比特1的数量的奇偶性产生影响,影响相互抵消,此时就无法检查出错误)。

由于奇偶性的漏检率比较高,因此一般不会采用这种检测方法(检测比特流在传输过程中是否发生误码)。

下面我们来看循环冗余检验——CRC(Cyclic Redundancy Check

三、循环冗余检验——CRC(Cyclic Redundancy Check)重点

CRC是一种检测能力很强的一种检测方法,漏检率极低。

下图是循环冗余检验的过程:
在这里插入图片描述

  • 现在来看发送方的操作:使用除法来计算冗余码,待发送的数据作为被除数的一部分,后面添加生成多项式最高次个0以构成被除数;生成多项式各项系数构成的比特串作为除数。然后进行除法从而得到商和余数。余数就是计算出的冗余码,将其添加到待发送的数据后面一起发送过程如下图:

在这里插入图片描述

  • 现在来看接收方的操作,依然是做除法;被除数是接收到的数据;除数仍然是生成多项式各项系数构成的构成的比特串;然后进行除法得到商和余数。如果余数为0,则可以判定比特流传输过程中没有产生误码,否则则可以判定产生了误码。过程如下图:

在这里插入图片描述

生成多项式

现在我们对生成多项式进行举例说明:

在这里插入图片描述

下图是常用到的生成多项式:

使用这些生成多项式进行CRC校验,可以达到较好的检测效果(即漏检率比较低)。

注意:CRC算法要求生成多项式必须包含最低次项

练习1

在这里插入图片描述
将余数添加到待发送数据的后面就可以发送了。

练习2

在这里插入图片描述

四、总结

在这里插入图片描述

本文到这里就结束了,希望友友们可以支持一下一键三连哈。嗯,就到这里吧,再见啦!!!

在这里插入图片描述

这篇关于【计算机网络】第三章——差错检测的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.