在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁 > EDA/PCB > 設(shè)計應(yīng)用 > 基于FPGA的RS碼譯碼器的設(shè)計

            基于FPGA的RS碼譯碼器的設(shè)計

            作者: 時間:2016-10-18 來源:網(wǎng)絡(luò) 收藏

            摘要:介紹了符合CCSDS標(biāo)準(zhǔn)的RS(255,223)碼的硬件實現(xiàn)結(jié)構(gòu)。采用8位并行時域譯碼算法,主要包括了修正后的無逆BM迭代譯碼算法,錢搜索算法和Forney算法。采用了三級流水線結(jié)構(gòu)實現(xiàn),減小了的時延,提高了譯碼的速率,使用了VHDL語言完成譯碼器的設(shè)計與實現(xiàn)。測試表明,該譯碼器性能優(yōu)良,適用于高速通信。
            關(guān)鍵詞:;譯碼器;;

            在數(shù)字通信中,信號在有噪信道中傳輸,不可避免的會受到噪聲的干擾,引起誤碼。在已知信噪比的情況下要達到一定的誤碼率指標(biāo),在合理設(shè)計基帶信號,選擇調(diào)制解調(diào)方式,及時域均衡或頻域均衡的基礎(chǔ)上,使用差錯控制技術(shù)可以使誤碼率進一步的降低。屬于分組碼,是BCH碼的一個子類,是最大距離可分碼,它是由Reed和Solomon于1960年構(gòu)造出來。由于它具有很強的糾正隨機錯誤和突發(fā)錯誤的能力,以及極低的不可探測的差錯率,所以已經(jīng)廣泛應(yīng)用于深空通信、衛(wèi)星通信、存儲介質(zhì)、數(shù)字視頻廣播和擴頻數(shù)字通信中。
            在一些特定應(yīng)用域中,RS碼的設(shè)計和實現(xiàn)是比較困難的,RS碼是在上進行的代數(shù)運算,不同于常用的二進制系統(tǒng),現(xiàn)實相對復(fù)雜一些,其復(fù)雜度主要決定于的大小、碼字的長度,采用的編碼算法等。能夠快速和經(jīng)濟的將電路描述轉(zhuǎn)化為硬件實現(xiàn),而且對設(shè)計的修訂也比較方便。文中使用VHDL語言設(shè)計了RS(255,223)譯碼器,并經(jīng)過了PFGA芯片上的驗證。整個設(shè)計采用流水線結(jié)構(gòu),提高譯碼器的數(shù)據(jù)吞吐量,同時對電路結(jié)構(gòu)進行優(yōu)化,減少體積和時延,非常有利于微小衛(wèi)星中應(yīng)用。

            1 RS碼譯碼原理及實現(xiàn)
            1.1 RS(255,223)碼的參數(shù)
            RS(255,223)是在有限域GF(28)中計算得到的,其具體參數(shù)為:
            1)每個符號的bit數(shù):m=8;
            2)每個碼字包含的符號個數(shù):n=28-1=255;
            3)每個碼字包含的信息位的符號個數(shù):k=223;
            4)碼字中校驗位的符號個數(shù):2t=255-223=32;
            5)一個碼字所能糾錯的最大符號數(shù):t=16;
            6)GF(28)域的本原多項式:f(x)=x8+x7+x2+x+1;
            7)生成多項式:
            a.jpg
            1.2 RS碼譯碼原理
            RS譯碼算法有兩類:時域譯碼和頻域譯碼。在實際工程中,由于RS碼符號通常取自有限域GF(28)上,采用時域系統(tǒng)碼編碼方式,系統(tǒng)碼編碼方式可較容易縮短,滿足工程應(yīng)用的需求。如圖1所示,RS碼時域譯碼器主要分為四個模塊:伴隨式計算模塊、錯誤位置多項式計算模塊、錢搜索模塊、錯誤值計模塊。其中錯誤位置多項式計算采用修正后的無逆BM迭代算法,錯誤值計算采用Forney算法,還需要一個FIFO來
            緩存所接受的碼字,使與經(jīng)過譯碼后計算出的錯誤值同步。

            本文引用地址:http://www.biyoush.com/article/201610/308556.htm

            b.jpg


            RS碼時域譯碼的一般步驟為:
            1)根據(jù)接收的碼字計算伴隨式,如果計算出來的2t個伴隨式都等于0,那么表示接收的碼字沒有錯誤,不再進行下面的步驟,否則進行下面的步驟;
            2)利用計算好的伴隨式計算錯誤位置多項式和錯誤值多項式;
            3)計算錯誤位置和錯誤值;
            4)根據(jù)計算的錯誤位置和錯誤值可得到錯誤多項式E(x),將接收的碼字R(x)與E(x)相加,即可譯碼。
            1.2.1 域內(nèi)加法器和乘法器
            有限域GF(2m)中的元素都可以用二元域GF(2)中的元素的m重來表示,域中的任意元素都可以用次數(shù)小于m的多項式表示,加法和乘法運算是有限域GF(2m)中最簡單的運算。
            有限域上的加法比較簡單,只需要對m維并行數(shù)據(jù)進行異或即可。
            有限域上的乘法通常認為是時延較大,結(jié)構(gòu)復(fù)雜的運算操作。有限域的乘法器,即對于域內(nèi)的任意兩個元素,可以用m-1次多項式來表示,這樣兩個元素的乘積為2m-2次多項式,再把乘積對有限域的本原多項式求余,所得的結(jié)果即為兩個元素的乘積。文中的乘法器是采用八位并行與門和異或門來實現(xiàn)的,這種有限域乘法器的設(shè)計充分利用了特征為2的有限域元素的加減法運算即為異或運算的特征,大大簡化了設(shè)計,同時也使算法描述更簡單,且容易實現(xiàn)。
            1.2.2 計算伴隨式模塊
            BS(255,223)譯碼的第一步就是計算2t個伴隨式Si:
            c.jpg
            其實現(xiàn)結(jié)構(gòu)如圖2所示,在初始階段,寄存器被清零,輸入第一個碼字(接收的碼字高位)在與零相加后被送入寄存器,再乘以與第二個輸入的碼字相加,如此循環(huán),直到255個碼字全部進去寄存器經(jīng)過計算后,寄存器內(nèi)的值便是我們需要的伴隨式Si。

            d.jpg


            1.2.3 修正后的無逆BM迭代算法模塊
            求解關(guān)鍵方程是解碼器實現(xiàn)中最復(fù)雜和占用資源最多的模塊,其目的是為了求出錯誤位置多項式σ(x),根是錯誤位置的t次多項式:
            e.jpg
            關(guān)于求解關(guān)鍵方程的算法的已有很多,例如,Euclid算法,非二進制的BM算法等。文中采用修正后的無逆BM迭代算法實現(xiàn)。傳統(tǒng)的BM迭代譯碼算法,每次迭代都有一個求逆的運算,求逆是比較復(fù)雜且對硬件要求高的算法。無逆BM迭代算法避免了進行繁瑣耗時的求逆運算,但是迭代過程中只計算了錯誤位置多項式,最后還需要根據(jù)關(guān)鍵方程和得到的錯誤位置多項式來求的錯誤值多項式,這樣也增加了譯碼的時延。改進后的無逆BM迭代算法,在計算了錯誤位置多項式的同時也計算了錯誤值多項式,減少了時鐘的損耗,提高了譯碼的速率。具體實現(xiàn)流程如圖3所示。

            g.jpg


            圖3中λ(x)是計算錯誤位置多項式σ(x)的輔助多項式,α(x)是計算錯誤值多項式ω(x)的輔助多項式,k為迭代的次數(shù),δ為前一次迭代和這次迭代的修正項。
            1.2.4 錢搜索和Forney算法模塊
            錯誤位置多項式σ(x)和錯誤值多項式ω(x)確定后,錯誤位置可以通過求解錯誤位置多項式的根求得的,工程上用的最多的是錢搜索算法。譯碼器通過錢搜索算法檢查當(dāng)x=α0,α1,…,αn時,代入錯誤位置多項式σ(x)中,若σ(αi)=0,則表示αi為出錯的位置。
            利用Forney算法可以求得錯誤位置上的錯誤值,在已求得錯誤位置多項式和錯誤值多項式前提下:
            f.jpg
            h.jpg
            在實現(xiàn)過程中,錢搜索和Forney算法是在一個模塊中實現(xiàn)的。對αi進行錢搜索的同時,也把αi輸入Forney算法實現(xiàn)結(jié)構(gòu)中,采用流水線結(jié)構(gòu),這樣可以減少時鐘周期,經(jīng)過t+1個時鐘后即可以輸出第一個糾錯后的結(jié)果。結(jié)構(gòu)如圖4所示,σ0,σ1,…,σ16分別表示σ(x)的系數(shù),ω0,ω1,…,ω16表示ω(x)的系數(shù),x1,…,x16表示αi,…,α16i,對于求σ’(x)時,中間需要等一個時鐘,流水線結(jié)構(gòu)一定要注意同步,錯開一個時鐘都會產(chǎn)生錯誤。這部分有一個求逆的運算,本文中的求逆運算是用的查表法實現(xiàn)的,查表法的基本思想是GF(28)域上的元素的逆元先計算出來存儲到ROM中,將待求逆元作為讀取ROM的地址,讀出ROM的存儲值,該值便是所求結(jié)果,這種方法的計算速度非常快。使用這種結(jié)構(gòu)提高了譯碼的速率。

            j.jpg


            1.2.5 糾錯模塊
            當(dāng)確定可誤碼的位置及具體的誤碼值后,也就確定了錯誤多項式,將得到的錯誤多項式與接收多項式相加,即完成誤碼的糾正。
            i.jpg
            糾錯的硬件實現(xiàn)結(jié)構(gòu)如圖5所示,是一個二選一的多項選擇器,如果代入錯誤位置多項式后得到的值為0,那么需要將接收值與計算得到的錯誤值相加,如果不等以0,則直接輸出接收值。接收碼字需要經(jīng)過一個緩存器,這樣接收值才能與經(jīng)過譯碼算法輸出的錯誤值同步,達到糾錯的目的。

            2 實現(xiàn)及測試結(jié)果
            運用上文提出的硬件實現(xiàn)結(jié)構(gòu)框架,采用VHDL輸入,在FPGA上實現(xiàn)了RS(255,223)碼的連續(xù)譯碼,使用了XilinxISE10.1編譯,采用了xc4vsx55芯片綜合,Slice個數(shù)為5 209個,占用芯片總數(shù)的21%,最高速率達到了149.836 MHz。通過Modelsim6.2驗證,采用了三級流水線結(jié)構(gòu),譯碼所需時鐘周期為255+2*t+2+t+1,文中譯碼器的時鐘周期為306個時鐘。

            k.jpg


            仿真采用時鐘為100 M,將正確的編碼后的碼字人為的輸入16個連續(xù)錯誤和16個分散錯誤,啟動仿真,由波形中引出計算的所得的錯誤值和相應(yīng)的錯誤位置,16個錯誤均得到了糾正。由圖6可以看到輸入信號rs_data_in,人為的將27—42改為30、35、128、60、167、250、75、43、108、89、135、40、79、191、2、9。由圖7可以看到輸出信號rs_data_out,錯誤的數(shù)據(jù)已經(jīng)得到了糾正,驗證了譯碼器的正確性。

            3 結(jié)束語
            文中實現(xiàn)了RS碼時域譯碼器結(jié)構(gòu),根據(jù)該結(jié)構(gòu)完成了符號取自有限域GF(256)上的RS(255,223)碼譯碼器。這種RS碼譯碼器硬件實現(xiàn)結(jié)構(gòu)具有功能模塊化、結(jié)構(gòu)規(guī)則化的特點,采用了流水線結(jié)構(gòu),最大限度提高譯碼數(shù)據(jù)的吞吐量,提高了譯碼速度,適用于高速通信。并且在此基礎(chǔ)上只需進行少量更動就可以較容易實現(xiàn)其它碼型的譯碼器,該方案已應(yīng)用于多個軍事通信設(shè)備中。



            評論


            相關(guān)推薦

            技術(shù)專區(qū)

            關(guān)閉