LK 三种常用的CR16校验算法的C51程序的优化.docVIP

LK 三种常用的CR16校验算法的C51程序的优化.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
LK 三种常用的CR16校验算法的C51程序的优化

LEAD1N CRC校验又称为循环冗余校验,是数据通讯中常用的一种校验算法。它可以有效的判别出数据在传输过程中是否发生了错误,从而保障了传输的数据可靠性。 CRC校验有多种方式,如:CRC8、CRC16、CRC32等等。在实际使用中,我们经常使用CRC16校验。CRC16校验也有多种,如:1005多项式、1021多项式(CRC-ITU)等。在这里我们不讨论CRC算法是怎样产生的,而是重点落在几种算法的C51程序的优化上。 计算CRC校验时,最常用的计算方式有三种:查表、计算、查表+计算。一般来说,查表法最快,但是需要较大的空间存放表格;计算法最慢,但是代码最简洁、占用空间最小;而在既要求速度,空间又比较紧张时常用查表+计算法。 下面我们分别就这三种方法进行讨论和比较。这里以使用广泛的51单片机为例,分别用查表、计算、查表+计算三种方法计算 1021多项式(CRC-ITU)校验。原始程序都是在网上或杂志上经常能见到的,相信大家也比较熟悉了,甚至就是正在使用或已经使用过的程序。 编译平台采用 Keil C51 7.0,使用小内存模式,编译器默认的优化方式。 常用的查表法程序如下,这是网上经常能够看到的程序范例。因为篇幅关系,省略了大部分表格的内容。 code unsigned int Crc1021Table[256] = { 0x0000, 0x1021, 0x2042, 0x3063,... 0x1ef0 }; unsigned int crc0(unsigned char *pData, unsigned char nLength) { unsigned int CRC16 = 0; while(nLength0) { CRC16 = (CRC16 8 ) ^ Crc1021Table[((CRC168) ^ *pData) 0xFF]; nLength--; pData++; } return CRC16; } 编译后,函数crc0的代码为68字节,加上表格占用的512字节,一共使用了580个字节的代码空间。 下面是常见的计算法的程序: unsigned int crc2(unsigned char *ptr, unsigned char count) { unsigned int crc =0; unsigned char i; while(count-- 0) { crc = ( crc^(((unsigned int)*ptr)8)); for(i=0;i8;i++) { if(crc0x8000) crc= ((crc1)^0x1021); else crc = 1; } ptr++; } return crc; } 下面是常见的一种查表+计算的方法: unsigned int crc4(unsigned char *ptr, unsigned char len) { unsigned int crc; unsigned char da; code unsigned int crc_ta[16]={ /* CRC余式表 */ 0x0000,0x1021,0x2042,0x3063,0x4084,0x50a5,0x60c6,0x70e7, 0x8108,0x9129,0xa14a,0xb16b,0xc18c,0xd1ad,0xe1ce,0xf1ef, }; crc=0; while(len--0) { da = ((crc/256))/16; /* 暂存CRC的高四位 */ crc =4; /* CRC右移4位,相当于取CRC的低12位)*/ crc ^= crc_ta[da^(*ptr/16)]; /* CRC的高4位和本字节的前半字节相加后查表*/ /*计算CRC,然后加上上一次CRC的余数 */ da = ((crc/256))/16; /* 暂存CRC的高4位 */ crc =4; /* CRC右移4位, 相当于CRC的低12位) */ crc ^= crc_ta[da^(*ptr0x0f)];/* CRC的高4位和本字节的后半字节相加后查表*/ /*计算CRC,然后再加上上一次CRC的余数 */ ptr++; } return

文档评论(0)

xciqshic + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档