本實用新型涉及GPS導(dǎo)航系統(tǒng),特別是涉及一種基于FPGA捕獲微弱GPS導(dǎo)航信號的電路。
背景技術(shù):
近年來,GPS導(dǎo)航系統(tǒng)在世界范圍內(nèi)得到了廣泛的應(yīng)用,同時受到了國內(nèi)外科研人員的關(guān)注,其中信號捕獲為該領(lǐng)域的技術(shù)難點和核心部分。衛(wèi)星信號捕獲本質(zhì)上是將接收信號與本地復(fù)現(xiàn)的偽碼和載波進(jìn)行二維搜索計算相關(guān)值,從而找到初始碼相位和載頻。其中順序法捕獲法通過滑動來計算出相關(guān)峰值,此方法實現(xiàn)簡單,但是非常耗費時間,不滿足實時性的要求?,F(xiàn)今捕獲方法大多采用并行法,但該方法耗費更多硬件資源,實現(xiàn)較困難。在利用有限硬件資源的前提下開發(fā)出實時性好、精度高并且針對微弱信號具有較高捕獲靈敏度的接收機(jī)滿足社會生活各方面需求仍然是一項艱巨任務(wù)。
技術(shù)實現(xiàn)要素:
鑒于現(xiàn)有技術(shù)狀況,本實用新型提供一種基于FPGA捕獲微弱GPS導(dǎo)航信號的電路。本設(shè)計的FPGA芯片采用Xilinx公司kintex_7系列的xc7k325t,封裝形式為FFG676。本設(shè)計能夠成功復(fù)現(xiàn)出本地C/A碼和頻率可控的正余弦載波信號,通過基于累加點數(shù)存儲器的分段累加操作實現(xiàn)平均采樣,再通過幾個分時復(fù)用的數(shù)據(jù)暫存存儲器和FFT、IFFT模塊以及相應(yīng)的控制信號在節(jié)約硬件資源的情況下快速計算出相關(guān)結(jié)果,并通過8ms相關(guān)結(jié)果的非相干累加實現(xiàn)微弱信號的精確、成功捕獲。
本實用新型采取的技術(shù)方案是:一種基于FPGA捕獲微弱GPS導(dǎo)航信號的電路,其特征在于:包括時鐘發(fā)生模塊、時鐘分頻模塊、中頻數(shù)據(jù)接收控制模塊、中頻數(shù)據(jù)接收模塊、C/A碼發(fā)生模塊、載波生成與剝離模塊、C/A碼平均采樣模塊、C/A碼平均采樣數(shù)據(jù)存儲模塊、同相正交平均采樣模塊、同相正交平均采樣數(shù)據(jù)存儲模塊、同相正交FFT模塊、C/A碼FFT模塊、復(fù)數(shù)乘法模塊、復(fù)數(shù)乘法結(jié)果存儲模塊、IFFT模塊、相關(guān)值存儲模塊以及峰值檢測模塊;其中時鐘發(fā)生模塊分別與時鐘分頻模塊、中頻數(shù)據(jù)接收控制模塊、載波生成與剝離模塊相連接,中頻數(shù)據(jù)接收控制模塊與中頻數(shù)據(jù)接收模塊相連接,中頻數(shù)據(jù)接收模塊與載波生成與剝離模塊相連接,載波生成與剝離模塊與同相正交平均采樣模塊相連接,同相正交平均采樣模塊與同相正交平均采樣數(shù)據(jù)存儲模塊相連接,同相正交平均采樣數(shù)據(jù)存儲模塊與同相正交FFT模塊相連接,時鐘分頻模塊與C/A碼發(fā)生模塊相連接,C/A碼發(fā)生模塊與C/A碼平均采樣模塊相連接,C/A碼平均采樣模塊與C/A碼平均采樣數(shù)據(jù)存儲模塊相連接,C/A碼平均采樣數(shù)據(jù)存儲模塊與C/A碼FFT模塊相連接,同相正交FFT模塊和C/A碼FFT模塊同時與復(fù)數(shù)乘法模塊相連接,復(fù)數(shù)乘法模塊與復(fù)數(shù)乘法結(jié)果存儲模塊相連接,復(fù)數(shù)乘法結(jié)果存儲模塊與IFFT模塊相連接,IFFT模塊與相關(guān)值存儲模塊相連接,相關(guān)值存儲模塊與峰值檢測模塊相連接。
本實用新型的特點是:在中頻數(shù)據(jù)接收使能控制方面采取外部信號與內(nèi)部計數(shù)信號共同控制的方法,保證每次接收的中頻數(shù)據(jù)長度剛好為1ms。在平均采樣過程中采用塊存儲器儲存累加點數(shù)的方法代替時鐘沿累加,既節(jié)省了FPGA內(nèi)寶貴的時鐘資源,又克服了時鐘沿累加法易產(chǎn)生時序問題的缺陷。在數(shù)據(jù)處理方面,F(xiàn)FT、IFFT模塊和各存儲器采用了分時復(fù)用的原則,節(jié)省了硬件資源,并且在輸出和儲存1ms處理結(jié)果的時候可以同時進(jìn)行下1ms輸入數(shù)據(jù)的計算和暫存,大大縮減了捕獲的時間。通過連續(xù)8ms信號相關(guān)結(jié)果的非相干累加檢測峰值,提升了信號捕獲靈敏度。實驗測試表明,本設(shè)計的平均捕獲時間為110ms,精度為半個碼片,在節(jié)省硬件資源的前提下,能夠?qū)崿F(xiàn)微弱信號的快速、精確捕獲。
附圖說明
圖1為本實用新型的基本連接框圖;
圖2為本實用新型捕獲微弱GPS導(dǎo)航信號的基本流程圖;
圖3為圖1中的時鐘發(fā)生模塊引腳圖;
圖4為圖1中的時鐘分頻模塊引腳圖;
圖5為圖1中的中頻數(shù)據(jù)接收控制模塊引腳圖;
圖6為圖1中的中頻數(shù)據(jù)接收模塊引腳圖;
圖7為圖1中的C/A碼發(fā)生模塊引腳圖;
圖8為圖1中的載波發(fā)生與剝離模塊引腳圖;
圖9為圖1中的C/A碼平均采樣模塊引腳圖;
圖10為圖1中的同相正交平均采樣模塊引腳圖;
圖11為圖1中的C/A碼平均采樣數(shù)據(jù)存儲模塊引腳圖;
圖12為圖1中的同相正交平均采樣數(shù)據(jù)存儲模塊引腳圖;
圖13為圖1中的C/A碼FFT模塊引腳圖;
圖14為圖1中的同相正交FFT模塊引腳圖;
圖15為圖1中的復(fù)數(shù)乘法模塊引腳圖;
圖16為圖1中的復(fù)數(shù)乘法結(jié)果存儲模塊引腳圖;
圖17為圖1中的IFFT模塊引腳圖;
圖18為圖1中的相關(guān)值存儲模塊引腳圖;
圖19為圖1中的峰值檢測模塊引腳圖。
具體實施方式
以下結(jié)合附圖對本實用新型作進(jìn)一步說明:
如圖1所示,本設(shè)計包括時鐘發(fā)生模塊、時鐘分頻模塊、中頻數(shù)據(jù)接收控制模塊、中頻數(shù)據(jù)接收模塊、C/A碼發(fā)生模塊、載波生成與剝離模塊、C/A碼平均采樣模塊、C/A碼平均采樣數(shù)據(jù)存儲模塊、同相正交平均采樣模塊、同相正交平均采樣數(shù)據(jù)存儲模塊、同相正交FFT(傅里葉變換)模塊、C/A碼FFT模塊、復(fù)數(shù)乘法模塊、復(fù)數(shù)乘法結(jié)果存儲模塊、IFFT(傅里葉反變換)模塊、相關(guān)值存儲模塊以及峰值檢測模塊;其中時鐘發(fā)生模塊分別與時鐘分頻模塊、中頻數(shù)據(jù)接收控制模塊、載波生成與剝離模塊相連接,中頻數(shù)據(jù)接收控制模塊與中頻數(shù)據(jù)接收模塊相連接,中頻數(shù)據(jù)接收模塊與載波生成與剝離模塊相連接,載波生成與剝離模塊與同相正交平均采樣模塊相連接,同相正交平均采樣模塊與同相正交平均采樣數(shù)據(jù)存儲模塊相連接,同相正交平均采樣數(shù)據(jù)存儲模塊與同相正交FFT模塊相連接,時鐘分頻模塊與C/A碼發(fā)生模塊相連接,C/A碼發(fā)生模塊與C/A碼平均采樣模塊相連接,C/A碼平均采樣模塊與C/A碼平均采樣數(shù)據(jù)存儲模塊相連接,C/A碼平均采樣數(shù)據(jù)存儲模塊與C/A碼FFT模塊相連接,同相正交FFT模塊和C/A碼FFT模塊同時與復(fù)數(shù)乘法模塊相連接,復(fù)數(shù)乘法模塊與復(fù)數(shù)乘法結(jié)果存儲模塊相連接,復(fù)數(shù)乘法結(jié)果存儲模塊與IFFT模塊相連接,IFFT模塊與相關(guān)值存儲模塊相連接,相關(guān)值存儲模塊與峰值檢測模塊相連接。
如圖2所示,時鐘發(fā)生模塊產(chǎn)生62MHZ和10.23MHZ的時鐘,其中62MHZ時鐘控制中頻數(shù)據(jù)采樣以及除C/A碼發(fā)生模塊外所有模塊的驅(qū)動,10.23MHZ時鐘通過時鐘分頻模塊十分頻后產(chǎn)生1.023MHZ的時鐘控制C/A碼發(fā)生模塊;中頻數(shù)據(jù)接收控制模塊通過外部控制信號和內(nèi)部計數(shù)控制信號的邏輯與運算精確控制1ms中頻數(shù)據(jù)讀入,C/A碼發(fā)生模塊在1.023MHZ控制下產(chǎn)生C/A碼;載波生成與剝離模塊通過每一個時鐘沿將累加步長寫入到32位的累加寄存器中,并根據(jù)累加寄存器高四位的數(shù)值對一個周期的載波相位進(jìn)行十六等分,再根據(jù)相位值到幅度值的映射以產(chǎn)生頻率可控的正余弦載波,并將其分別與中頻數(shù)據(jù)相乘產(chǎn)生同相和正交數(shù)據(jù);平均采樣模塊中內(nèi)置一個累加點數(shù)存儲器用于存儲每一個平均采樣數(shù)據(jù)需要的累加點數(shù);平均采樣模塊根據(jù)累加點數(shù)存儲器中的值將1ms的C/A碼和同相正交數(shù)據(jù)由62MHZ時鐘采樣后分段累加成2048個采樣點存入平均采樣數(shù)據(jù)存儲模塊,存滿后輸出一個高脈沖連接到FFT模塊的起始信號端口,并依據(jù)輸入索引讀取平均采樣數(shù)據(jù)存儲模塊中的數(shù)據(jù),當(dāng)FFT模塊的輸出數(shù)據(jù)有效時,啟動復(fù)數(shù)乘法模塊,將C/A碼變換結(jié)果取共軛后,與同相正交數(shù)據(jù)變換結(jié)果進(jìn)行復(fù)數(shù)相乘并存入復(fù)數(shù)乘法結(jié)果存儲模塊,存滿后啟動IFFT模塊,并依次讀取復(fù)數(shù)乘法結(jié)果存儲模塊中的數(shù)據(jù),IFFT模塊的輸出數(shù)據(jù)即為相關(guān)值;將連續(xù)8ms相關(guān)結(jié)果進(jìn)行非相干累加后,存入相關(guān)值存儲模塊,最后啟動相關(guān)峰值檢測模塊計算出主次峰值,并與設(shè)定門限進(jìn)行對比判定是否捕獲成功。
如圖3所示,時鐘發(fā)生模塊通過IP核實現(xiàn),輸出信號CLK_OUT1和CLK_OUT2分別為62MHZ和10.23MHZ的輸出時鐘。時鐘發(fā)生模塊的LOCKED為鎖定信號,當(dāng)輸出時鐘穩(wěn)定時,該端口持續(xù)輸出高電平。
如圖4所示,時鐘分頻模塊用于對10.23MHZ的時鐘進(jìn)行十分頻產(chǎn)生穩(wěn)定的1.023MHZ的時鐘,用于驅(qū)動C/A碼。時鐘分頻模塊的clk_in端口為輸入時鐘,連接10.23MHZ時鐘,模塊內(nèi)置計數(shù)器,當(dāng)計數(shù)到5時,計數(shù)器清零,并使輸出時鐘翻轉(zhuǎn)。時鐘分頻模塊的re_clk_div端口為復(fù)位信號,此信號為高電平時輸出時鐘復(fù)位到0,并且計數(shù)器清零。時鐘分頻模塊的clk_div_en端口為分頻使能信號,連接時鐘發(fā)生模塊的LOCKED端口,當(dāng)時鐘發(fā)生模塊產(chǎn)生穩(wěn)定時鐘時,時鐘分頻模塊開始有效,時鐘分頻模塊的clk_out輸出端口為穩(wěn)定的1.023MHZ時鐘。
如圖5所示,中頻數(shù)據(jù)接收控制模塊通過外部控制信號和內(nèi)部計數(shù)控制信號的與運算控制中頻數(shù)據(jù)的接收,clk62M輸入端口連接62MHZ的時鐘。rec_en端口為外部控制信號,當(dāng)C/A碼開始有效時置為高電平。內(nèi)部計數(shù)控制信號為寄存器型,初始值為1。模塊內(nèi)置初值為0的計數(shù)器,當(dāng)中頻數(shù)據(jù)接收控制模塊的rec_en端口為高電平時,此時兩個控制信號的與運算即IF_en信號為高電平,此時開始接收中頻數(shù)據(jù),并且計數(shù)器在輸入時鐘控制下遞增,當(dāng)計數(shù)器計滿62000個數(shù)即1ms中頻數(shù)據(jù)時,內(nèi)部計數(shù)控制信號置0,此時IF_en信號為低電平,停止數(shù)據(jù)接收。中頻數(shù)據(jù)接收控制模塊的rst_IF_rec端口為復(fù)位信號,當(dāng)此信號為高電平時,內(nèi)部計數(shù)控制信號恢復(fù)到低電平,且計數(shù)器清零。
如圖6所示,中頻數(shù)據(jù)接收模塊的clk_IF端口為62MHZ輸入時鐘。中頻數(shù)據(jù)接收模塊的IF_en端口為接收有效信號,當(dāng)此信號為高電平時,在輸入時鐘控制下產(chǎn)生數(shù)字10位數(shù)字中頻數(shù)據(jù)IF_data。
如圖7所示,C/A碼發(fā)生模塊的clk_1023端口為時鐘驅(qū)動信號,連接1.023MHZ時鐘。Sel端口為衛(wèi)星號選擇端口。C/A碼發(fā)生模塊的ca_en端口為使能信號,連接到時鐘發(fā)生模塊的LOCKED端口,當(dāng)此信號為高電平時,模塊內(nèi)的兩個十位移位寄存器開始進(jìn)行移位,并按照衛(wèi)星號確定時延進(jìn)行輸出結(jié)果的異或運算產(chǎn)生特定的C/A碼,C/A碼發(fā)生模塊的gold_out端口為產(chǎn)生的C/A碼,C/A碼發(fā)生模塊的ca_start端口為C/A碼有效信號,初值為0,在C/A碼發(fā)生模塊的ca_en端口為高電平之后的第一個有效時鐘沿置1,此時C/A碼開始有效輸出,此信號連接到中頻數(shù)據(jù)接收控制模塊的rec_en端口。C/A碼發(fā)生模塊的ca_rst端口為復(fù)位信號,C/A碼發(fā)生模塊的ca_rec_rst端口為反饋復(fù)位信號,當(dāng)這兩個信號其中之一出現(xiàn)高電平時,將移位寄存器初始化。
如圖8所示,載波生成和剝離模塊的carr_enable端口為使能信號,該端口連接C/A碼發(fā)生模塊的ca_start端口,此信號有效時,在輸入的62MHZ時鐘控制下,32位累加寄存器對頻率控制字進(jìn)行線性累加,再通過累加寄存器的高四位映射出特定幅度的正余弦值。載波的頻率計算方法如下所示:
其中fclk為62MHZ的輸入時鐘,incr為控制步長,f為載波頻率。中頻頻率為46.42MHZ,對應(yīng)的步長為3215683579,每次多普勒搜索的步長為500HZ,對應(yīng)的控制字?jǐn)?shù)值變化為34637。通過此方法復(fù)現(xiàn)出46.42MHZ(中頻頻率)加上-5000HZ至+5000HZ多普勒頻移的正余弦載波,并與中頻數(shù)據(jù)分別相乘產(chǎn)生同相、正交兩路數(shù)據(jù)。載波生成和剝離模塊的carr_rst端口為復(fù)位信號,此信號為高電平時,累加寄存器清零。載波生成和剝離模塊的carr_change端口為反饋信號,此信號有效時,將累加寄存器清零,并將頻率控制字改變34637以搜索下一個多普勒頻率。載波生成和剝離模塊的I、Q端口分別為剝離載波后的同相、正交數(shù)據(jù),載波發(fā)生與剝離模塊的incr_out端口為此時的步進(jìn)值。
如圖9、圖10所示,C/A碼平均采樣模塊通過分段累加用于對1ms的C/A碼和同相正交數(shù)據(jù)下采樣成2048點。通過計算得出1488個平均采樣數(shù)據(jù),采用30點累加,560個平均采樣數(shù)據(jù)采用31點累加,再算出每一個平均采樣數(shù)據(jù)需要的累加點數(shù),存儲在深度為2048的累加點數(shù)存儲器中,計算方法如下:
average=62000/2048=30.27342375(2)
accu_ram(i)=round(average*i)-round(average*(i-1)) (3)
其中accu_ram(i)表示第i個平均采樣數(shù)據(jù)的累加點數(shù),即累加點數(shù)存儲器第i個地址的值,round表示最接近的整數(shù)。C/A碼平均采樣模塊的ca_aver_en端口和同相正交平均采樣模塊的IQ_aver_en端口為使能信號,連接到C/A碼發(fā)生模塊的ca_start端口,此信號有效時,在輸入的62MHZ時鐘驅(qū)動下,依據(jù)累加點數(shù)存儲器的值對偽碼和同相正交數(shù)據(jù)進(jìn)行累加,當(dāng)累加完與累加點數(shù)存儲器的值個數(shù)相等數(shù)據(jù)后將地址值加一,與此同時,將C/A碼平均采樣模塊的存儲使能信號ca_ram_en和同相正交平均采樣模塊的IQ_ram_en端口置為高電平,并且C/A碼平均采樣模塊和同相正交平均采樣模塊分別輸出累加值aver_ca、aver_I和aver_Q。C/A碼平均采樣模塊的rst_ca_aver端口和同相正交平均采樣模塊的rst_IQ_aver端口為復(fù)位信號,當(dāng)此信號為高電平時,將地址值重新置零。
如圖11、圖12所示,C/A碼平均采樣數(shù)據(jù)存儲模塊和同相正交平均采樣數(shù)據(jù)存儲模塊分別在存儲使能信號ca_ram_en和IQ_ram_en為高電平期間將平均采樣值aver_ca和aver_I、aver_Q讀入內(nèi)置的2048深度存儲器,同時每存儲一次數(shù)據(jù)計數(shù)器的值加一,當(dāng)存滿2048個數(shù)據(jù)時,C/A碼平均采樣數(shù)據(jù)存儲模塊和同相正交平均采樣數(shù)據(jù)存儲模塊分別將指示信號ca_ram_flag和IQ_ram_flag輸出一個高脈沖,開始啟動FFT變換,同時將計數(shù)器置0,C/A碼平均采樣數(shù)據(jù)存儲模塊的ca_rfd和同相正交平均采樣數(shù)據(jù)存儲模塊的IQ_rfd為讀使能信號,此信號為高電平期間依據(jù)讀地址索引值ca_xn_index和IQ_xn_index依次讀取存儲器中的數(shù)據(jù),并分別輸出到ca_out端口、I_out端口、Q_out端口。
如圖13、圖14所示,F(xiàn)FT模塊采用IP核實現(xiàn),為了節(jié)省硬件資源,實現(xiàn)結(jié)構(gòu)為Radix-2 Burst I/O,變換點數(shù)為2048。C/A碼FFT模塊的啟動信號ca_start連接C/A碼平均采樣數(shù)據(jù)存儲模塊的ca_ram_flag端口,同相正交FFT模塊的啟動信號IQ_start連接同相正交平均采樣數(shù)據(jù)存儲模塊的IQ_ram_flag端口。C/A碼FFT模塊的ca_rfd端口和同相正交FFT模塊的IQ_rfd端口為讀使能信號,分別連接C/A碼平均采樣數(shù)據(jù)存儲模塊和同相正交平均采樣數(shù)據(jù)存儲模塊的ca_rfd端口和IQ_rfd端口,當(dāng)C/A碼FFT模塊和同相正交FFT模塊開始接收數(shù)據(jù)時,ca_rfd端口和IQ_rfd端口持續(xù)輸出高電平,此時依照C/A碼平均采樣數(shù)據(jù)存儲模塊和同相正交平均采樣數(shù)據(jù)存儲模塊的索引值ca_xn_index和IQ_xn_index讀取存儲器中的數(shù)據(jù)。C/A碼FFT模塊和同相正交FFT模塊的ca_fwd_inv和IQ_fwd_inv信號為控制信號,當(dāng)進(jìn)行FFT變換時,這兩個信號置為高電平,C/A碼FFT模塊的ca_fwd_inv_en端口和同相正交FFT模塊的IQ_fwd_inv_en端口為ca_fwd_inv端口和IQ_fwd_inv端口的寫使能信號,全部置為高電平。C/A碼FFT模塊的ca_unload端口和同相正交FFT模塊的IQ_unload端口為輸出結(jié)果信號,置為高電平。C/A碼FFT模塊和同相正交FFT模塊的clk時鐘信號連接62MHZ時鐘,C/A碼FFT模塊輸入數(shù)據(jù)的實部ca_xn_re信號連接C/A碼平均采樣數(shù)據(jù)存儲模塊的ca_out端口,C/A碼FFT模塊輸入數(shù)據(jù)的虛部ca_xn_im置為低電平。同相正交FFT模塊輸入數(shù)據(jù)實部IQ_xn_re和虛部IQ_xn_im分別連接同相正交平均采樣數(shù)據(jù)存儲模塊的I_out端口和Q_out端口,C/A碼FFT模塊和同相正交FFT模塊的完成信號ca_done和IQ_done進(jìn)行與運算后連接到中頻數(shù)據(jù)接收控制模塊、C/A碼發(fā)生模塊、載波生成與剝離模塊、C/A碼平均采樣模塊、同相正交平均采樣模塊的反饋復(fù)位信號rst_IF_rec、ca_rst、carr_rst、rst_ca_aver和rst_IQ_aver,開始處理下1ms中頻數(shù)據(jù)。C/A碼FFT模塊和同相正交FFT模塊的輸出結(jié)果有效信號ca_dv和IQ_dv為高電平期間開始輸出變換結(jié)果,C/A碼FFT模塊變換結(jié)果的實部和虛部為ca_xk_re、ca_xk_im,同相正交FFT模塊變換結(jié)果的實部和虛部為IQ_xk_re和IQ_xk_im。
FFT變換之后需要對C/A碼變換結(jié)果的共軛和同相正交變換結(jié)果進(jìn)行復(fù)數(shù)乘法。計算方法如公式(4)和(5)所示:
qr=ar×(br+bi)+br×(ai-ar) (4)
qi=ar×(br+bi)-bi×(ai+ar) (5)
其中ar、br、ai、bi分別表示兩個乘數(shù)的實部和虛部,qr和qi表示復(fù)數(shù)乘法結(jié)果的實部和虛部。
如圖15所示,C/A碼FFT模塊的ca_xk_im端口取反后連接到復(fù)數(shù)乘法模塊ai端口,復(fù)數(shù)乘法模塊ar端口連接C/A碼FFT模塊的ca_xk_re端口。復(fù)數(shù)乘法模塊的bi和br端口分別連接到同相正交FFT模塊的IQ_xk_im和IQ_xk_re端口。復(fù)數(shù)乘法模塊的clk62M端口連接62MHZ時鐘,端口ca_dv和IQ_dv都為高電平時在輸入時鐘控制下接收FFT變換結(jié)果進(jìn)行復(fù)數(shù)乘法運算,同時將計算結(jié)果的實部qr和虛部qi輸出,并暫存到復(fù)數(shù)乘法結(jié)果存儲器當(dāng)中,在此期間,復(fù)數(shù)乘法模塊的輸出指示信號en_ifft_ram置為高電平。
如圖16所示,復(fù)數(shù)乘法結(jié)果存儲模塊在en_ifft_ram端口為高電平期間,在62MHZ時鐘驅(qū)動下,將復(fù)數(shù)乘法結(jié)果qi和qr存儲到2048位存儲器中。存滿后將輸出指示信號ifft_flag輸出一個高脈沖,并連接到傅里葉反變換(IFFT)模塊的起始信號start端口,復(fù)數(shù)乘法結(jié)果存儲模塊的ifft_rfd端口連接到IFFT模塊的準(zhǔn)備好接收數(shù)據(jù)rfd端口,復(fù)數(shù)乘法結(jié)果存儲模塊的ifft_xn_index端口連接到IFFT模塊的數(shù)據(jù)輸入索引值。在ifft_rfd端口為高電平期間,依據(jù)ifft_xn_index端口將存儲的數(shù)據(jù)通過ifft_re端口和ifft_im端口依次傳送到IFFT模塊數(shù)據(jù)輸入端口xn_re和xn_im,開始進(jìn)行傅里葉反變換。
如圖17所示,IFFT模塊和FFT模塊一樣采樣IP核。IFFT模塊的fwd_inv信號置為低電平,表示此時進(jìn)行傅里葉反變換。fwd_inv_en(fwd_inv寫使能信號)和un_load(輸出結(jié)果信號)信號置為高電平,輸入數(shù)據(jù)xn_re端口和xn_im端口連接到復(fù)數(shù)乘法數(shù)據(jù)存儲模塊的ifft_re端口和ifft_im端口,IFFT變換結(jié)果的實部和虛部為ifft_xk_re和ifft_xk_im,在計算結(jié)果穩(wěn)定輸出期間將IFFT變換結(jié)果的實部和虛部ifft_xk_re和ifft_xk_im存入相關(guān)值存儲模塊。
如圖18所示,相關(guān)值存儲模塊的ifft_dv端口連接IFFT模塊的輸出數(shù)據(jù)有效指示信號(dv),此信號為高電平時,將IFFT變換結(jié)果實部(ifft_xk_re)和虛部(ifft_xk_im)進(jìn)行平方和后,依次存入存儲器中,此結(jié)果為相關(guān)值。為了成功捕獲微弱信號并克服噪聲帶來的影響,將連續(xù)8ms的結(jié)果進(jìn)行累加之后把輸出信號edge_ram_flag置為高電平,同時將累加結(jié)果acq_res依次輸出,當(dāng)2048個結(jié)果全部輸出完畢之后,將輸出信號edge_ram_flag恢復(fù)到初始的低電平狀態(tài)。
如圖19所示,峰值檢測檢測模塊的test_en端口為使能信號,連接相關(guān)值存儲模塊的edge_ram_flag端口。在此信號為高電平期間,輸入acq_res端口,并在62MHZ時鐘驅(qū)動下記錄主峰值和次峰值和主峰值出現(xiàn)的碼相位,如果主次峰值比大于一定閾值并且主峰值大于設(shè)定門限時,捕獲成功,此時將峰值檢測檢測模塊的acq_flag端口置為高電平,同時輸出多普勒(acq_incr)和碼相位(acq_codePhase),否則將輸出結(jié)果carr_change賦予一個高脈沖信號,把此端口連接到中頻數(shù)據(jù)接收控制模塊、C/A碼發(fā)生模塊、載波生成與剝離模塊和平均采樣模塊的rst_IF_rec、ca_rst、carr_change、rst_ca_aver和rst_IQ_aver端口,修改步進(jìn)值,將頻率移動至下一個多普勒,同時將載波和C/A碼復(fù)位進(jìn)行下一個多普勒頻槽的搜索,直至搜索出滿足條件的結(jié)果。