CRC学习小结

       由于前些天一个大学好友向我提起了CRC通信校验的问题,他需要为客户提供这个功能,以确保通信数据的准确性。以前在project中也用过CRC算法做校验,当时为了赶进度,就直接拿来主义,用别人现成的代码调试通过就为我所用了。近来深入研究CRC原理,却发现原来水很深啊。文中大部分参考以下两个文献,特别是文献二说的比较详细。

[1] crc校念原理http://wenku.baidu.com/view/3952fb80d4d8d15abe234e55.html

[2]我学习CRC32CRC16CRC原理和算法的总结(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

3CRC码集选择的原则:若设码字长度为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)

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值