modbusCRC16的手工计算
来源:互联网 发布:哪里的mac pro最便宜 编辑:程序博客网 时间:2024/05/17 02:10
在网上流行的CRC码的计算方法如下:
1、 预置1个16位的寄存器为十六进制FFFF(即全为1);称此寄存器为CRC寄存器;
2、 把第一个8位二进制数据(既通讯信息帧的第一个字节)与16位的CRC寄存器的低 8位相异或,把结果放于CRC寄存器;
3、 把CRC寄存器的内容右移一位(朝低位)用0填补最高位,并检查移出位;
4、 如果移出位为0:重复第3步(再次右移一位); 如果移出位为1:CRC寄存器与多项式A001(1010 0000 0000 0001)进行异或;
5、 重复步骤3和4,直到右移8次,这样整个8位数据全部进行了处理;
6、 重复步骤2到步骤5,进行通讯信息帧下一个字节的处理;
7、 将该通讯信息帧所有字节按上述步骤计算完成后,得到的16位CRC寄存器;
8、 最后得到的CRC寄存器的高、低字节进行交换即为:CRC码。
据此,给出一个H05的CRC-16演算过程,
H05的CRC码:
HFFFF:1111 1111 1111 1111
H05 :0000 0000 0000 0101
X0R :1111 1111 1111 1010
--------------------------
N1--> 0111 1111 1111 1101
--------------------------
N2--> 0011 1111 1111 1110
HA001: 1010 0000 0000 0001
XOR : 1001 1111 1111 1111
--------------------------
N3--> 0100 1111 1111 1111
HA001: 1010 0000 0000 0001
XOR : 1110 1111 1111 1110
--------------------------
N4--> 0111 0111 1111 1111
--------------------------
N5--> 0011 1011 1111 1111
HA001: 1010 0000 0000 0001
XOR : 1001 1011 1111 1110
--------------------------
N6--> 0100 1101 1111 1111
--------------------------
N7--> 0010 0110 1111 1111
HA001: 1010 0000 0000 0001
XOR : 1000 0110 1111 1110
--------------------------
N8--> 0100 0011 0111 1111
1、 预置1个16位的寄存器为十六进制FFFF(即全为1);称此寄存器为CRC寄存器;
2、 把第一个8位二进制数据(既通讯信息帧的第一个字节)与16位的CRC寄存器的低 8位相异或,把结果放于CRC寄存器;
3、 把CRC寄存器的内容右移一位(朝低位)用0填补最高位,并检查移出位;
4、 如果移出位为0:重复第3步(再次右移一位); 如果移出位为1:CRC寄存器与多项式A001(1010 0000 0000 0001)进行异或;
5、 重复步骤3和4,直到右移8次,这样整个8位数据全部进行了处理;
6、 重复步骤2到步骤5,进行通讯信息帧下一个字节的处理;
7、 将该通讯信息帧所有字节按上述步骤计算完成后,得到的16位CRC寄存器;
8、 最后得到的CRC寄存器的高、低字节进行交换即为:CRC码。
据此,给出一个H05的CRC-16演算过程,
H05的CRC码:
HFFFF:1111 1111 1111 1111
H05 :0000 0000 0000 0101
X0R :1111 1111 1111 1010
--------------------------
N1--> 0111 1111 1111 1101
--------------------------
N2--> 0011 1111 1111 1110
HA001: 1010 0000 0000 0001
XOR : 1001 1111 1111 1111
--------------------------
N3--> 0100 1111 1111 1111
HA001: 1010 0000 0000 0001
XOR : 1110 1111 1111 1110
--------------------------
N4--> 0111 0111 1111 1111
--------------------------
N5--> 0011 1011 1111 1111
HA001: 1010 0000 0000 0001
XOR : 1001 1011 1111 1110
--------------------------
N6--> 0100 1101 1111 1111
--------------------------
N7--> 0010 0110 1111 1111
HA001: 1010 0000 0000 0001
XOR : 1000 0110 1111 1110
--------------------------
N8--> 0100 0011 0111 1111
|| H 4 3 7 F
多项式也就是校验串可以自订,这里还是使用0xA001
另外,CRC传输是低位在前,高位在后,也就是[数据..][CRC低位][CRC高位]
据此,有如下程序
#define CRC_PRESET 0xFFFF
#define CRC_POLYNOM 0xA001
unsigned int ModbusCRC16(unsigned char *data_value, unsigned char length)
{
unsigned int crc_value = CRC_PRESET;
unsigned char i;
while(length-- != 0)
{
crc_value ^= *data_value;
for(i = 0x01;i != 0;i <<= 1)
{
if((crc_value & 0x0001) != 0)
{
crc_value >>= 1;
crc_value ^= CRC_POLYNOM;
}
else crc_value >>= 1;
}
data_value++;
}
return(crc_value);
}
- modbusCRC16的手工计算
- 遗传算法的手工模拟计算示例
- KMP算法的next、next value数组的手工计算
- 258.369f的科学记数法手工计算和验证
- KMP算法中next数组、nextval数组的手工计算
- 手工计算浮点数到16进制科学记数法的辅助验证工具
- MATLAB BP神经网络中仿真结果与手工计算不符合的解决办法
- 手工计算KMP里的NEXT和NEXEVAL数组-嘎嘎好使
- 学会了手工计算开平方
- 灰鸽子的手工检测
- DataGrid的手工分页
- 手工测试的心得
- 一个手工同步的方案
- 看看手工做的电脑!
- 打造手工素描的自画像
- 一次手工杀毒的经历
- DataGrid数据项的手工添加
- 手工签署证书的方法
- Struts2中的OGNL表达式
- js实现页面跳转的几种方式
- 数据库字段类型对应C#字段类型
- css position了解
- javaIO流相关
- modbusCRC16的手工计算
- fast sqrt of type float
- (四)用户界面 View
- Native Method中操作Java对象的属性为数组时的处理
- 为找房方便,将sohu房产的rss 转成全文的!
- Android Intent Action 大全
- multiply of big Number
- 解决安卓应用程序未安装的三种方法
- 软件工程--需求分析方法