cvlsam
富士低壓,POD(觸摸屏),PLC專賣
級別: VIP會員
|
非常繁瑣~~要看公式 采用什么~~ 首先,與FFFF異或,然后保存,判斷最低位是否為1,如果是,那么再異或,如果不是,那么移位后再次執(zhí)行判斷,然后一個一個字節(jié)照著上述過程來一遍。 總之,是個雙循環(huán)的過程:外面的循環(huán)控制要校驗的字節(jié)數(shù),里面的循環(huán)用于控制每個字節(jié)的移位與異或。 1個字節(jié)的校驗要至少算8行,然后多少個字節(jié)×8大致上就是要做的工作。 另外一種方式就是查表法,這種方式要比前面的快很多,不過得到準(zhǔn)確的表示關(guān)鍵。 要看運算過程,請看富士電機的FRENIC-MINI或者FRENIC-VP變頻器的RS485通訊手冊的第3-21頁,小心看暈掉。 Regards |
---|---|
本帖最近評分記錄: |
sjm213
有小知識,無大學(xué)問。
級別: 論壇版主
|
前一陣也有好幾個關(guān)于CRC的問題,樓上已經(jīng)逐個給出了解答。 在網(wǎng)上流行的CRC碼的計算方法如下: 1、 預(yù)置1個16位的寄存器為十六進制FFFF(即全為1);稱此寄存器為CRC寄存器; 2、 把第一個8位二進制數(shù)據(jù)(既通訊信息幀的第一個字節(jié))與16位的CRC寄存器的低 8位相異或,把結(jié)果放于CRC寄存器; 3、 把CRC寄存器的內(nèi)容右移一位(朝低位)用0填補最高位,并檢查移出位; 4、 如果移出位為0:重復(fù)第3步(再次右移一位); 如果移出位為1:CRC寄存器與多項式A001(1010 0000 0000 0001)進行異或; 5、 重復(fù)步驟3和4,直到右移8次,這樣整個8位數(shù)據(jù)全部進行了處理; 6、 重復(fù)步驟2到步驟5,進行通訊信息幀下一個字節(jié)的處理; 7、 將該通訊信息幀所有字節(jié)按上述步驟計算完成后,得到的16位CRC寄存器; 8、 最后得到的CRC寄存器的高、低字節(jié)進行交換即為:CRC碼。 據(jù)此,給出一個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 大體就是這樣進行8次移位,希望您沒有暈。 所以最好是通過軟件,讓程序來做這樣的麻煩事。 以三菱為例,你可以這樣做: 在D10~D15輸入進行校驗的數(shù),在D20就能得到結(jié)果。 |
---|---|
本帖最近評分記錄: |
yxc111
級別: 略有小成
|
在問下2樓的老師 不是在移位后看B0的值嗎 若果是0就在向右移一位嗎? 如果是1 就和A001做XOR運算 怎么你B0是1 的時候也連續(xù)移位啊 |
---|---|
|
zichen8716
我行,我行,我行行行!!!
級別: 家園常客
|
我在論壇上上傳了一個CRC校驗的子程序 可以去下載 |
|
---|---|---|
|
sjm213
有小知識,無大學(xué)問。
級別: 論壇版主
|
1.程序上傳不上傳,我很糾結(jié); 2.判斷末位是0與否看的是移出位,即移位之前的那個末位,但做XOR的卻是移位后的數(shù),所以文字闡述可能造成誤解,但看程序就能推敲出來; 3.這個程序里16位不行,至于為什么您自己推敲!當(dāng)然您可以用別的辦法,避免使用32位! |
---|---|
|
beiye1234
級別: 略有小成
|
好像計算機網(wǎng)絡(luò)技術(shù)及應(yīng)用那本書有關(guān)于冗余校驗的算法,說的很詳細(xì),以前學(xué)過。 |
---|---|
|