循环冗余校验码CRC

循环冗余校验(CRC)是一种广泛用于数据通信和存储的错误检测技术。它通过使用生成多项式进行模2除法,添加校验码以增强数据的可靠性。CRC的基本过程包括信息码左移、模2除法和校验码拼接。例如,给定CRC生成多项式11001,信息码10110011,经过计算得到的CRC校验码为0100,最终编码为101100110100。这种方法有效地提高了数据的查错能力。

定义

循环冗余校验码(Cyclic Redundancy Chec,CRC) 是通过多项式&模2除法给信息码加上几位校验码,以增加整个编码系统的码距和查错纠错能力,广泛应用于移动通信和磁盘数据存储中。

原理

CRC 的基本原理是:在 K 位信息码后再添加 R 位的校验码,整个编码长度为 N 位,因此,这种编码又称(N,K)码。对于一个给定的(N,K)码,可以证明存在一个最高次幂为 N-K=R 的多项式 G(x)。根据 G(x)可以生成 R 位的校验码,而 G(x)叫作这个 CRC 码的生成多项式。
校验码的具体生成过程为:假设发送信息用信息多项式 C(x)表示,将 C(x)左移 R 位,则可表示成 C(x)×2R 这样 C(x)的右边就会空出 R 位,这就是校验码的位置。通过 C(x)×2R除以生成多项式 G(x)得到的余数就是校验码。
CRC 码的生成步骤为:
(1)将 x 的最高幂次为 R 的生成多项式 G(x)转换成对应的 R+1 位二进制数。
(2)将信息码左移 R 位,相当于对应的信息多项式 C(x)×2R 。
(3)用生成多项式(二进制数)对信息码做模 2 除,得到 R 位的余数。
(4)将余数拼到信息码左移后空出的位置,得到完整的 CRC 码。

示例

CRC生成多项式为 G( X) = X4 + X3 + 1,求出二进制序列 10110011的 CRC校验码。
1、将多项式转为R+1二进制。
G( X) = X4 + X3 + 1中,x的二次方和一次方缺失,所以为0,其他为1,结果为11001
2、将信息码左移R位
上面得出多项式的位数为5,那么R=4,将信息码10110011左移4位后为:
101100110000
3、用多项式二进制11001对信息码101100110000做模2除
余数为:100,不足R位,前面补0,所以余数为0100
4、将余数拼接到信息码左移后空出位置
结果为101100110100

模2除

模2除关键点:
1、除数和被除数的对应位置做异或运算得到余数。
2、未除尽时,如果余数不足R+1位,则商为0,直到余数足够R+1位;否则,商为1
以上述例子为例:

             11010100


11001 / 101100110000
             11001


               11110
               11001


                   11111
                   11001


                       11000
                       11001


                             0100

### 循环冗余校验码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); } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值