加入星計(jì)劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴(kuò)散
  • 作品版權(quán)保護(hù)
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長(zhǎng)期合作伙伴
立即加入
  • 正文
    • 基于 FPGA 的偽隨機(jī)序列發(fā)生器設(shè)計(jì)
    • 4 FPGA 的 LSFR 驗(yàn)證
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請(qǐng)入駐 產(chǎn)業(yè)圖譜

基于FPGA的偽隨機(jī)序列發(fā)生器設(shè)計(jì)

2020/07/02
310
閱讀需 8 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點(diǎn)資訊討論

基于 FPGA 的偽隨機(jī)序列發(fā)生器設(shè)計(jì)

1 基本概念與應(yīng)用

1)LFSR:線性反饋移位寄存器(linear feedback shift register, LFSR)是指給定前一狀態(tài)的輸出,將該輸出的線性函數(shù)再用作輸入的移位寄存器。異或運(yùn)算是最常見的單比特線性函數(shù):對(duì)寄存器的某些位進(jìn)行異或操作后作為輸入,再對(duì)寄存器中的各比特進(jìn)行整體移位。

LFSR 產(chǎn)生的兩種形式為伽羅瓦(Galois)和斐波那契(Fibonacci)兩種形式。也有成為外部(External)執(zhí)行方式和內(nèi)部(Internal)執(zhí)行方式。

(1)伽羅瓦方式(Internal)

?

?

?

Galois 方式特征數(shù)據(jù)的方向從左至右,反饋線路是從右至左。其中 X^0 項(xiàng)(本原多項(xiàng)式里面的‘1’這一項(xiàng))作為起始項(xiàng)。按照本原多項(xiàng)式的指示確定異或門(XOR)在移位寄存器電路上的位置。如上圖所示 X^4。因此 Galois 方式也有人稱作線內(nèi)或模類型(M- 型)LFSR。

(2)斐波那契方式(External)

??

從圖中我們可以看到 Fibonacci 方式的數(shù)學(xué)流向和反饋形式是恰好跟 Galois 方式相反的,按照本原多項(xiàng)式,其中 X^0 這一項(xiàng)作為最后一項(xiàng),這里需要一個(gè) XOR 門,將本原多項(xiàng)式中所給的 taps 來(lái)設(shè)定它的異或方式。因此 Fibonacci 方式也被叫做線外或者簡(jiǎn)型(S- 型)LFSR。

2)本原多項(xiàng)式

本原多項(xiàng)式是近世代數(shù)中的一個(gè)概念,是唯一分解整環(huán)上滿足所有系數(shù)的最大公因數(shù)為 1 的多項(xiàng)式。本原多項(xiàng)式不等于零,與本原多項(xiàng)式相伴的多項(xiàng)式仍為本原多項(xiàng)式。

(1)在 MATLAB 中,本原多項(xiàng)式可以通過(guò)函數(shù) primpoly(x)來(lái)產(chǎn)生。

(2)在 MATLAB 中,通過(guò)函數(shù) gfprimfd(m,'min')可以找到一個(gè)最小的本原多項(xiàng)式。

3)應(yīng)用

誤碼率測(cè)量 -- 在數(shù)字通信中誤碼率是一項(xiàng)重要的質(zhì)量指標(biāo),在實(shí)際測(cè)量數(shù)字通信系統(tǒng)的誤碼率時(shí),一般來(lái)說(shuō),測(cè)量結(jié)果與信源發(fā)出信號(hào)的統(tǒng)計(jì)特性有關(guān)。通常認(rèn)為二進(jìn)制信號(hào) 0 和 1 是以等概率隨機(jī)出現(xiàn)的。所以測(cè)量誤碼率時(shí)最理想的信源應(yīng)是偽隨機(jī)序列產(chǎn)生器。這樣測(cè)量的結(jié)果,我們認(rèn)為是符合實(shí)際運(yùn)用時(shí)的情況。

時(shí)延測(cè)量 -- 有時(shí)我們需要測(cè)量信號(hào)經(jīng)過(guò)某一傳輸路徑所收到的時(shí)間延遲,例如,需要測(cè)量某一延遲線的時(shí)間延遲。另外,我們還常常通過(guò)測(cè)量一無(wú)線電信號(hào)在某個(gè)媒質(zhì)中的傳播時(shí)間,從而折算傳播距離,即利用無(wú)線電信號(hào)測(cè)距。這就是說(shuō),這種測(cè)距的原理實(shí)質(zhì)上也是測(cè)量延遲。

噪聲產(chǎn)生器 -- 測(cè)量通信系統(tǒng)的性能時(shí),常常要使用噪聲產(chǎn)生器,由它給出具有所要求的統(tǒng)計(jì)特性和頻率特性的噪聲,并且可以隨意控制其強(qiáng)度,以便得到不同信噪比條件下的系統(tǒng)性能。例如,在許多情況下,要求它能產(chǎn)生限帶白色高斯噪聲。

通信加密、數(shù)據(jù)序列的加擾與解擾、擴(kuò)展頻譜通信、分離多徑技術(shù)等等。

2 偽隨機(jī)序列的原理

對(duì)于某種反饋邏輯、初始化狀態(tài)非全零時(shí),若輸出序列周期最長(zhǎng)(P=2r-1),稱為 m 序列,也稱為偽隨機(jī)序列。

偽隨機(jī)序列通常由反饋移位寄存器產(chǎn)生,又可分為線性反饋移位寄存器和非線性反饋移位寄存器兩類。由線性反饋移位寄存器產(chǎn)生出的周期最長(zhǎng)的二進(jìn)制數(shù)字序列稱為最大長(zhǎng)度線性反饋移位寄存器,即為通常說(shuō)的 m 序列,因其理論成熟,實(shí)現(xiàn)簡(jiǎn)單,應(yīng)用較為廣泛。下面介紹 m 序列的產(chǎn)生原理。

在二進(jìn)制多級(jí)移位寄存器中,若線性反饋移位寄存器(LFSR)有 n 階(即有 n 級(jí)寄存器),則所能產(chǎn)生的最大長(zhǎng)度的碼序列為 2n-1 位。如果數(shù)字信號(hào)直接取自 LFSR(非翻轉(zhuǎn)信號(hào))的輸出,那么最長(zhǎng)的連 0 數(shù)為 n-1。除了字符串的連 0 和連 1,偽隨機(jī)序列在一個(gè)長(zhǎng)度為 n 的字符串中將包含任何可能的 0 和 1 的組合。要使移位寄存器產(chǎn)生確定的值,必須置其初值并允許時(shí)鐘電路產(chǎn)生移位時(shí)鐘。

線性反饋移位寄存器產(chǎn)生 m 序列

在圖中給出一個(gè)一般的線性反饋移位寄存器的組成。圖中一級(jí)移存器的狀態(tài)用表示,=0 或 1,i=整數(shù)。反饋線的連接狀態(tài)用?表示,=1 表示此線接通(參加反饋),=0 表示此線斷開。我們不難推想,反饋線的連接狀態(tài)不同,就可能改變此移存器輸出序列的周期 p。

的取值決定了移存器的反饋連接和序列的結(jié)構(gòu),也就是決定了序列的周期。用特征多項(xiàng)式表示為:

當(dāng)特征多項(xiàng)式符合某些條件時(shí)稱為本原多項(xiàng)式。在設(shè)計(jì) m 序列產(chǎn)生器時(shí),移位寄存器反饋線的結(jié)構(gòu)直接決定于本原多項(xiàng)式的結(jié)構(gòu)。也就是只要找到本原多項(xiàng)式,就能由它構(gòu)成 m 序列產(chǎn)生器。

3 matlab 的 LFSR 驗(yàn)證

1)matlab 函數(shù)產(chǎn)生本原多項(xiàng)式

clear all

close all

primpoly(8);

2)本原多項(xiàng)式產(chǎn)生隨機(jī)序列

clear all

close all

% m=8

% x^8+x^4+x^3+x^2+1

% 435

s=[1 1 1 1 1 1 1 1];

t=[8 4 3 2];

[seq c]=LFSRv1(s,t);

4 FPGA 的 LSFR 驗(yàn)證

1)fpga 實(shí)現(xiàn)本原多項(xiàng)式

/*m:x^8+x^4+x^3+x^2+1*/ module msequence8#(       parameter seed= 8'b1111_1111   )(   clk,   rst_n,   en,   mse8, //m sequence   rand8   );     input clk, rst_n;    input en;    output mse8;    output reg [7:0] rand8;     assign mse8 = rand8[0];     always @ (posedge clk or negedge rst_n)begin       if(!rst_n)          rand8 <= seed;       else if(en) begin          rand8[0] <= rand8[1];          rand8[1] <= rand8[2];          rand8[2] <= rand8[3];          rand8[3] <= rand8[4];          rand8[4] <= rand8[5];          rand8[5] <= rand8[6];          rand8[6] <= rand8[7];          rand8[7] <= rand8[0] ^ rand8[4] ^ rand8[5] ^ rand8[6];       end       else          rand8 <= rand8;    end endmodule

如上圖所示,當(dāng) fpga 仿真的輸入種子和 matlab 的輸入種子一致時(shí)產(chǎn)生的序列一致。

上圖為隨機(jī)序列的模擬信號(hào)展示。

3)在產(chǎn)生隨機(jī)數(shù)序列的基礎(chǔ)上我們可以進(jìn)一步去產(chǎn)生符合高斯分布的高斯白噪聲

相關(guān)推薦

電子產(chǎn)業(yè)圖譜

lee
lee

從數(shù)字出發(fā),走進(jìn)圖像世界,聆聽音頻的美妙旋律。從電路出發(fā),實(shí)現(xiàn)美妙的算法,展示代碼的美奐。從知識(shí)到實(shí)現(xiàn),歡迎大家關(guān)注公眾號(hào)FPGA開源工作室。