基于WCDMA速率適配算法的FPGA設計
速率適配的FPGA實現(xiàn)
通過對編碼復接的方案研究發(fā)現(xiàn),直接根據(jù)協(xié)議流程對數(shù)據(jù)流各個步驟(一共大約11個步驟)直接進行處理將會大大增加系統(tǒng)復雜度,這樣每個步驟之間都需對數(shù)據(jù)進行緩存,而移動環(huán)境下系統(tǒng)支持的最高速率可達384Kbps,對于TTI=20ms的業(yè)務,平均每步需要的緩存為7.68K,所需要的總存儲量是巨大的。而且這中間,數(shù)據(jù)流頻繁的寫入讀出所導致的處理時延也是難以忍受的。因此,如果將某些步驟合并起來,就能減少不必要的數(shù)據(jù)存取工作,從而節(jié)省存儲量,縮短處理延時。
上行鏈路的速率匹配按10ms數(shù)據(jù)幀為單位進行,而下行鏈路則是以TTI為單位針對一個無線幀的數(shù)據(jù)比特進行的。雖然算法上一致,但是考慮到上下行各自的步驟合并情況,在實際處理上還是有很大區(qū)別的。下面以下行144Kb/s速率適配為例介紹一下其FPGA的實現(xiàn)方法。
144Kb/s速率適配過程大致分為兩個模塊:鑿圖樣產生模塊和保留比特搬移轉換模塊。在實現(xiàn)過程中,用到的存儲資源是兩個RAM―一個用來存“鑿”圖樣、另一個用來存原來的數(shù)據(jù),兩個DCFIFO(雙時鐘FIFO)用來存比特收集后的兩幀數(shù)據(jù)。
鑿孔圖樣產生模塊
由于144Kb/s業(yè)務信道編碼用的是Turbo編碼,鑿孔時只針對兩個分量編碼器輸出的校驗比特,因此需先進行比特分離再分塊進行鑿孔操作(系統(tǒng)比特塊自動保留不進行鑿孔操作)。我們采用了一種鑿孔圖樣控制方式,所有待速率適配比特都對應一個P比特,P=1表示鑿去,P=0表示保留,以此種方式產生鑿孔圖樣來控制保留比特的搬移。具體實現(xiàn)框圖如圖4所示。主要硬件結構包括一個加法器、一個減法器、一個數(shù)值比較器、一個計數(shù)器和一個選通控制模塊及參數(shù)初始化模塊。
本文引用地址:http://m.butianyuan.cn/article/151705.htm
圖4 鑿孔圖樣產生
該結構工作過程如下:首先,比特分離和參數(shù)初始化模塊主要完成模塊計數(shù)和eini、eminus、eplus等參數(shù)的初始化設置。
在減法器端,當前誤差值e減去eminus,該數(shù)值同時送給數(shù)值比較器和選通控制模塊。減法器的輸出結果和0值作比較,如果結果小于零則記P比特為1;如果結果大于零則記P比特為0,同時將減法器的輸出結構作為當前加法器的A端輸入值。P比特則在選通控制模塊產生的讀寫使能、地址信號線的驅動下寫入Punc_ram。另外用一個計數(shù)器來對比特數(shù)進行記錄,以控制整個流程的結束時刻。系統(tǒng)時鐘為8倍碼片時鐘,計數(shù)器和Punc_ram都采用同步控制,加法器、減法器及比較器都不采用同步時鐘延時。
保留比特搬移轉換模塊
鑿圖樣產生以后,接下來的操作就是保留比特的搬移和轉換,并進行第一次交織和無線幀分段。按照3GPP協(xié)議,對于TTI=20ms的144Kb/s業(yè)務,其交織模式是0,1>,亦即順序輸出。
圖5 保留比特搬移轉換
實現(xiàn)的流程圖如圖5。假定TURBO編碼后待的比特流存在out_ram中,這里進行的操作關鍵是鑿孔圖樣的讀出和out_ram的讀出應該是同步一致進行(在同一個時鐘上升沿開始),用Punc_ram的輸出來作為積攢比特的使能信號。用移位寄存器組和計數(shù)器實現(xiàn)比特積攢,每等到滿16bit時,就進行串并轉換,同時產生一個fifo寫使能脈沖,把一個字的內容寫入fifo;等到滿一幀(復接前的數(shù)據(jù)幀)的時候,轉向對下一個fifo進行寫操作。到一個數(shù)據(jù)幀4205bit結束時,積攢比特不滿16的補零表示,串并轉換為一個字寫入fifo。
資源使用和時延分析
按照上面的實現(xiàn)方式,主要占用的是存儲資源,現(xiàn)代FPGA中的ESB(嵌入式系統(tǒng)塊)可以很容易地實現(xiàn)各種類型的存儲模塊,包括雙端口RAM、ROM、FIFO及CAM塊。下面主要進行的是時延分析。
按照上面的流程可以大致估算一個比特從“鑿孔”圖樣產生到比特搬移完成所用的時間。所選工作時鐘速率為8倍碼片速率3.84MHz,一個時鐘周期約為32.4ns。鑿孔圖樣模塊中的加法器、減法器、選通控制大概需要3個時鐘周期,9516個鑿孔圖樣的產生需要大致925ns;保留比特搬移模塊主要是數(shù)據(jù)比特的直接搬移,對于最后一個比特而言,假定它是保留比特,從搬移開始到最終寫入FIFO,經過了大致9516+16=9532個時鐘周期,耗時大約308ns。對整個流程用MAXPUSII仿真,總共耗時1.336ms,考慮到中間的緩沖控制和使能控制延遲,仿真結果和計算值大致吻合。對于TTI=20ms的業(yè)務,完全滿足處理要求。
結語
WCDMA系統(tǒng)的電路型數(shù)據(jù)業(yè)務(64K)和分組型數(shù)據(jù)業(yè)務(144K、384K)可以實現(xiàn)對多媒體業(yè)務的承載,但由于基帶數(shù)據(jù)處理量大、比特搬移操作明顯,編碼復接中的核心算法之一速率適配算法我們采用了FPGA實現(xiàn),并且適當合并了前后步驟,大大縮短了處理時間,使系統(tǒng)達到了很高的吞吐量和處理速度,完全滿足3GPP協(xié)議規(guī)范的要求。在實際實施中被證明是可行的。此外,文中提出的模塊合并、產生鑿孔圖樣進行比特積攢搬移的思想同樣可以適合未來更復雜的編碼復接方案。
WCDMA文章專題:WCDMA是什么意思
評論