采用歐氏算法和頻譜結(jié)構(gòu)分析相結(jié)合的RS硬件解碼方
差錯(cuò)控制編碼技術(shù)對改善誤碼率、提高通信的可靠性具重要作用。RS碼既可以糾正隨機(jī)錯(cuò)誤,又可以糾正突發(fā)錯(cuò)誤,具有很強(qiáng)的糾錯(cuò)能力,在通信系統(tǒng)中應(yīng)用廣泛。由于RS碼的譯碼復(fù)雜度高,數(shù)字運(yùn)算量大,常見的硬件及軟件譯碼方案大多不能滿足高速率的傳輸需求,一般適用于10Mbps以下。本文提出的歐氏算法和頻譜結(jié)構(gòu)分析相結(jié)合的RS硬件解碼方案,適用于FPGA單片實(shí)現(xiàn),速率高、延遲小、通用性強(qiáng)、使用靈活。筆者在FPGA芯片上實(shí)現(xiàn)了GF(2 8)上符號速率為50Mbps的流式解碼方案,最大延時(shí)為640ns,參數(shù)可以根據(jù)需要靈活設(shè)置。
本文引用地址:http://cafeforensic.com/article/190170.htm1 RS碼的結(jié)構(gòu)
碼字長度為N=q-1(q=2i),生成多項(xiàng)式為,αi∈GF(q) 的RS碼有最小碼距δ=2t+1,能夠糾正t個(gè)隨機(jī)或突發(fā)錯(cuò)誤[1]。本文列舉的方案測試中采用的RS碼主要參數(shù)為N=255、m0=0、t=8,其中 GF(2 8)的生成多項(xiàng)式為g(x)=x8+x4+x3+x2+1。由于RS碼的編碼邏輯結(jié)構(gòu)比較簡單,文中僅給出仿真結(jié)果。
2 RS碼的譯碼算法
RS譯碼算法一般分為三步:伴隨式計(jì)算、關(guān)鍵方程獲得和錯(cuò)誤圖樣的求解。其中關(guān)鍵方程的獲得是RS譯碼中最困難、最為關(guān)鍵的一步。
在利用伴隨式求解關(guān)鍵方程時(shí),BM算法和Euclidean(歐氏)算法是兩種較好的選擇。BM算法涉及大量的變量存儲和復(fù)雜的邏輯控制,適用于軟件編程而不適合硬件實(shí)現(xiàn)。歐氏算法數(shù)據(jù)存儲量少、控制便捷,適合硬件實(shí)現(xiàn)。且采用歐氏算法確定關(guān)鍵方程所需時(shí)間與錯(cuò)誤個(gè)數(shù)成正比,因此從處理時(shí)間上考慮,歐氏算法也是較好的選擇。
在獲得關(guān)鍵方程后,采用時(shí)域處理方法,需要大量的運(yùn)算單元和控制電路,在硬件實(shí)現(xiàn)中是不可取的。而采用頻譜結(jié)構(gòu)分析方法,利用最短線性移位寄存器綜合及離散傅氏逆變換進(jìn)行處理,邏輯簡單、耗時(shí)少,適合硬件實(shí)現(xiàn)。雖然在傅氏變換時(shí)需要較多的邏輯單元,但對GF(2n)在n10的情況下,變換域譯碼器要比時(shí)域譯碼器簡單得多。因而本文提出歐氏算法和頻譜結(jié)構(gòu)分析相結(jié)合的方案,并在實(shí)踐中獲得了較好的效果。
Euclidean算法[3]步驟如下:
?。?)按所列方法進(jìn)行迭代
3 方案流程
方案流程框圖如圖1所示。
3.1 伴隨式S0,S1,…,S2t-1的計(jì)算
令r1,r2,…,rn為接收到的RS碼字,根據(jù)系統(tǒng)碼監(jiān)督矩陣的特性,可構(gòu)造如圖2所示伴隨式計(jì)算電路Si=(((r1αi+r2)αi+r3)αi…+rn,從而實(shí)際伴隨式序列的計(jì)算。
評論