對于移相波束形成的抗噪聲性能分析,我們主要通過對系統在不同的SNR信噪比下進行仿真分析,這里FPGA的幾個主要仿真引數:入射角為5度,FFT變換長度為256,將FPGA系統分別在沒有噪聲,SNR為-10db,SNR為0db,SNR為10db三種情況對比沒有噪聲下的仿真結果,
通過仿真,我們可以得到如下的仿真結果:

圖1 不同SNR下波束形成仿真結果
圖1的仿真結果中,o_boxes為沒有噪聲的波束形成,o_boxes10為信噪比為10db下的波束形成輸出,o_boxes0為信噪比為0db下的波束形成輸出,o_boxes_10為信噪比為-10db下的波束形成輸出,從上面的仿真結果可以看到,當噪聲不斷增加的時候,輸出的波束形成具有明顯的噪聲干擾,
上圖是入射角為5度的時候仿真,為了進一步對比噪聲對角度計算的精度影響,將上面的仿真圖放大,可以看到如下的仿真結果圖,

圖2不同SNR下波束形成放大后的仿真結果
從圖2的仿真結果可以看到,我們以不帶噪聲的輸出作為標準的角度值,當SNR為10db的時候,誤差在0.02度左右,當SNR為0db的時候,誤差在0.04度左右,當SNR為-10db的時候,誤差在0.07度左右,
從上面的仿真結果可以看到,隨著噪聲功率的增加,移相波束形成得到的角度計算值誤差越大,對比本文前面章節的MATLAB仿真結果可知,最后計算的角度存在一定的誤差,
計算結論基本能夠反映實際的噪聲影響,和MATLAB的理論仿真結果誤差是因為在FPGA設計程序中,每一個模塊都需要截取位寬以及量化處理,因此會存在較大的誤差,當做乘法運算的時候,資料的位寬會翻倍的增加,如果不進行位寬的截取,則會大大增加FPGA內部的資源占用,因此一般情況下,每次做完乘法運算,往往需要進行位寬的截取,截取位寬導致的誤差取決于位寬截取的大小,位寬截取越多,則誤差越大,位寬截取越少,則誤差越小,
另外一方面,由于在FPGA內部采用的計算方法是定點計算方法,這會引入量化噪聲,由量化噪聲導致的誤差稱為量化誤差量化誤差是指量化結果和被量化模擬量的差值,顯然量化級數越多,量化的相對誤差越小,量化級數指的是將最大值均等的級數,每一個均值的大小稱為一個量化單位,
·基于FPGA的角度解析度分析
通過輸入不同入射角的信號,分別分析入射角的理論值和實際計算值的誤差,這里,分別設定入射角為5度和15度,SNR信噪比為10db,FFT傅里葉變換的長度設定為256,然后進行仿真,仿真結果如下所示:

圖3 入射角為5度的仿真結果
圖3中第一個波形為理想狀態下的入射角,第二個圖為通過移相波束形成后的角度計算值,為了更精確的分析角度計算的精度,我們將輸出波形進行區域的放大,得到如下的仿真結果圖,

圖4 入射角為5度的仿真結果(區域放大)
從圖4的仿真結果可知,當入射角為5度的時候,其誤差在0.02度左右,這說明系統可以很好的達到測定目標方向的目標,其誤差在0.4%左右,
為了更進一步的分析基于FPGA的移相波束形成的角度解析度,我們將入射角設定為15度,其余引數和上面的引數相同,得到如下的仿真結果:

圖5 入射角為15度的仿真結果
和圖3的仿真結果類似,圖5中第一個波形為理想狀態下的入射角,第二個圖為通過移相波束形成后的角度計算值,然后我們將輸出波形進行區域的放大,得到如下的仿真結果圖,

圖6 入射角為15度的仿真結果(區域放大)
從圖6的仿真結果可知,當入射角為15度的時候,其誤差在0.07度左右,雖然誤差角度大于入射角為5度的計算結果,但其誤差百分比為0.467%,基本和上面的仿真結果一直,
通過上面兩種入射角情況下的輸入信號計算結果的對比,最后得到的誤差結果基本和MATLAB的誤差結果一直,
仿真得到的0.4%左右的誤差,主要來自三個方面的影響,
第一,噪聲的干擾,由于仿真的時候引入了SNR=10db的噪聲,因此,最后的輸出結果會存在一定的誤差,
第二,由于FPGA和位寬截取和量化噪聲導致結論的誤差,這個原因和上一節介紹的原因類似,
第三,FPGA系統內部時鐘及部分時序抖動而導致的誤差,
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/168819.html
標籤:其他
