滑動相關法偽碼捕獲的FPGA實現(xiàn)
捕獲方法3 (滑動步進為TC/2)
本文引用地址:http://2s4d.com/article/86525.htm 加脈沖移位法:
此方法是采用一個異或門,如圖5所示,使碼NCO的輸出CLK與一個信號異或輸出,此信號平時一直為高(或低)電平,一旦收到低于門限值時,輸出一個低(或高)脈沖,與CLK異或后,相當于在原CLK時鐘上加了一個脈沖,通過圖示的電路后,偽碼產生器前進了半個相位,通過移位寄存器后,即可實現(xiàn)半個碼相位的移動(超前半個碼片)。
FPGA仿真結果如圖6所示。圖中CLK1為碼NCO的輸出,CLK2為它的二分頻作為偽碼產生器的時鐘,pn1為偽碼產生器輸出,k1為信號,平常輸出高電平,當門限檢測結果為低時,輸出一個低脈沖與CLK1異或輸出,結果為CLK3。從仿真圖中可以看出CLK3相對于CLK2在k1為低脈沖時,增加了一個脈沖。
下載到FPGA中,利用SIGNALTAP,測試結果如圖7所示。圖中CLK1為碼NCO輸出時鐘,CLK2為異或門的輸出,從圖中可以看出,在門限檢測為低時,CLK2比CLK1多增加了一個脈沖,測試結果與仿真結果一致。
實現(xiàn)結果
通過以上的分析,再結合擴頻通信的有關理論,可以知道要實現(xiàn)信號的捕獲,必須通過載波和偽碼相位的二維搜索。首先,對接收的信號進行數字下變頻,變?yōu)榱阒蓄lI、Q兩路信號,再與本地PN碼進行解擴運算。結果與門限值比較,如果小于門限則按照前面分析的方法順序移動半個碼片,直到包絡的平方大于門限轉入跟蹤狀態(tài)。捕獲電路如圖1所示。
采用上述方法,在實際中對某一擴頻信號進行捕獲
信號參數
中頻40MHz ;
調制樣式為DS-BPSK;
偽碼長度為1024;
數據率5Kb/s;
采樣時鐘60MHz;
各個模塊功能描述
數字下變頻:
載波NCO的輸出與輸入信號在乘法器中進行數字下變頻,功能是去除輸入信號載頻而保留了用于基帶相關的碼。
數字相關器:
累加清除器的作用是對經過數字正交下變頻后的I、Q兩路信號與本地再生偽碼相乘的結果進行積分累加。采用的是一個累加器對數字混頻后輸入信號與本地碼相乘的每一位結果進行累加。經過一定時間(本方案為12000次)的積分累積后,得到一個數據位的相關值。此相關值與預設門限比較,進行捕獲判決。如果小于門限,則認為捕獲失敗,清除累加結,滑動半個碼片后,重新進行累加積分。累加清洗器進行一個碼周期的數據累加,輸出一次相關累加值。最大的捕獲時間為0.4094秒(0.2mS*2047)。
載波NCO:
載波NCO是載波跟蹤環(huán)的重要組成部分,它的主要功能是產生本地復制載波信號。載波NCO模塊設置有頻率控制字輸入接口,模塊內部通過32位相位累加其對輸入控制字進行累加,獲得相位值的映射地址,通過查表獲得正余弦兩路信號。載波環(huán)路通過不斷調整載波NCO的頻率字來保持對接收信號載波頻率和相位的跟蹤。
碼NCO:
碼NCO是碼跟蹤環(huán)的核心。它的主要功能是為再生偽碼發(fā)生器提供精確的時鐘信號,保證實現(xiàn)對接收信號的碼捕獲和跟蹤。碼NCO設置有頻率控制字,頻率控制字負責碼率的調整和碼相位延時。
實現(xiàn)結果
A/D采用AD9288-100,是8位的轉換結果,最高工作頻率可達到100M,數字下變頻和捕獲電路在EP1C12Q240C8(Cyclong)中實現(xiàn),運算的中間測試結果如圖8所示,圖中pn2_clk為NCO輸出時鐘,x_pn為偽碼,c1_data和s1_data為載波NCO產生的用于下變頻的I、Q路載波信號。pn_e、pn_p、pn_l分別為移位寄存器輸出的超前、即時和滯后碼,它們相差半個碼片。
最后的捕獲結果如圖9所示。圖中ad_data為接收的數字中頻信號,last_data為最后捕獲的結果。
保存數據,在Matlab中的相關結果如圖10所示。
結束語
加脈沖法可以使本地碼相位超前半個碼片相位,實現(xiàn)非連續(xù)相位滑動相關,電路結構簡單,在FPGA中容易實現(xiàn),是一種簡單實用的方法,在實際系統(tǒng)設計中已被采用并獲得了理想的結果。
fpga相關文章:fpga是什么
鎖相環(huán)相關文章:鎖相環(huán)原理 網線測試儀相關文章:網線測試儀原理
評論