前一陣也有好幾個(gè)關(guān)于CRC的問題,樓上已經(jīng)逐個(gè)給出了解答。
在網(wǎng)上流行的CRC碼的計(jì)算方法如下:
1、 預(yù)置1個(gè)16位的寄存器為十六進(jìn)制FFFF(即全為1);稱此寄存器為CRC寄存器;
2、 把第一個(gè)8位二進(jìn)制數(shù)據(jù)(既通訊信息幀的第一個(gè)字節(jié))與16位的CRC寄存器的低 8位相異或,把結(jié)果放于CRC寄存器;
3、 把CRC寄存器的內(nèi)容右移一位(朝低位)用0填補(bǔ)最高位,并檢查移出位;
4、 如果移出位為0:重復(fù)第3步(再次右移一位); 如果移出位為1:CRC寄存器與多項(xiàng)式A001(1010 0000 0000 0001)進(jìn)行異或;
5、 重復(fù)步驟3和4,直到右移8次,這樣整個(gè)8位數(shù)據(jù)全部進(jìn)行了處理;
6、 重復(fù)步驟2到步驟5,進(jìn)行通訊信息幀下一個(gè)字節(jié)的處理;
7、 將該通訊信息幀所有字節(jié)按上述步驟計(jì)算完成后,得到的16位CRC寄存器;
8、 最后得到的CRC寄存器的高、低字節(jié)進(jìn)行交換即為:CRC碼。據(jù)此,給出一個(gè)H05的CRC-16演算過程,
H05的CRC碼:
HFFFF:1111 1111 1111 1111
H05 :0000 0000 0000 0101
X0R :1111 1111 1111 101
0--------------------------
N1--> 0111 1111 1111 110
1--------------------------
N2--> 0011 1111 1111 1110
HA001: 1010 0000 0000 0001
XOR : 1001 1111 1111 111
1--------------------------
N3--> 0100 1111 1111 1111
HA001: 1010 0000 0000 0001
XOR : 1110 1111 1111 111
0--------------------------
N4--> 0111 0111 1111 111
1--------------------------
N5--> 0011 1011 1111 1111
HA001: 1010 0000 0000 0001
XOR : 1001 1011 1111 111
0--------------------------
N6--> 0100 1101 1111 111
1--------------------------
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
大體就是這樣進(jìn)行8次移位,希望您沒有暈。
所以最好是通過軟件,讓程序來做這樣的麻煩事。
以三菱為例,你可以這樣做:
在D10~D15輸入進(jìn)行校驗(yàn)的數(shù),在D20就能得到結(jié)果。