由于前些天一个大学好友向我提起了CRC通信校验的问题,他需要为客户提供这个功能,以确保通信数据的准确性。以前在project中也用过CRC算法做校验,当时为了赶进度,就直接拿来主义,用别人现成的代码调试通过就为我所用了。近来深入研究CRC原理,却发现原来水很深啊。文中大部分参考以下两个文献,特别是文献二说的比较详细。
[1] crc校念原理http://wenku.baidu.com/view/3952fb80d4d8d15abe234e55.html
[2]我学习CRC32、CRC16、CRC原理和算法的总结(与WINRAR结果一致).pdf http://wenku.baidu.com/view/fb791c0203d8ce2f006623f5.html
1 校验原理
1、循环校验码(CRC码):是数据通信领域中最常用的一种差错校验码,其特征是信息字段和校验字段的长度可以任意选定。
2、生成CRC码的基本原理:任意一个由二进制位串组成的代码都可以和一个系数仅为‘0’和‘1’取值的多项式一一对应。例如:代码1010111对应的多项式为x6+x4+x2+x+1,而多项式为x5+x3+x2+x+1对应的代码101111。
3、CRC码集选择的原则:若设码字长度为N,信息字段为K位,校验字段为R位(N=K+R),则对于CRC码集中的任一码字,存在且仅存在一个R次多项式g(x),使得
V(x)=A(x)g(x)=xRm(x)+r(x);
其中: m(x)为K次信息多项式, r(x)为R-1次校验多项式,
g(x)称为生成多项式:
g(x)=g0+g1x+g2x2+...+g(R-1)x(R-1)+gRxR
发送方通过指定的g(x)