《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 可編程邏輯 > 其他 > FPGA教學(xué)——?基于Verilog的DDS波形發(fā)生器的分析與實現(xiàn)(三角波、正弦波)

FPGA教學(xué)——?基于Verilog的DDS波形發(fā)生器的分析與實現(xiàn)(三角波、正弦波)

2022-09-02
來源:FPGA設(shè)計論壇
關(guān)鍵詞: Verilog DDS波形發(fā)生器

  基于VerilogDDS波形發(fā)生器的分析與實現(xiàn)(三角波、正弦波)

  最近學(xué)習(xí)了一下關(guān)于DDS的相關(guān)知識,本篇概要記錄一下自己的理解與實現(xiàn)。

  DDS信號發(fā)生器采用直接數(shù)字頻率合成(Direct Digital Synthesis,簡稱DDS)技術(shù),把信號發(fā)生器的頻率穩(wěn)定度、準(zhǔn)確度提高到與基準(zhǔn)頻率相同的水平,并且可以在很寬的頻率范圍內(nèi)進行精細(xì)的頻率調(diào)節(jié)。采用這種方法設(shè)計的信號源可工作于調(diào)制狀態(tài),可對輸出電平進行調(diào)節(jié),也可輸出各種波形。

  下圖為DDS 的基本結(jié)構(gòu)圖

微信圖片_20220902141213.png

  由上圖 可以看出,DDS 主要由相位累加器、相位調(diào)制器、波形數(shù)據(jù)表以及 D/A 轉(zhuǎn)換器構(gòu)成。

  相位累加部分控制輸出波形頻率,相位字輸入部分來改變相位,ROM表中存儲一個周期波形的幅度值。

  其中相位累加器由 N 位加法器與 N 位寄存器構(gòu)成。每來一個時鐘,加法器就將頻率控制字與累加寄存器輸出的相位數(shù)據(jù)相加,相加的結(jié)果又反饋至累加寄存器的數(shù)據(jù)輸入端,以使加法器在下一個時鐘脈沖的作用下繼續(xù)與頻率控制字相加。這樣,相位累加器在時鐘作用下,不斷對頻率控制字進行線性相位累加。即在每一個時鐘脈沖輸入時,相位累加器便把頻率控制字累加一次。相位累加器輸出的數(shù)據(jù)就是合成信號的相位。相位累加器的溢出頻率,就是 DDS 輸出的信號頻率。(解釋:定義一個N位寄存器,一般為32位,如果來一個時鐘計一次,那就要計2^32次才滿,這樣太慢,因此引入頻率控制字設(shè)為A,以前以1為單位,現(xiàn)在以A為單位計數(shù)累加,可以控制計數(shù)更新的速度)

  用相位累加器輸出的數(shù)據(jù),作為波形存儲器的相位采樣地址,這樣就可以把存儲在波形存儲器里的波形采樣值經(jīng)查表找出,完成相位到幅度的轉(zhuǎn)換。波形存儲器的輸出送到 D/A 轉(zhuǎn)換器,由 D/A 轉(zhuǎn)換器將數(shù)字信號轉(zhuǎn)換成模擬信號輸出。

  一般32位累加器不會全用來輸出作為ROM地址,會根據(jù)ROM深度來適當(dāng)截取高位作為地址,其余位可以作為控制頻率。例如現(xiàn)在ROM中存儲波形一個周期數(shù)據(jù)每個數(shù)據(jù)位寬8位,則數(shù)據(jù)范圍為0-2^8(256),但是要產(chǎn)生一個周期波形需要512個,因為0-256一般是上升期,256-0處于下降期,那么現(xiàn)在ROM深度為512,則地址位寬應(yīng)為9位,2的9次方=512,則32位累加器只需高9位即可[31:23]尋址,其余位用來控制地址改變的頻率。假如現(xiàn)在每來一個時鐘地址變一次,那么其余位(即頻率控制字A)應(yīng)設(shè)置為32‘h800000即32’b0000_0000_10000000_0000_0000_0000_0000,最高位1其實就是地址的最低位,累加器初始為0,來個時鐘沿加一次A,高9位地址變化一次。要想兩個時鐘變化一次,那么A就是32‘b0000_00000100_0000_0000_0000_0000_0000,兩個時鐘之后地址的最低位才會變化。這樣通過對頻率控制字A的設(shè)置就可以達到改變地址的變化頻率,其實就是輸出的頻率。不知道這樣說看者能否理解。

 微信截圖_20220902141325.png

  代碼:

  module dds(

  clk,

  rst,

  Fword, //頻率控制字A

  Pword, //相位控制字

  data

  );

  input clk,rst;

  input [31:0] Fword;

  input [8:0] Pword;

  output [7:0] data; //8位數(shù)據(jù)

  reg [31:0] r_Fword;

  reg [8:0] r_Pword;

  reg [31:0] cnt;

  wire [8:0] rom_adder;

  always@(posedge clk)

  begin

  r_Fword<=Fword;

  r_Pword<=Pword;

  end

  always@(posedge clk or negedge rst)    //累加器部分

  begin

  if(!rst)

  cnt<=32'd0;

  else

  cnt<=cnt+r_Fword;

  end

  assign rom_adder=cnt[31:23]+r_Pword;     //ROM地址

  rom  rom(                              //例化一個ROM ip核

  .address(rom_adder),

  .clock(clk),

  .q(data)

  );

  endmodule

  tb:

  `timescale 1ns/1ns

  module dds_tb;

  reg clk,rst;

  reg [31:0] Fword;

  reg [8:0] Pword;

  wire [7:0] data;

  dds u0(

  .clk(clk),

  .rst(rst),

  .Fword(Fword),

  .Pword(Pword),

  .data(data)

  );

  initial clk=1;

  always #10 clk=~clk;

  initial begin

  rst=0;

  Fword=32'h800000;

  Pword=9'd0;

  #101;

  rst=1;

  #500;

  $stop;

  end

  endmodule

  ROM中值,用來比對,在例化ip是輸出加了一個寄存器,因此會延時一拍輸出。主時鐘50M,下圖把data轉(zhuǎn)換為模擬值,兩個黃線之間為頻率97.65khz,A為32‘h800000=32’d8388608,50_000_000乘以A等于419430400000000,除以2^32等于97656.25khz驗證正確。

  更改ROM中mif文件,添加三角波,ROM中三角波這里一共有256個數(shù)值,0-127,127-0,地址位寬為8位,那么[31:24]作為地址,其余位作為頻率控制字。只需改動程序中地址位寬就可以了,A暫時設(shè)為32‘h01000000,下圖為相位控制字為8‘h0,8’h5;可以看出相位控制字不會改變輸出頻率.

  附加:如果此時知道主時鐘50M,想生成一個25M的波形,那么首先根據(jù)公式計算出A=2147483648即二進制1000_0000_0000_0000_0000_0000_0000_0000.仿真如下圖為方波,因為根據(jù)地址變化只取0、127.

  總結(jié):本文內(nèi)容也是在看相關(guān)視頻后自己更改ROM深度,更換波形仿真后得出,由于敘述水平有限,其中原理可以自行查看其他文章內(nèi)容了解,關(guān)于本文如有不懂之處可以聯(lián)系我,共同再探討。同時其中主要思想可以用來作為任意分頻設(shè)計,后續(xù)再做。

  文末附上一個mif文件生成器,不然手動輸入ROM值太慢了

  

 更多信息可以來這里獲取==>>電子技術(shù)應(yīng)用-AET<<

微信圖片_20210517164139.jpg


本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美日韩a区| 国产日韩欧美亚洲一区| 亚洲欧美视频在线| 一本高清dvd不卡在线观看| 最近看过的日韩成人| 亚洲高清激情| 久久成人人人人精品欧| 亚洲欧美日本日韩| 亚洲制服少妇| 亚洲中字在线| 亚洲一区二区三区三| 亚洲视频在线一区| 亚洲午夜久久久久久尤物| 一本到12不卡视频在线dvd| 亚洲人成77777在线观看网| 亚洲激情成人网| 亚洲级视频在线观看免费1级| 亚洲第一级黄色片| 亚洲国产日韩一区二区| 亚洲电影免费在线| 亚洲国产精品久久久久秋霞蜜臀| 亚洲风情在线资源站| 亚洲国产精品成人精品| 亚洲国产1区| 亚洲人成亚洲人成在线观看| 亚洲三级毛片| 一本色道久久88综合亚洲精品ⅰ| 一区二区欧美日韩| 亚洲一卡二卡三卡四卡五卡| 亚洲视频香蕉人妖| 亚洲欧美久久久| 欧美一区二区三区在线| 久久不射中文字幕| 亚洲大胆视频| 亚洲麻豆av| 在线视频你懂得一区| 亚洲午夜一区| 午夜宅男久久久| 久久久高清一区二区三区| 猛男gaygay欧美视频| 欧美激情一区二区三区| 欧美日韩午夜在线| 国产女精品视频网站免费| 国外成人网址| 91久久精品国产91久久| 亚洲美女尤物影院| 亚洲小说欧美另类婷婷| 久久国产精彩视频| 日韩一级欧洲| 午夜精品视频一区| 乱人伦精品视频在线观看| 欧美激情在线播放| 国产精品日韩欧美一区二区三区 | 午夜精品一区二区三区电影天堂| 欧美亚洲三区| 91久久午夜| 亚洲一区免费在线观看| 久久久噜噜噜久久久| 欧美精品久久久久久久久久| 国产精品久久久久久一区二区三区| 国产一区二区精品| 亚洲欧洲日本mm| 亚洲一区日韩| 亚洲精品日本| 欧美一级理论片| 欧美国产1区2区| 国产麻豆精品视频| 亚洲人成7777| 欧美一区=区| 一区二区三区高清视频在线观看 | 欧美一区亚洲| 欧美成人精品1314www| 欧美午夜片欧美片在线观看| 国产一区av在线| 99精品欧美| 久久精品成人一区二区三区| 亚洲午夜久久久久久尤物| 久久最新视频| 国产精品日日摸夜夜添夜夜av| 伊人一区二区三区久久精品| 亚洲图片在线观看| 日韩视频免费大全中文字幕| 久久成人精品无人区| 欧美日韩免费一区二区三区视频| 激情懂色av一区av二区av| 一区二区福利| 亚洲精品一区二区三区婷婷月 | 欧美在线视频一区二区三区| 欧美日韩精品| 在线成人欧美| 亚洲欧美国内爽妇网| 一区二区福利| 免费av成人在线| 国产区在线观看成人精品| 夜夜嗨网站十八久久| 亚洲精品免费一区二区三区| 久久成人亚洲| 国产精品嫩草影院一区二区| 亚洲毛片在线看| 91久久国产综合久久91精品网站| 久久国产日本精品| 国产精品久久久久久久久| 日韩午夜av| 99re亚洲国产精品| 欧美成人精品在线视频| 激情欧美亚洲| 欧美在线播放| 欧美一区二区高清在线观看| 国产精品国色综合久久| 日韩亚洲欧美高清| 日韩亚洲国产欧美| 另类天堂av| 国内精品久久久久影院优| 性欧美video另类hd性玩具| 午夜精品美女久久久久av福利| 欧美日韩一区二区三区在线观看免| 在线观看欧美日韩国产| 亚洲高清中文字幕| 久久久久久电影| 国产视频一区三区| 欧美亚洲综合久久| 久久精品国产第一区二区三区| 国产精品中文在线| 亚洲欧美一区二区视频| 性欧美大战久久久久久久久| 国产精品久久久久7777婷婷| 一本久道久久综合婷婷鲸鱼| 一区二区成人精品| 欧美日韩亚洲成人| 99精品热视频| 亚洲主播在线播放| 国产精品久久久久久久久婷婷| 一区二区三区日韩欧美精品| 亚洲一区二区久久| 国产精品久久网| 校园春色综合网| 久久久噜噜噜久久人人看| 国内精品国语自产拍在线观看| 欧美自拍丝袜亚洲| 免费日韩av电影| 亚洲人成人一区二区在线观看| 99成人精品| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 久久综合图片| 亚洲激情视频在线播放| 在线综合亚洲| 国产精品一区一区三区| 欧美在线视频一区二区| 欧美大尺度在线| 夜夜嗨av一区二区三区网站四季av| 亚洲欧美日韩综合国产aⅴ| 国产日产亚洲精品系列| 久久精品国产一区二区三| 欧美成人a视频| 日韩视频国产视频| 欧美怡红院视频一区二区三区| 韩日成人在线| 正在播放欧美视频| 国产九区一区在线| 亚洲国产成人久久综合| 欧美日韩精品欧美日韩精品| 中文亚洲免费| 久久久久久久一区二区| 亚洲精品免费一区二区三区| 亚洲欧美久久| 伊人蜜桃色噜噜激情综合| 中文国产亚洲喷潮| 国产亚洲欧美日韩一区二区| 亚洲人成7777| 国产精品稀缺呦系列在线| 亚洲国产精品高清久久久| 国产精品v欧美精品v日韩| 久久国产精品久久久| 欧美日韩理论| 久久精品99| 国产精品激情| 亚洲精品欧美日韩| 国产麻豆精品视频| 亚洲理伦电影| 国产亚洲美州欧州综合国| 日韩一级黄色大片| 国产亚洲欧洲| 一区二区三区国产在线| 国产一区自拍视频| 亚洲午夜精品久久久久久浪潮 | 亚洲国产精品99久久久久久久久| 欧美色大人视频| 亚洲国产精品久久人人爱蜜臀| 国产精品v日韩精品| 久久精品亚洲一区二区| 国产精品成人v| 亚洲人成77777在线观看网| 国产精品日韩二区| 99re6这里只有精品视频在线观看| 国产日韩欧美在线看| 一区二区三区欧美日韩| 极品尤物久久久av免费看| 午夜亚洲性色视频| 亚洲日本成人网| 久久只精品国产|