卷積碼+QPSK的中頻調制解調系統的FPGA
在無線數據傳輸中,由于信道中的噪聲干擾,在接收端會引入一定的誤碼率(Bit Error Rate,BER)。高質量的數據業務要求較低的BER。為了達到較低的BER,經常采用信道編碼技術。卷積編碼和Viterbi譯碼是廣泛使用的信道編碼技術,具有一定的克服突發錯誤的能力,可以降低信道的誤碼率,帶來很高的編碼增益。信道編碼的引入在提供糾錯能力的同時,還擴展了信號的帶寬。為了保證頻帶的利用率,本文采用QPSK調制方式,使數據調制在中頻載波上,實現數據的可靠傳輸。
本文所述的中頻調制解調系統具有以下特點:
(1)所有算法(編碼、調制、解調和譯碼)都是在Xilinx公司的FPGA芯片中實現的,結構簡單,體積小,功耗低。
?。?)具有很好的實時性。對于1Mbit/s以上的數據速率,譯碼延遲不超過0.1ms。
?。?)模塊化的設計使得系統具有一定的兼容性,只需要修改少量程序,即可實現各種卷積編碼和不同的調制中頻。
1 系統總結構及硬件設計
圖1是中頻調制解調系統的工作流程圖。在發端,數據通過A/D轉換器采樣后進入FPGA,在其中完成(2,1,7)卷積編碼和QPSK調制后通過D/A轉換器輸出。在收端,接收到的信號通過A/D轉換器采樣后進入FPGA,在其中完成QPSK解調和Viterbi譯碼后通過D/A轉換器輸出。
2 系統的FPGA實現
系統主要分為編譯碼和調制解調兩大部分,下面分別敘述這兩部分的原理及設計。
2.1 卷積編碼與Viterbi譯碼的FPGA實現
2.1.1 (2,1,7)卷積編碼
典型的(n,m,k)卷積碼編碼器是指輸入位數為m、輸出位數為n、約束長度為k的卷積碼編碼器,其編碼速率為m/n。一個(2,1,7)的卷積編碼器如圖2所示,可用六個移位寄存器實現。
2.1.2 Viterbi譯碼
由Viterbi算法的基本原理可得典型的Viterbi譯碼器,如圖3所示。
分支路徑度量產生單元BMG(Branch Metric Generate)用于產生接收序列與狀態轉移分支上編碼輸出數據之間的距離。令長度為n的接收信號為R=(r1,…rn),與之相應的發送信號為C=(c1,…cn)。因為具有最小歐式距離的路徑也就是具有最大相關的路徑,所以定義分支路徑上的度量為:由于此分支路徑度量沒有平方運算,所以可將狀態轉移分支上的編碼輸出數據存儲在查找表內,這樣只需進行加減和查表運算,大大減小了實現的復雜程度。以上計算公式中數值為連續值,而本設計采用的是軟判決譯碼器,故只需對輸入的接收信號進行均勻量化即可(量化比特數為q)。
相關推薦
-
-
xiaohua | 2002-09-24
-
-
sandman555 | 2005-02-05
-
-
sandman555 | 2005-02-05
-
-
-
-
sandman555 | 2005-02-05
-
-
-
-
herbertwj | 2004-08-15
評論