没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
标准 CRC 生成多项式如下表:
名称生成多项式简记式* 标准引用
CRC-4 x4+x+1 3 ITU G.704
CRC-8 x8+x5+x4+1 0x31
CRC-8 x8+x2+x1+1 0x07
CRC-8 x8+x6+x4+x3+x2+x1 0x5E
CRC-12 x12+x11+x3+x+1 80F
CRC-16 x16+x15+x2+1 8005 IBM SDLC
CRC16-CCITT x16+x12+x5+1 1021 ISO HDLC, ITU X.25,
V.34/V.41/V.42, PPP-FCS
CRC-32 x32+x26+x23+...+x2+x+1 04C11DB7 ZIP, RAR, IEEE 802
LAN/FDDI, IEEE 1394, PPP-FCS
CRC-32c x32+x28+x27+...+x8+x6+1 1EDC6F41 SCTP
生成多项式的最高位固定的 1,故在简记式中忽略最高位 1 了,如 0x1021 实际是
0x11021。
I、基本算法(人工笔算):
以 CRC16-CCITT 为例进行说明,CRC 校验码为 16 位,生成多项式 17 位。假如数据
流为 4 字节:BYTE[3]、BYTE[2]、BYTE[1]、BYTE[0];
数据流左移 16 位,相当于扩大 256×256 倍,再除以生成多项式 0x11021,做不借位的
除法运算(相当于按位异或),所得的余数就是 CRC 校验码。
发送时的数据流为 6 字节:
BYTE[3]、BYTE[2]、BYTE[1]、BYTE[0]、CRC[1]、CRC[0];
II、计算机算法 1(比特型算法):
1)将扩大后的数据流(6 字节)高 16 位(BYTE[3]、BYTE[2])放入一个长度为 16 的
寄存器;
2)如果寄存器的首位为 1,将寄存器左移 1 位(寄存器的最低位从下一个字节获得),再与
生成多项式的简记式异或;
否则仅将寄存器左移 1 位(寄存器的最低位从下一个字节获得);
3)重复第 2 步,直到数据流(6 字节)全部移入寄存器;
4)寄存器中的值则为 CRC 校验码 CRC[1]、CRC[0]。
III、计算机算法 2(字节型算法):256^n 表示 256 的 n 次方
把按字节排列的数据流表示成数学多项式,设数据流为 BYTE[n]BYTE[n-1]BYTE[n
-2]、、、BYTE[1]BYTE[0],表示成数学表达式为 BYTE[n]×256^n+BYTE[n-
1]×256^(n-1)
+...+BYTE[1]*256+BYTE[0],在这里+表示为异或运算。设生成多项式为
G17(17bit),CRC 码为 CRC16。
则,CRC16=(BYTE[n]×256^n+BYTE[n-1]×256^(n-1)+...
+BYTE[1]×256+BYTE[0])×256^2/G17,即数据流左移 16 位,再除以生成多项式
G17。
先变换 BYTE[n-1]、BYTE[n-1]扩大后的形式,
CRC16
=BYTE[n]×256^n×256^2/G17+BYTE[n-1]×256^(n-1)×256^2/G17+...
+BYTE[1]×256×256^2/G17+BYTE[0]×256^2/G17
=(Z[n]+Y[n]/G17)×256^n+BYTE[n-1]×256^(n-1)×256^2/G17+...
+BYTE[1]×256×256^2/G17+BYTE[0]×256^2/G17
=Z[n]×256^n+{Y[n]×256/G17+BYTE[n-1]×256^2/G17}×256^(n-
1)+...+BYTE[1]×256×256^2/G17+BYTE[0]×256^2/G17
=Z[n]×256^n+{(YH8[n]×256+YHL[n])×256/G17+BYTE[n-1]×256^2/G17}×2
56^(n-1)+...+BYTE[1]×256×256^2/G17+BYTE[0]×256^2/G17
=Z[n]×256^n+{YHL[n]×256/G17+(YH8[n]+BYTE[n-1])×256^2/G17}×256^(
n-1)+...+BYTE[1]×256×256^2/G17+BYTE[0]×256^2/G17
这样就推导出,BYTE[n-1]字节的 CRC 校验码为{YHL[n]×256/G17+(YH8[n]
+BYTE[n-1])×256^2/G17},即上一字节 CRC 校验码 Y[n]的高 8 位(YH8[n])与本
字节 BYTE[n-1]异或,
该结果单独计算 CRC 校验码(即单字节的 16 位 CRC 校验码,对单字节可建立表格,
预先生成对应的 16 位 CRC 校验码),所得的 CRC 校验码与上一字节 CRC 校验码 Y[n]的
低 8 位(YL8[n])
乘以 256(即左移 8 位)异或。然后依次逐个字节求出 CRC,直到 BYTE[0]。
字节型算法的一般描述为:本字节的 CRC 码,等于上一字节 CRC 码的低 8 位左移 8 位,
与上一字节 CRC 右移 8 位同本字节异或后所得的 CRC 码异或。
字节型算法如下:
1)CRC 寄存器组初始化为全"0"(0x0000)。(注意:CRC 寄存器组初始化全为 1 时,
最后 CRC 应取反。)
2)CRC 寄存器组向左移 8 位,并保存到 CRC 寄存器组。
3)原 CRC 寄存器组高 8 位(右移 8 位)与数据字节进行异或运算,得出一个指向值表
的索引。
4)索引所指的表值与 CRC 寄存器组做异或运算。
5)数据指针加 1,如果数据没有全部处理完,则重复步骤 2)。
6)得出 CRC。
unsigned short GetCrc_16(unsigned char * pData, int nLength)
//函数功能:计算数据流* pData 的 16 位 CRC 校验码,数据流长度为 nLength
{
unsigned short cRc_16 = 0x0000; // 初始化
while(nLength>0)
{
cRc_16 = (cRc_16 << 8) ^ cRctable_16[((cRc_16>>8) ^ *pData) & 0xJ];
//cRctable_16 表由函数 mK_cRctable 生成
nLength--;
pData++;
}
return cRc_16;
}
void mK_cRctable(unsigned short gEnpoly)
//函数功能:生成 0-255 对应的 16CRC 校验码,其实就是计算机算法 1(比特型算法)
//gEnpoly 为生成多项式
//注意,低位先传送时,生成多项式应反转(低位与高位互换)。如 CRC16-CCITT 为
0x1021,反转后为 0x8408
{
unsigned short cRc_16=0;
unsigned short i,j,k;
for(i=0,k=0;i<256;i++,k++)
{
cRc_16 = i<<8;
for(j=8;j>0;j--)
{
if(cRc_16&0x8000) //反转时 cRc_16&0x0001
cRc_16=(cRc_16<<=1)^gEnpoly; //反转时
cRc_16=(cRc_16>>=1)^gEnpoly
else
cRc_16<<=1; //反转时 cRc_16>>=1
}
cRctable_16[k] = cRc_16;
}
}
这几天研究了一下 CRC 算法,碰到了一些问题,研究了一下,小有心得。
CRC 算法是在通讯领域广泛采用的校验算法。原理我就不说了,这里说一
下简单的程序实现。以下均采用 CRC 多项式为 0x1021 即:
g(x) = x16+x12+x5+x0;CRC 的基本原理就不说了,那个搜一下就有了。
最基本的算法应该是按位计算了,这个方法可以适用于所有长度的数据校
验,最为灵活,但由于是按位计算,其效率并不是最优,只适用于对速度不敏
感的场合。基本的算法如下:
unsigned short do_crc_16(unsigned char *message, unsigned int
len)
{
int i, j;
剩余10页未读,继续阅读
bingbing38726
- 粉丝: 30
- 资源: 32
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 基于opencv的dnn模块实现Yolo-Fastest的目标检测python源码+模型+说明(高分项目).zip
- 使用Python调用微信本地ocr服务.zip
- 【精品推荐】人工智能在医疗中的应用.pptx
- 【精品推荐】电子医疗仪器人机接口-(1).ppt
- 【精品推荐】电子医疗仪器人机接口.ppt
- ubuntu镜像ubuntu镜像01
- 基于paddle搭建神经网络实现5种水果识别分类python源码+数据集(高分毕设).zip
- 【精品推荐】电子商务网店类型介绍.ppt
- 基于paddle搭建神经网络实现水果识别分类python源码+数据集(高分项目).zip
- 三菱plc编程口通信学习笔记.doc
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
- 1
- 2
前往页