資料介紹
CRC的全稱為Cyclic Redundancy Check,中文名稱為循環(huán)冗余校驗(yàn)。它是一類重要的線性分組碼,編碼和解碼方法簡單,檢錯和糾錯能力強(qiáng),在通信領(lǐng)域廣泛地用于實(shí)現(xiàn)差錯控制。實(shí)際上,除 數(shù)據(jù)通信外,CRC在其它很多領(lǐng)域也是大有用武之地的。例如我們讀軟盤上的文件,以及解壓一個ZIP文件時(shí),偶爾會碰到“Bad CRC”錯誤,由此它在數(shù)據(jù)存儲方面的應(yīng)用可略見一斑。
差錯控制理論是在代數(shù)理論基礎(chǔ)上建立起來的。這里我們著眼于介紹CRC的算法與實(shí)現(xiàn),對原理只能捎帶說明一下。若需要進(jìn)一步了解線性碼、分組碼、循環(huán)碼、糾錯編碼等方面的原理,可以閱讀有關(guān)資料。
利用CRC進(jìn)行檢錯的過程可簡單描述為:在發(fā)送端根據(jù)要傳送的k位二進(jìn)制碼序列,以一定的規(guī)則產(chǎn)生一個校驗(yàn)用的r位監(jiān)督 碼(CRC碼),附在原始信息后邊,構(gòu)成一個新的二進(jìn)制碼序列數(shù)共k+r位,然后發(fā)送出去。在接收端,根據(jù)信息碼和CRC碼之間所遵循的規(guī)則進(jìn)行檢驗(yàn),以 確定傳送中是否出錯。這個規(guī)則,在差錯控制理論中稱為“生成多項(xiàng)式”。
1 代數(shù)學(xué)的一般性算法
在代數(shù)編碼理論中,將一個碼組表示為一個多項(xiàng)式,碼組中各碼元當(dāng)作多項(xiàng)式的系數(shù)。例如 1100101 表示為
1·x6+1·x5+0·x4+0·x3+1·x2+0·x+1,即 x6+x5+x2+1。
設(shè)編碼前的原始信息多項(xiàng)式為P(x),P(x)的最高冪次加1等于k;生成多項(xiàng)式為G(x),G(x)的最高冪次等于r;CRC多項(xiàng)式為R(x);編碼后的帶CRC的信息多項(xiàng)式為T(x)。
發(fā)送方編碼方法:將P(x)乘以xr(即對應(yīng)的二進(jìn)制碼序列左移r位),再除以G(x),所得余式即為R(x)。用公式表示為
T(x)=xrP(x)+R(x)
接收方解碼方法:將T(x)除以G(x),如果余數(shù)為0,則說明傳輸中無錯誤發(fā)生,否則說明傳輸有誤。
舉例來說,設(shè)信息碼為1100,生成多項(xiàng)式為1011,即P(x)=x3+x2,G(x)=x3+x+1,計(jì)算CRC的過程為
xrP(x) x3(x3+x2) x6+x5 x
-------- = ---------- = -------- = (x3+x2+x) + --------
G(x) x3+x+1 x3+x+1 x3+x+1
即 R(x)=x。注意到G(x)最高冪次r=3,得出CRC為010。
如果用豎式除法,計(jì)算過程為
1110
-------
1011 /1100000 (1100左移3位)
1011
----
1110
1011
-----
1010
1011
-----
0010
0000
----
010
因此,T(x)=(x6+x5)+(x)=x6+x5+x, 即 1100000+010=1100010
如果傳輸無誤,
T(x) x6+x5+x
------ = --------- = x3+x2+x,
G(x) x3+x+1
無余式?;仡^看一下上面的豎式除法,如果被除數(shù)是1100010,顯然在商第三個1時(shí),就能除盡。
上述推算過程,有助于我們理解CRC的概念。但直接編程來實(shí)現(xiàn)上面的算法,不僅繁瑣,效率也不高。實(shí)際上在工程中不會直接這樣去計(jì)算和驗(yàn)證CRC。
下表中列出了一些見于標(biāo)準(zhǔn)的CRC資料:
名稱生成多項(xiàng)式簡記式*應(yīng)用舉例
CRC-4x4+x+1ITU G.704
CRC-12x12+x11+x3+x+1
CRC-16x16+x12+x2+11005IBM SDLC
CRC-ITU**x16+x12+x5+11021ISO HDLC, ITU X.25, V.34/V.41/V.42, PPP-FCS
CRC-32x32+x26+x23+.。.+x2+x+104C11DB7ZIP, RAR, IEEE 802 LAN/FDDI, IEEE 1394, PPP-FCS
CRC-32cx32+x28+x27+.。.+x8+x6+11EDC6F41SCTP
* 生成多項(xiàng)式的最高冪次項(xiàng)系數(shù)是固定的1,故在簡記式中,將最高的1統(tǒng)一去掉了,
如04C11DB7實(shí)際上是104C11DB7。
** 前稱CRC-CCITT。ITU的前身是CCITT。
2.CRC算法的實(shí)現(xiàn)
---------------
要用程序?qū)崿F(xiàn)CRC算法,考慮對第2節(jié)的長除法做一下變換,依然是M = 11100110,G = 1011,
其系數(shù)r為3。
11001100
------------------------
1011 )11100110000
1011.。..。..
----。..。..。
1010.。..。.
1011.。..。.
----。..。..
1110.。.
1011.。.
------。..
1010.。
1011.。
-------
100 《---校驗(yàn)碼
?
差錯控制理論是在代數(shù)理論基礎(chǔ)上建立起來的。這里我們著眼于介紹CRC的算法與實(shí)現(xiàn),對原理只能捎帶說明一下。若需要進(jìn)一步了解線性碼、分組碼、循環(huán)碼、糾錯編碼等方面的原理,可以閱讀有關(guān)資料。
利用CRC進(jìn)行檢錯的過程可簡單描述為:在發(fā)送端根據(jù)要傳送的k位二進(jìn)制碼序列,以一定的規(guī)則產(chǎn)生一個校驗(yàn)用的r位監(jiān)督 碼(CRC碼),附在原始信息后邊,構(gòu)成一個新的二進(jìn)制碼序列數(shù)共k+r位,然后發(fā)送出去。在接收端,根據(jù)信息碼和CRC碼之間所遵循的規(guī)則進(jìn)行檢驗(yàn),以 確定傳送中是否出錯。這個規(guī)則,在差錯控制理論中稱為“生成多項(xiàng)式”。
1 代數(shù)學(xué)的一般性算法
在代數(shù)編碼理論中,將一個碼組表示為一個多項(xiàng)式,碼組中各碼元當(dāng)作多項(xiàng)式的系數(shù)。例如 1100101 表示為
1·x6+1·x5+0·x4+0·x3+1·x2+0·x+1,即 x6+x5+x2+1。
設(shè)編碼前的原始信息多項(xiàng)式為P(x),P(x)的最高冪次加1等于k;生成多項(xiàng)式為G(x),G(x)的最高冪次等于r;CRC多項(xiàng)式為R(x);編碼后的帶CRC的信息多項(xiàng)式為T(x)。
發(fā)送方編碼方法:將P(x)乘以xr(即對應(yīng)的二進(jìn)制碼序列左移r位),再除以G(x),所得余式即為R(x)。用公式表示為
T(x)=xrP(x)+R(x)
接收方解碼方法:將T(x)除以G(x),如果余數(shù)為0,則說明傳輸中無錯誤發(fā)生,否則說明傳輸有誤。
舉例來說,設(shè)信息碼為1100,生成多項(xiàng)式為1011,即P(x)=x3+x2,G(x)=x3+x+1,計(jì)算CRC的過程為
xrP(x) x3(x3+x2) x6+x5 x
-------- = ---------- = -------- = (x3+x2+x) + --------
G(x) x3+x+1 x3+x+1 x3+x+1
即 R(x)=x。注意到G(x)最高冪次r=3,得出CRC為010。
如果用豎式除法,計(jì)算過程為
1110
-------
1011 /1100000 (1100左移3位)
1011
----
1110
1011
-----
1010
1011
-----
0010
0000
----
010
因此,T(x)=(x6+x5)+(x)=x6+x5+x, 即 1100000+010=1100010
如果傳輸無誤,
T(x) x6+x5+x
------ = --------- = x3+x2+x,
G(x) x3+x+1
無余式?;仡^看一下上面的豎式除法,如果被除數(shù)是1100010,顯然在商第三個1時(shí),就能除盡。
上述推算過程,有助于我們理解CRC的概念。但直接編程來實(shí)現(xiàn)上面的算法,不僅繁瑣,效率也不高。實(shí)際上在工程中不會直接這樣去計(jì)算和驗(yàn)證CRC。
下表中列出了一些見于標(biāo)準(zhǔn)的CRC資料:
名稱生成多項(xiàng)式簡記式*應(yīng)用舉例
CRC-4x4+x+1ITU G.704
CRC-12x12+x11+x3+x+1
CRC-16x16+x12+x2+11005IBM SDLC
CRC-ITU**x16+x12+x5+11021ISO HDLC, ITU X.25, V.34/V.41/V.42, PPP-FCS
CRC-32x32+x26+x23+.。.+x2+x+104C11DB7ZIP, RAR, IEEE 802 LAN/FDDI, IEEE 1394, PPP-FCS
CRC-32cx32+x28+x27+.。.+x8+x6+11EDC6F41SCTP
* 生成多項(xiàng)式的最高冪次項(xiàng)系數(shù)是固定的1,故在簡記式中,將最高的1統(tǒng)一去掉了,
如04C11DB7實(shí)際上是104C11DB7。
** 前稱CRC-CCITT。ITU的前身是CCITT。
2.CRC算法的實(shí)現(xiàn)
---------------
要用程序?qū)崿F(xiàn)CRC算法,考慮對第2節(jié)的長除法做一下變換,依然是M = 11100110,G = 1011,
其系數(shù)r為3。
11001100
------------------------
1011 )11100110000
1011.。..。..
----。..。..。
1010.。..。.
1011.。..。.
----。..。..
1110.。.
1011.。.
------。..
1010.。
1011.。
-------
100 《---校驗(yàn)碼
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- HT8 UL60730安全庫-恒定存儲器CRC-16 CCITT測試
- ModeBusRTU調(diào)試工具CRC16版下載 0次下載
- CRC校驗(yàn)碼并行計(jì)算的FPGA實(shí)現(xiàn) 30次下載
- 16位CRC驗(yàn)證碼生成VI工具下載 54次下載
- 如何使用FPGA實(shí)現(xiàn)32位并行數(shù)據(jù)的CRC16編碼器 14次下載
- 8位和16位CRC計(jì)算器軟件免費(fèi)下載 9次下載
- CRC16校驗(yàn)碼計(jì)算器v1.2版應(yīng)用程序免費(fèi)下載 0次下載
- CRC算法原理和CRC編碼的實(shí)現(xiàn)方式與使用Verilog對CRC編碼進(jìn)行描述 36次下載
- CRC計(jì)算工具CRC校驗(yàn)碼計(jì)算器應(yīng)用程序免費(fèi)下載 132次下載
- CRC基本原理及其兩個重要性質(zhì)的介紹及FPGA實(shí)現(xiàn) 23次下載
- CRC計(jì)算器 4次下載
- CRC-16校驗(yàn)碼生成 8次下載
- 計(jì)算CRC-16循環(huán)冗余校驗(yàn)碼的程序開發(fā) 0次下載
- CRC校驗(yàn)源碼分析 117次下載
- crc16計(jì)算器 (計(jì)算工具)
- 如何在IAR Embedded Workbench中配置生成對應(yīng)代碼區(qū)域的CRC校驗(yàn)碼 1260次閱讀
- N32G45x硬件CRC計(jì)算Modbus的CRC16 883次閱讀
- 西門子博途1200PLC中CRC校驗(yàn)生成步驟 5410次閱讀
- 西門子200SMART PLC CRC校驗(yàn)程序的編寫 3004次閱讀
- 了解和使用Maxim 1-Wire和iButton產(chǎn)品的循環(huán)冗余校驗(yàn) 1030次閱讀
- CRC校驗(yàn)verilog代碼如何生成? 1776次閱讀
- 從原理到代碼理解CRC循環(huán)冗余校驗(yàn) 1779次閱讀
- 細(xì)說下與傳統(tǒng)CAN相比CANFD CRC段帶來的變化 2124次閱讀
- 細(xì)說CANFD CRC段帶來的變化 1480次閱讀
- CRC校驗(yàn)的計(jì)算過程 1.1w次閱讀
- 基于TMS320C5000處理器實(shí)現(xiàn)CRC計(jì)算的設(shè)計(jì)實(shí)例 1739次閱讀
- 為什么微控制器接收的 CRC 編碼與計(jì)算的 CRC 不一致? 2257次閱讀
- CRC校驗(yàn)和STM32中CRC計(jì)算單元相關(guān)內(nèi)容 6260次閱讀
- CRC的計(jì)算過程 漢明距離如何計(jì)算呢 9813次閱讀
- STM32之軟件CRC和硬件CRC速度測試 6309次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費(fèi)
- 2開關(guān)電源基礎(chǔ)知識
- 5.73 MB | 6次下載 | 免費(fèi)
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計(jì)
- 0.60 MB | 3次下載 | 免費(fèi)
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
- 0.61 MB | 2次下載 | 免費(fèi)
- 6基于FPGA的C8051F單片機(jī)開發(fā)板設(shè)計(jì)
- 0.70 MB | 2次下載 | 免費(fèi)
- 751單片機(jī)窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費(fèi)
- 8基于51單片機(jī)的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21548次下載 | 免費(fèi)
- 5電氣工程師手冊免費(fèi)下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動電路設(shè)計(jì)》 溫德爾著
- 0.00 MB | 6653次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191185次下載 | 免費(fèi)
- 7十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183278次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評論
查看更多