新聞中心

EEPW首頁(yè) > 模擬技術(shù) > 設(shè)計(jì)應(yīng)用 > 循環(huán)冗余校驗(yàn)碼---CRC碼

循環(huán)冗余校驗(yàn)碼---CRC碼

作者: 時(shí)間:2011-07-03 來(lái)源:網(wǎng)絡(luò) 收藏
二進(jìn)制信息位串沿一條信號(hào)線逐位在部件之間或計(jì)算機(jī)之間傳送稱(chēng)為串行傳送。CRC(Cyclic Redundancy check)碼可以發(fā)現(xiàn)并糾正信息串行讀寫(xiě)、存儲(chǔ)或傳送過(guò)程中出現(xiàn)的一位、多位錯(cuò)誤,因此在磁介質(zhì)存儲(chǔ)器讀寫(xiě)和計(jì)算機(jī)之間通信方面得到廣泛應(yīng)用。

  CRC碼一般是指k位信息碼之后拼接r位校驗(yàn)碼。應(yīng)用CRC碼的關(guān)鍵,是如何從k位信息位簡(jiǎn)便地得到r位校驗(yàn)位(編碼)的值,以及如何判斷k+r位的碼字是否正確。下面僅就CRC碼應(yīng)用中的問(wèn)題做簡(jiǎn)單介紹(有關(guān)的理論問(wèn)題請(qǐng)參閱有關(guān)書(shū)籍)。

① CRC碼的編碼方法

  先介紹CRC碼編碼用到的模2除運(yùn)算。

  模2運(yùn)算是指以按位模2相加為基礎(chǔ)的四則運(yùn)算,運(yùn)算時(shí)不考慮位間進(jìn)位和借位。

  模2加減:即按位加,可用異或邏輯實(shí)現(xiàn)。模2加與模2減的結(jié)果相同,即
    0±0=0 0±1=1 1±0=1 1±1=0。兩個(gè)相同的數(shù)據(jù)的模2和為0。

  模2乘:按模2加求部分積之和。
  例:    1010
        101
     
       1010
       0000
      1010
     
       100010

  模2除:按模2減(加)求部分余數(shù)。每求一位商應(yīng)使部分余數(shù)減少一位。
  上商的原則是:當(dāng)部分余數(shù)的最高位為1時(shí),該位商取1;為0時(shí),該位商取0。當(dāng)部分的余數(shù)的位數(shù)小于除數(shù)的位數(shù)時(shí),該余數(shù)即為最后余數(shù)。
  例如,


    

  下面介紹CRC碼的編碼方法。
  首先,可將待編碼的k位有效信息位表達(dá)為多項(xiàng)式M(x)形式:
    M(x)= Ck-1xk-1 + Ck-2x k-2+…+Cixi+…+C1x1+C0
  式中Ci為0或1,x為偽變量,并用xi指明各位間的排列位置。

  若將信息位組左移r位,則可表示為多項(xiàng)式M(x) * xr ,這樣就可以空出初值為0的r個(gè)校驗(yàn)位,即
      

  CRC碼的碼字,是用k個(gè)數(shù)據(jù)位拼接上r個(gè)校驗(yàn)位得到的。校驗(yàn)位的值,就是通過(guò)對(duì)多項(xiàng)式M(x) * xr除以生成多項(xiàng)式G(x)(特定的一個(gè)多項(xiàng)式)所得到的余式。為了得到r位余數(shù)(校驗(yàn)位),G(x)必須是r+1位的,即為r次的多項(xiàng)式。
設(shè)所得余數(shù)表達(dá)式為R(x),商為 Q(x),就有:
     M(x).xr / G(x) = Q(x) + R(x) / G(x)

  將r次余式直接拼接在源數(shù)據(jù)多項(xiàng)式的右側(cè),可寫(xiě)成M(x).xr + R(x),并可推導(dǎo)出:
     M(x).xr + R(x) = [ Q(x)* G(x) + R(x) ] + R(x)
             = [ Q(x)* G(x) ] + [ R(x)+R(x) ]
             = Q(X)* G(x)

  這證明所得到的CRC碼字是一個(gè)可被G(x)(多項(xiàng)式)數(shù)碼除盡的數(shù)碼(多項(xiàng)式)。
  例:對(duì)四位源信息 1100,來(lái)求三個(gè)校驗(yàn)位的值,可選擇生成多項(xiàng)式為 1011,則有:
     M(x) = x3 + x2 = 1100    (k = 4)
     M(x)*x3 = x6 + x5 = 1100000 (左移, r = 3位)
     G(x) = x3+ x + 1 =1011    (r+1 = 4位)

  

  所得到的碼字(系統(tǒng)線性(7,4)分組碼)為:
     M(x).x3 + R(x) = 1100000 + 010 = 1100010



評(píng)論


相關(guān)推薦

技術(shù)專(zhuān)區(qū)

關(guān)閉