电脑桌面
添加小米粒文库到电脑桌面
安装后可以在桌面快捷访问

三种常用的CRC16校验算法的C51程序的优化

三种常用的CRC16校验算法的C51程序的优化_第1页
1/13
三种常用的CRC16校验算法的C51程序的优化_第2页
2/13
三种常用的CRC16校验算法的C51程序的优化_第3页
3/13
三种常用的CRC16校验算法的C51程序的优化 2009-10-10 09:34:17| 分类: 技术知识 | 标签: |字号大 中 小 订阅 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(nLength>0) { CRC16 = (CRC16 << 8 ) ^ Crc1021Table[((CRC16>>8) ^ *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;i<8;i++) { if(crc&0x8000) crc= ((crc<<1)^0x1021); else crc <<= 1; } ptr++; } return crc; } 下面是常见的一种查表+计算的方法: unsigned int crc4(unsigned char *ptr, unsigned char len) { unsigned int crc; unsigned char da; code u...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。
3、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。

碎片内容

三种常用的CRC16校验算法的C51程序的优化

确认删除?
VIP
微信客服
  • 扫码咨询
会员Q群
  • 会员专属群点击这里加入QQ群
客服邮箱
回到顶部