一、简介

CRC的全称为Cyclic Redundancy Check,中文名称为循环冗余校验。它是一类重要的线性分组码,编码和解码方法简单,检错和纠错能力强,在通信领域广泛地用于实现差错控制。实际上,除 数据通信外,CRC在其它很多领域也是大有用武之地的。例如我们读软盘上的文件,以及解压一个ZIP文件时,偶尔会碰到“Bad CRC”错误,由此它在数据存储方面的应用可略见一斑。

二、原理介绍

上一个项目完成的不错,大雄和小兰打算做利用CRC做一个数据传输的保障,下面我们来简单介绍一下CRC的原理。
大雄最为数据的发送方,有一个8位的数据0001 0101要发送给小兰,根据CRC的原理大雄和小兰需要约定一个除数(按照不同的标准有不同的数,这里是通信双方自行定义的),大雄和小兰定义的是1100。
第一步: 现在大雄最为发送方需要将带发送的数据1:0001 0101向左移动三位,得到数据2:000 1010 1000。
为什么是三位呢?
后面的操作是将移位后的数据除以除数1100,这里需要保证被除数,大于除数,有效的办法就是让原始数据向左移动比除数少一位,这里的除数是四位的,所以原始数据需要向左移动的三位。

第二步: 就是大雄需要把数据2:000 1010 1000除以除数:1100,求得余数。
这里的除法不是普通的十进制除法,而是模“2”除法。
什么是模“2”除法?

下面计算数据

第三步: 大雄需要经数据1:0001 0101后面加上第二步计算的余数得到数据3:000 1010 1100。

小兰收到数据后怎么样验证数据的正确性?
小兰收到数据3:000 1010 1100后会用数据3除以除数:1100,也是模“2”除法,如果得到的结果为0,则数据正确,否则数据错误!

余数为0,数据正确!!!

计算过程总结:
1、由多项式得到除数n位
2、将需要发送的数据左移(n-1)位,得到余数
3、将第二步得到的余数加原始数据后面发送
接收方检验方法:将收到的数据模“2”除法除以除数,余数为0,数据正确,否则错误!

三、规范介绍

下表中列出了一些见于标准的CRC资料:

生成多项式的最高幂次项系数是固定的1,故在简记式中,将最高的1统一去掉了,如04C11DB7实际上是104C11DB7。 前称CRC-CCITT。ITU的前身是CCITT。
注释:
1、生成多项式是标准规定的
2、发送方和接收方必须事先商定一个生成多项式G(x),其高位和低位必须是1。

四、CRC参数模型

一个完整的CRC参数模型应该包含以下信息:WIDTH,POLY,INIT,REFIN,REFOUT,XOROUT。

  • NAME:参数模型名称。

  • WIDTH:宽度,即生成的CRC数据位宽,如CRC-8,生成的CRC为8位

  • POLY:十六进制多项式,省略最高位1,如 x8 + x2 + x + 1,二进制为1 0000 0111,省略最高位1,转换为十六进制为0x07。

  • INIT:CRC初始值,和WIDTH位宽一致。

  • REFIN:true或false,在进行计算之前,原始数据是否翻转,如原始数据:0x34 = 0011 0100,如果REFIN为true,进行翻转之后为0010 1100 = 0x2c

  • REFOUT:true或false,运算完成之后,得到的CRC值是否进行翻转,如计算得到的CRC值:0x97 = 1001 0111,如果REFOUT为true,进行翻转之后为11101001 = 0xE9。

  • XOROUT:计算结果与此参数进行异或运算后得到最终的CRC值,和WIDTH位宽一致。

  • 通常如果只给了一个多项式,其他的没有说明则:INIT=0x00,REFIN=false,REFOUT=false,XOROUT=0x00。

常见的CRC标准模型:

参考文章

1、CRC校验原理及其C语言实现

循环冗余校验-CRC相关推荐

  1. [2021.07.25更新]循环冗余校验(CRC)的MATLAB实现

    欢迎同步关注公众号[逆向通信猿] CRC校验(循环冗余校验) 在计算CRC校验的时候,发现一个网站如下 http://www.ip33.com/crc.html 于是,想自己动手实现该网站计算CRC校 ...

  2. 2.1.5-3 循环冗余校验(CRC)码

    想必是雪乞春华 (҂◔∀◐҂)☆万圣节快乐♬☆◥(ฅº₩ºฅ)◤ 不给糖就捣蛋 ☆(●⁰౪⁰●)没钱(*^3^)/-☆ 中午我们要学习最后一种校验码叫做循环冗余校验码英文缩写叫CrC码,这给出了他的英 ...

  3. CRC循环冗余校验(计算机网络)

    CRC循环冗余校验 CRC差错检验的过程 提要 CRC的具体过程 例题详解 CRC差错检验的过程 提要  数据在链路层进行传输时,为了保证接收到的数据比特流是准确无误的,会采用CRC循环冗余校验的方式 ...

  4. crc循环冗余校验 php,crc 循环冗余校验

    --- title: crc 循环冗余校验 date: 2018-09-26 updated: 2018-10-06 --- # crc 循环冗余校验 CRC(Cyclic Redundancy Ch ...

  5. 循环冗余校验码CRC,求解步骤

    循环冗余校验码CRC,是软考-计算机组成原理 中一种重要的编码. 下面只是简要描述求解CRC码的解题步骤,面向有一定理论基础的朋友. 直接看例题. 例.信息位: 10100110   生成多项式: 解 ...

  6. 第二章 数据的表示和运算 2.1.6 循环冗余校验码/CRC码 [计算机组成原理笔记]

    第二章 数据的表示和运算 2.1.6 循环冗余校验码/CRC码 本笔记参考书目: 计算机组成原理(第六版.立体化教材)白中英.戴志涛 2021王道计算机组成原理视频公开课 本节重点: 循环冗余校验码/ ...

  7. 计算机组成原理:循环冗余校验码CRC具备“一位纠错”功能的思考与探索

    笔者在阅读华中科技大学谭志虎老师主编的<计算机组成原理(微课版)>教材进行复习时,产生了一个疑问,并针对性地进行了一些思考.欢迎广大复习到这里同样有问题的同学(寒假开学接着考试实在有点汗, ...

  8. 一文读懂循环冗余校验(CRC)原理

    校验原理 baidu 循环冗余校验(Cyclic Redundancy Check, CRC)是一种根据网络数据包或计算机文件等数据产生简短固定位数校验码的一种信道编码技术,主要用来检测或校验数据传输 ...

  9. c语言累加和校验_循环冗余校验(CRC)算法入门

    http://blog.csdn.net/liyuanbhu/article/details/7882789 前言 CRC校验(循环冗余校验)是数据通讯中最常采用的校验方式.在嵌入式软件开发中,经常要 ...

最新文章

  1. Launcher代码大全
  2. Ada 程序设计语言(The Ada Programming Language)[第二集]
  3. 深度学习指南:在iOS平台上使用TensorFlow
  4. 远程桌面上的文件复制到本地
  5. Python 国产库推荐之 musicpy
  6. 中国内脏痛行业市场供需与战略研究报告
  7. Windows 7程序开发系列之一(任务栏篇)
  8. python sorted函数
  9. Java发送邮件(QQ邮箱)
  10. ICP算法详解——我见过最清晰的解释
  11. PS 工具获取:Photoshop CS6超级免安装精简版来临!不到200M!
  12. android studio连接木木模拟器
  13. 微信分享本地视频到朋友圈,收藏或者对话
  14. 网络及网络设备(持续更新)
  15. 【Leetcode】1564. Put Boxes Into the Warehouse I
  16. POJ - 1637 Sightseeing tour(混合图欧拉回路的求解--建图跑最大流)
  17. 2022 最新 JCR正式发布全球最新影响因子名单(前600名)
  18. iText生成PDF文件(解决了中文乱码)
  19. Matlab论文插图绘制模板第31期—堆叠折线图(stackedplot)
  20. 艾灸排病反应及解决方案(中),建议收藏!

热门文章

  1. 使用 LaTeX 的笔记
  2. IjkPlayer Option配置不当、导致视频卡顿或没有部分视频无声的坑;
  3. 基于SSM生产计划排程管理系统
  4. Win7用户文件夹转移
  5. vue3编写组件的几种方式
  6. 图10——判断顶点u和顶点v是否存在简单路径
  7. 超级详细配置SSM (Intellij idea + Maven + Spring + SpringMVC + MyBatis + c3p0 )
  8. 如何修改云服务器的远程连接密码?
  9. 关于8583报文详解
  10. 苹果手机里面彻底删除的照片如何找回来?