久久ER99热精品一区二区-久久精品99国产精品日本-久久精品免费一区二区三区-久久综合九色综合欧美狠狠

新聞中心

EEPW首頁 > 測試測量 > 設計應用 > CRC校驗的LabVIEW實現

CRC校驗的LabVIEW實現

作者: 時間:2017-01-09 來源:網絡 收藏
簡介:支持Host及FPGA的CRC實現
內容:
循環冗余校驗碼(CRC)的手算過程:
原始報文為1010
生成多項式G(X)=X3+X+1: 生成多項式G(X)=X3+X+1轉換成對應的二進制除數為1011。
用生成多項式對應的二進制數對左移3位后的原始報文進行模2除(高位對齊),相當于按位異或
1010000
1011
------------------
0001000
0001011
------------------
0000011
得到的余位011,所以最終編碼為:1010 011

編寫程序模擬計算CRC的過程,可以得到CRC校驗的結果。
同時還有另一種模擬CRC電路工作方式的CRC實現方法:
其電路的原理圖如下:(32bit數據+8bit CRC,生成多項式為:X8+ X7+ X4+ X3+ X1+ 1)


這種方式下,從第一個比特數據直接開始異或計算,最后一個數據輸入后,寄存器中的各個數據即為CRC校驗位
LabVIEW下的CRC計算可以模擬上述電路圖的工作過程。
  1. 對各寄存器中的數據向高位移位,并取得最高位數據,最低為在移位中補0。
  2. 1中取得的最高位數據與輸入數據異或,異或的結果決定后續是否進行3操作。
  3. 如果2中異或結果為真,使用多項式對寄存器中數據異或。

具體LabVIEW代碼見下圖:

該CRC代碼的主要特性有:
1.支持FPGA端的定時循環(FPGA定時循環內,CRC16的速率約460M)
2.支持實現任意位、任意生成多項式、任意寄存器初始值。
3.直接從第一個數據開始計算CRC,并在最末數據輸入后,直接得到CRC結果,使用方便。
4.支持CRC計算與校驗



關鍵詞: CRC校驗LabVIE

評論


技術專區

關閉