目录
CRC校验原理
在二进制编码传输协议中,为了数据传输的正确性经常会采用循环冗余校验码CRC(cyclic redundancy check)来测试一个数据包是否有错误发生,循环冗余校验码的理论虽然比较复杂,但是实现原理却较为简单。在k位信息码(多项式表示为m(x))后再拼接r位的校验码,整个编码长度为n位,因此这种编码又叫(n,k)码。对于一个给定的(n,k)码,可以证明存在一个最高次幂为n -k= r的多项式g(x)。根据g(x)可以生成k位信息的校验码,而g(x)叫做这个CRC码的生成多项式。
校验码的具体生成过程为:假设发送信息用数据多项式m(x)表示,将m(x)左移n -k位,则可表示成m(x)× 2n-k。这样m(x)的右边就会空出n -k位,即校验码的位置。m(x)× 2n-k通过模2除法(异或运算,后面详解)除以生成多项式g(x)得到的商Q(x)和余数r(x),其中余数r(x)就是校验码。即