【系统架构设计师】计算机组成与体系结构 ⑯ ( 奇偶校验码 | CRC 循环冗余码 | 海明码 | 模 2 除法 )

news2024/9/21 18:33:11

文章目录

  • 一、校验码
    • 1、校验码由来
    • 2、奇偶校验码
    • 3、CRC 循环冗余码 ( 重点考点 )
    • 4、海明码校验 ( 软考不经常考到 )
  • 二、CRC 循环冗余码 ( 重点考点 )
    • 1、模 2 除法概念
    • 2、模 2 除法步骤
    • 3、模 2 除法示例
    • 4、CRC 循环冗余码示例 1
    • 5、CRC 循环冗余码示例 2


参考之前的博客 :

  • 【计算机网络】数据链路层 : 差错控制 ( 检错编码 | 奇偶校验码 | CRC 循环冗余码 )★
  • 【计算机网络】数据链路层 : 差错控制 ( 纠错编码 | 海明码 | “海明码“ 原理 | “海明码“ 工作流程 | 确定校验啊位数 | 确定校验码和数据位置 | 求校验码值 | 检错纠错 )★




一、校验码




1、校验码由来


计算机 数据 传输时 , 数据 可能会因为 电磁干扰、硬件故障等原因 出现 1 变 0 或 0 变 1 的错误 ;

校验码 可以 通过 增加冗余信息 来 检测和纠正 数据传输 过程中的 错误 , 可 提高数据传输的可靠性 , 确保数据的 完整性和准确性 ;

常用的校验码有 :

  • 奇偶校验码
  • CRC 循环冗余码
  • 海明码

2、奇偶校验码


奇偶校验码 是在 数据的有效信息 之外 , 追加一位 , 组成校验码 ;

  • 奇校验 : 1 的个数为 奇数 , 追加的 冗余校验码位为 1 ;
  • 偶校验 : 1 的个数为 偶数 , 追加的 冗余校验码位为 0 ;

如果 正好有 2 位出现了错误 ,

  • 两个 1 变成了 0 ,
  • 两个 0 变成了 1 ,
  • 一个 1 变成了 0 , 一个 0 变成了 1 ,

就无法检查出错误 ; 同理 , 如果有 4 位出现了错误 , 也无法检查出来 ;


奇偶校验码 只能检查 奇数个 比特错误 , 如果有 偶数个比特错误 , 无法检查出来 , 检错率是 50 % ;

奇偶校验码 只能检查错误 , 不能纠错 ;

  • 纠错的前提是知道错误位置 , 将其取反即可 , 找不到错误位置 , 就无法进行纠错 ;

3、CRC 循环冗余码 ( 重点考点 )


CRC 循环冗余码 是 基于模 2 运算的校验码 , 通过将 数据 视为一个 多项式 并使用除法运算生成校验码 ;

CRC 循环冗余码 能够 检测错误 , 但是不能进行纠错 ;

CRC 循环冗余码 会在 信息位 之后 拼接 多位校验位 , 不是 奇偶校验码 的 一位 , 增加的冗余校验位增加 , 相对发现错误的几率也会更大 ;


CRC 循环冗余码 在 k 位信息后 , 拼接 r 位 校验码 , 这里涉及到两个问题 :

  • 发送端 : 根据 k 位信息 , 计算出 r 位 校验码 ;
  • 接收端 : 根据 k + r 位的信息 , 检验数据是否正确 ;

具体参考 【计算机网络】数据链路层 : 差错控制 ( 检错编码 | 奇偶校验码 | CRC 循环冗余码 )★ 博客中的内容 ;


4、海明码校验 ( 软考不经常考到 )


海明码校验 的 原理 是 通过 交叉校验的方式 , 形成了多组不同的 奇偶校验 ;

海明码 在 2 的幂次方的位置 插入校验位来工作 , 即位置1, 2, 4, 8, 16等 , 校验位的数量 取决于需要编码的数据位的数量 ;


校验位的数量 p 满足以下不等式 :

2 p ≥ n + p + 1 2^p ≥ n+p+1 2pn+p+1

  • p 是校验位数量 ;
  • n 是原始数据的位数 ;

具体的案例 , 参考 【计算机网络】数据链路层 : 差错控制 ( 纠错编码 | 海明码 | “海明码“ 原理 | “海明码“ 工作流程 | 确定校验啊位数 | 确定校验码和数据位置 | 求校验码值 | 检错纠错 )★ 博客 ;


在架构师考试时 , 该知识点不经常考到 , 掌握校验位个数的公式即可 ;





二、CRC 循环冗余码 ( 重点考点 )




1、模 2 除法概念


" 模 2 除法 " , 又称为 " 二进制除法 " 或 " 模 2 运算中的除法 " ;

" 模 2 除法 " 是一种 在 二进制数 系统 中执行的除法运算 , 与普通的 十进制除法 不同 , 模 2 除法中的所有运算都是基于 二进制 进行 ;

" 模 2 除法 " 在 除法运算过程中 , 不进行 借位 , 直接得到 借位 后的结果 ;

" 模 2 除法 " 在 计算过程中 , 每一步的 结果 与 " 异或运算 " 的结果是一样的 , " 异或运算 " 是 二者相同 则为假 , 二者不同则为真 ;


2、模 2 除法步骤


" 模 2 除法 " 步骤 :

  • 设置 被除数 和 除数 : 设置 两个 二进制数 , 一个作为 被除数 , 另一个作为除数 ;
  • 模 2 除法过程 ( 异或运算 ) :
    • 从 被除数 的最高位开始 , 将其与 除数 进行比较 ;
      • 这里每一位都按照 " 异或运算 " , 进行计算 ;
    • 重复上述步骤 , 直到处理完被除数的所有位 ;
  • 得到商和余数 : 完成上述步骤后 , 得到一个二进制数作为商 , 以及一个二进制数作为余数 , 余数就是 校验位 ;

3、模 2 除法示例


下面的运算就是一个 模 2 除法 :

在这里插入图片描述

第一步计算中 ,

  • 红色矩形框 中 1 减去 0 , 得 1 是正常的 ,
  • 蓝色矩形框 中 0 减去 1 , 按照普通除法来算的话 , 需要向前借一位 , 但是此时不进行借位 , 仍然得到结果 1 ;
  • 绿色矩形框 中 , 1 减去 1 , 得到的结果是 0 ;

异或运算 规律 :

  • 可以看到上述结果 不管是 1 和 0 还是 0 和 1 最终得到的结果都是 1 ;
  • 但是 如果 上下两位 都是 1 或者 都是 0 , 最终得到的结果就是 0 ;
  • 上述规律得到的结果与 异或运算 是相同的 ;

在这里插入图片描述


第二步中 ,

  • 红色矩形框 中 1 与 0 进行 异或运算 , 得到的结果是 1 ;
  • 蓝色矩形框 中 1 与 1 进行 异或运算 , 得到的结果是 0 ;

最终得到 011 , 小于 110 , 011 就是余数 , 商为 110 ;

在这里插入图片描述


4、CRC 循环冗余码示例 1


【计算机网络】数据链路层 : 差错控制 ( 检错编码 | 奇偶校验码 | CRC 循环冗余码 )★ 博客中也有一个 CRC 编码示例 , 可结合参考 ;


原始报文是 10111 , 生成多项式为 G ( x ) = x 4 + x + 1 G(x) = x^4 + x + 1 G(x)=x4+x+1 , 计算编码后的发送数据 ;

生成多项式 是 发送方 和 接收方 约定好的 ;


计算 帧检验序列 FCS :

① 数据加 冗余码 位数个 0 0 0 : 首先确定 冗余码 位数 , 冗余码的位数是 生成多项式的 阶 加上 1 , 即 生成多项式 的 总位数 减去 1 1 1 , 相当于 离散数学 中的生成函数的 最高位次幂 ; FCS 的位数是 4 4 4 位 ;

生成多项式 是 N N N 位 , 那么阶 就是 N − 1 N-1 N1 位 , FCS 帧检验序列就是 N − 1 N-1 N1 位 ;

生成多项式为 G ( x ) = x 4 + x + 1 G(x) = x^4 + x + 1 G(x)=x4+x+1 , 阶为 4 , FCS 帧检验序列是 4 位 , 其二进制形式有 5 位 ;

10111 数据加 4 4 4 0 0 0 后为 101110000 10111 0000 101110000 ;


② 生成多项式 转为二进制 :

G ( x ) = x 4 + x + 1 G(x) = x^4 + x + 1 G(x)=x4+x+1

将空位补齐后为 :

G ( x ) = 1 x 4 + 0 x 3 + 0 x 2 + 1 x 1 + 1 x 0 G(x) = 1x^4 + 0x^3 + 0x^2 + 1x^1 + 1x^0 G(x)=1x4+0x3+0x2+1x1+1x0

将生成多项式转为二进制形式后为 : 10011 10011 10011 ;


② 模 2 2 2 除法 : 数据 加上 0 0 0 后 , 除以 生成多项式 , 余数就是 FCS 帧检验序列 ;

二进制除法 , 与十进制除法不同的是 , 每个除法相除的计算是 异或操作 ;

异或运算 : 同 0 0 0 , 异 1 1 1 ;

在这里插入图片描述

2 2 2 除法计算过程分析 : 被除数 9 位 ( 1 ~ 9 计数 ) , 除数 5 位 ( 1 ~ 5 计数 ) ;

  • 10111 10111 10111 异或 10011 10011 10011 计算得到 100 100 100 , 然后第六位 0 0 0 落下来 , 得到 1000 1000 1000 ;
  • 1000 1000 1000 位数不足 , 继续第七位 0 0 0 落下来 , 得到 10000 10000 10000 ;
  • 10000 10000 10000 异或 10011 10011 10011 计算得到 11 11 11 , 然后下面第八位 落下来 , 得到 110 110 110 ;
  • 110 110 110 位数不足 , 继续第九位 0 0 0 落下来 , 得到 1100 1100 1100 ;

最终的余数是 1100 , 这也是 FSC 帧检验序列 ;


最终计算出来的 帧检验序列 是 1100 1100 1100 ;

最终发送的数据是 : 10111 10111 10111 1100 1100 1100



接收端接收数据并校验 :

① 检验过程 : 接收端接收 上述 10111 10111 10111 1100 1100 1100 数据 , 将上述数据 与 生成多项式 10011 10011 10011 相除 , 如果余数为 0 0 0 说明该数据帧没有差错 ;

② 结果判定 : 如果余数不为 0 0 0 , 说明数据帧错误 , 而且不知道哪里出现错误 , 丢弃该数据帧 , 重新发送 ;


5、CRC 循环冗余码示例 2


传输数据位 111000110 , 生成多项式为 G ( x ) = x 5 + x 3 + x + 1 G(x) = x^5 + x^3 + x + 1 G(x)=x5+x3+x+1 , 计算 CRC 循环冗余校验码 ;

生成多项式 是 发送方 和 接收方 约定好的 ;


生成多项式为 G ( x ) = x 5 + x 3 + x + 1 G(x) = x^5 + x^3 + x + 1 G(x)=x5+x3+x+1 , 补齐后为 :

G ( x ) = 1 x 5 + 0 x 4 + 1 x 3 + 0 x 2 + 1 x 1 + 1 x 0 G(x) = 1x^5 + 0x^4 + 1x^3 + 0x^2 + 1x^1 + 1x^0 G(x)=1x5+0x4+1x3+0x2+1x1+1x0

得到的二进制形式为 101011 ;


进行模 2 除法 : 111000110 ÷ 101011 111000110 \div 101011 111000110÷101011 , 得到余数 11001 11001 11001 ;

在这里插入图片描述

余数 11001 11001 11001 就是校验码 ;

最终的发送序列为 : 111000110 111000110 111000110 11001 11001 11001

  • 蓝色为原始数据 ;
  • 红色为校验序列 ;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1947201.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于微信小程序的自习室选座系统/基于Java的自习室选座系统/自习室管理系统的设计与实现

获取源码联系方式请查看文章结尾🍅 摘要 自习室选座是学校针对用户必不可少的一个部分。在学校的整个过程中,学生担负着最重要的角色。为满足如今日益复杂的管理需求,各类微信小程序自习室选座也在不断改进。本课题所设计的小程序自习室选座系…

npm下载pnpm

一、提供node_global和node_cache的文件夹 若不存在,可自行新建文件夹 二、配置环境变量 配置NODE_PATH变量: 配置Path变量: 三、执行cmd指令 npm config set prefix "D:\Configure\nodejs\node_global" npm config set cache &…

cdga|数据治理难题破解:策略与实施路径

随着信息技术的飞速发展,数据已成为企业最宝贵的资产之一。然而,数据治理的复杂性也随之增加,如何有效管理、保护和利用数据成为摆在企业面前的一大难题。本文将从数据治理的挑战入手,探讨其破解策略与实施路径。 数据治理的挑战 …

华为IoTDA平台下发MQTT消息

前一篇博文介绍了如何使用MQTTX连接华为IoTDA平台并上报消息,本文介绍一下如何下发消息。 IoT设备接入平台支持MQTT协议设备进行命令下发,属性设置,属性查询以及消息下发等操作。 在进入指定设备的页面后,选择“云端下发”&#…

洛谷 P9854 [CCC 2008 J1] Body Mass Index

这题让我们计算出 BMI 值,随后判断属于哪个等级。 BMI 值计算公式: ​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​​ ​​​​​​​。 BMI 范围 对应信息 …

element-plus时间组件el-date-picker只能选择当前及之前日期

<el-date-picker v-model"timeVal" type"daterange" value-format"YYYY-MM-DD" range-separator"To" start-placeholder"开始时间" end-placeholder"结束时间" />默认是这样的&#xff0c;需要绑定disabled…

安卓手机怎么恢复出厂设置?之后如何恢复数据?3个技巧解决

随着时间的推移&#xff0c;手机可能会遇到性能下降、系统崩溃或其他问题。在这种情况下&#xff0c;恢复出厂设置成为了一个常见的解决方案。安卓手机怎么恢复出厂设置&#xff1f;如何在恢复出厂设置后恢复数据呢&#xff1f;本文将详细解答这些问题&#xff0c;并分享3个数据…

JavaWeb-Servlet(1)-Servlet程序、请求处理、继承体系

目录 什么是Servlet 手动实现Servlet程序 ​编辑url地址如何定位到Servlet程序去访问 Servlet的生命周期 ​编辑GET和POST请求的分发处理 通过继承HttpServlet类实现Servlet程序 IDEA菜单生成Servlet程序 Servlet类的继承体系 ServletConfig类 ServletContext类 什么…

Elasticsearch 7.x入门学习-Java API操作

1 创建项目 在idea开发工具中创建Maven项目 修改 pom 文件&#xff0c;增加 Maven 依赖关系 <dependencies><dependency><groupId>org.elasticsearch</groupId><artifactId>elasticsearch</artifactId><version>7.8.0</versi…

2024恶意样本提交激励计划:年中特别回馈惊喜来袭

恶意样本提交激励计划 “恶意样本提交激励计划”由CACTER邮件安全发起&#xff0c;主要目的是更好地帮助客户排查潜在风险问题&#xff0c;同时丰富Coremail邮件安全大数据中心威胁邮件云端特征库&#xff0c;共同提升Coremail邮件安全大数据中心的识别能力&#xff0c;共同建…

别错过!2024年苹果iPhone AI革命:揭秘技术突破与未来蓝图

本文首发于公众号“AntDream”&#xff0c;欢迎微信搜索“AntDream”或扫描文章底部二维码关注&#xff0c;和我一起每天进步一点点 2024年&#xff0c;苹果公司的iPhone手机在技术创新和系统升级方面展现出一系列亮点&#xff0c;预示着苹果在智能手机领域的持续领导地位。以下…

【python】Python中采集Prometheus数据,进行数据分析和可视化展示

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

openEuler安装docker,加速镜像拉取

文章目录 文章来源1.配置镜像源2.编辑配置文件3.安装想要的版本4. ~ 原神&#xff01;5.由于很多镜像无法拉取配置镜像源 文章来源 http://t.csdnimg.cn/zYDYy 原文连接 由于之前的仓库不让用且 1.配置镜像源 由于 国外的镜像仓库好多不让用 所以配置阿里的镜像源 yum-confi…

MySQL之视图和索引

新建数据库 插入数据 处理表 1. 2. 3. mysql> alter table sc add unique index SC_INDEX (sno asc,cno asc); 4. mysql> create view stu_info as select student.sno,ssex,sc.cno,score from student join sc on student.snosc.sno; 5. mysql> drop index S…

VD2120-DB可替代HY2120-DB 两串可充电锂电池保护IC

VD2120系列10,内置高精度电压检测电路和延时电路&#xff0c;是用于2节串联锂离子/锂聚合物可再充电电池的保护IC。VD2120系列IC适合于对2节串联可再充电锂离子/锂聚合物电池的过充电、过放电和过电流进行保护。 VD2120-DB的参数如下 HY2120-DB的参数如下 参数上面的使用上基本…

LeetCode - #103 二叉树的锯齿形层序遍历

文章目录 前言1. 描述2. 示例3. 答案关于我们 前言 我们社区陆续会将顾毅&#xff08;Netflix 增长黑客&#xff0c;《iOS 面试之道》作者&#xff0c;ACE 职业健身教练。&#xff09;的 Swift 算法题题解整理为文字版以方便大家学习与阅读。 LeetCode 算法到目前我们已经更新…

销售分析,奥威BI,销售好帮手

【销售分析&#xff0c;奥威BI&#xff0c;销售好帮手】 在商海浮沉中&#xff0c;销售数据是企业最宝贵的资产之一&#xff0c;它不仅反映了市场的反馈&#xff0c;更是指引企业未来战略方向的灯塔。奥威BI&#xff08;Business Intelligence&#xff09;&#xff0c;作为数据…

【实现100个unity特效之8】使用ShaderGraph实现2d贴图中指定部分局部发光效果

最终效果 寒冰法师 火焰法师 文章目录 最终效果寒冰法师火焰法师 素材一、功能分析实现方法基本思路Unity的Bloom后处理为什么关键部位白色&#xff1f;最终结果 二、 新建URP项目三、合并图片四、使用PS制作黑白图片方法一 手动涂鸦方法二 魔棒工具1. 拖入图片进PS&#xff0…

干货 | 记一次src通杀漏洞挖掘

0x1 前言 这里我是有目的地去对某机构或者某学校进行渗透测试漏洞挖掘的&#xff0c;之前在网上看到很多文章说可以直接去edusrc官网的漏洞排行榜上去找&#xff0c;可以去看一些开发商排行榜以及某些高校大学的排行榜&#xff0c;里面有很多的该公司或者该学校的漏洞提交情况…

PACS医学影像临床信息系统,C#影像归档和通信系统源码,PACS源码,支持图像的获取、传输、浏览、打印、测量、重建、对比、存储、处理,电子胶片影像管理等

医学影像临床信息系统具有图像采集、显示、存储、传输和管理等功能&#xff0c;支持DICOM影像设备和非DICOM影像设备&#xff0c;可以识别CT、MR、CR/DR、X光、DSA、B超、NM、SC等设备的图像类型&#xff0c;可对数字影像进行无损压缩和有损压缩处理。C/S体系结构的多媒体数据库…