差错控制:循环冗余校验码(CRC)的使用方法

目录

循环冗余校验码(CRC)的功能:

基本思想/使用方法:

例题:

1.确定K,R这两个位数,以及确定对应的二进制码(除数):

2.移位相除,对移位的信息码,用生成的多项式进行模2除法,产生余数:

3.接收方的检错:

CRC校验纠错的局限性


循环冗余校验码(CRC)的功能:

循环冗余检验码主要用于在物理层接收信号转换为比特流后,向数据链路层传输。数据链路层接收到传来的比特后,对将这些比特组装成帧。在对帧进行差错控制时使用的一种方法。(数据链路层负责将物理层接收的比特流组成帧,并进行差错控制。接收方的数据链路层会对收到的帧进行校验,例如通过循环冗余校验码(CRC)、奇偶校验码等方法检查帧在传输过程中是否出现差错如果发现差错,一般会采用反馈重发的方法通知发送方重新发送该帧

基本思想/使用方法:

循环冗余校验码(以下简称为CRC检验码) 是一种基于多项式运算的差错检测方法。在 CRC 中,数据被看作是一个多项式的系数。

CRC检验码为信息位加检验位组成。其中,也就是需要传输的原始数据内容。

例如,要传输一个文件,文件中的字节序列等实际数据内容就是信息位。假设我们要发送的数据是二进制序列 “101011”,这个序列就是信息位。

校验位是根据信息位和选定的生成多项式计算出来的。发送端使用信息位对应的多项式除以生成多项式,得到的余数作

### 循环冗余校验码CRC的工作原理 循环冗余校验(Cyclic Redundancy Check, CRC)是一种基于除法和取模运算的数据验证方法,主要用于检测数据传输中的错误。其工作流程如下: 1. **生成多项式的选择**:发送方和接收方共同约定一个生成多项式 \(G(x)\),该多项式的系数决定了后续计算的具体方式。 2. **信息序列扩展**:假设原始消息长度为\(k\)比特,则在其后面附加\(r\)个零构成新的二进制串作为被除数,其中\(r\)等于生成多项式的最高次幂减去1。对于给定的例子,如果采用的生成多项式是\(G(x)=x^3+x^2+1\)[^1],那么就需要在原信息后补上三个0变成`1111000`或`1100000`的形式用于下一步处理。 3. **执行模2除法**:以上述得到的新字符串作为分子,以选定的生成多项式对应的二进制形式作为分母进行无借位的二进制除法操作直到商不再含有前导'1'。所得余数即为要加入到实际传送的消息后面的检验字段——也就是所谓的“冗余位”。 4. **构建最终报文并发送**:将上述获得的冗余位连接至初始的信息之后形成完整的CRC编码后的帧结构准备发出;当对方接收到这个组合体时会重复相同的步骤来重新计算一次CRC并与随同传来的那个做对比从而得知是否有误发生过。 5. **错误检测机制**:一旦发现两者不匹配就意味着途中出现了差错现象需要采取相应措施比如请求重发等动作确保通信质量可靠稳定[^2]。 ```cpp // C++实现简单的CRC-CCITT (XModem) 计算函数 unsigned short crc_ccitt(unsigned char *data_p, unsigned short length){ int i; unsigned short data; unsigned short crc = 0xFFFF; while(length--){ for(data=(crc>>8)^*data_p++,i=0;i<8;i++) crc = ((crc<<1)^((data&0x80)?0x1021:0)) & 0xffff, data <<= 1; } return(crc); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值