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

FPGA教學——?基于Verilog的DDS波形發生器的分析與實現(三角波、正弦波)

2022-09-02
來源:FPGA設計論壇

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

  最近學習了一下關于DDS的相關知識,本篇概要記錄一下自己的理解與實現。

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

  下圖為DDS 的基本結構圖

微信圖片_20220902141213.png

  由上圖 可以看出,DDS 主要由相位累加器、相位調制器、波形數據表以及 D/A 轉換器構成。

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

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

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

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

 微信截圖_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位數據

  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轉換為模擬值,兩個黃線之間為頻率97.65khz,A為32‘h800000=32’d8388608,50_000_000乘以A等于419430400000000,除以2^32等于97656.25khz驗證正確。

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

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

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

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

  

 更多信息可以來這里獲取==>>電子技術應用-AET<<

微信圖片_20210517164139.jpg


本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          亚洲女同精品视频| 国产日产亚洲精品| 国产视频自拍一区| 蜜臀91精品一区二区三区| 亚洲男人影院| 欧美成人一二三| 国产精品蜜臀在线观看| 免费高清在线视频一区·| 亚洲乱亚洲高清| 国产精品一页| 欧美日韩在线一区| 国产欧美精品一区二区色综合| 亚洲区欧美区| 欧美在线亚洲综合一区| 国产日韩欧美综合精品| 久久久久久久网| 国产一二三精品| 国产精品制服诱惑| 亚洲欧美在线一区二区| 欧美金8天国| 99精品视频免费观看视频| 国产精品白丝jk黑袜喷水| 欧美专区在线观看一区| 欧美日韩在线一区二区三区| 欧美亚洲在线播放| 夜夜嗨av色综合久久久综合网| 国产农村妇女毛片精品久久麻豆| 尹人成人综合网| 国产精品午夜久久| 国产精品私人影院| 日韩亚洲欧美高清| 99国产精品久久久久老师| 国产日韩精品视频一区二区三区| 久久久xxx| 亚洲欧美在线观看| 在线视频国内自拍亚洲视频| 国模私拍视频一区| 亚洲免费观看高清在线观看| 狠狠色丁香婷婷综合影院| 欧美国产日韩视频| 久久免费视频在线| 午夜在线视频一区二区区别| 欧美一区二区三区在线视频| 国产精品一区二区三区免费观看| 一区二区三区免费网站| 久久综合中文字幕| 国精品一区二区三区| 亚洲主播在线观看| 久久综合伊人77777| 欧美大片免费观看| 99视频精品全国免费| 亚洲三级视频| 国产精品成人一区二区网站软件| 欧美亚州一区二区三区| 91久久中文字幕| 国产亚洲欧美一区二区| 亚洲区一区二区三区| 欧美成人精品h版在线观看| 午夜影院日韩| 亚洲精品女人| 亚洲高清不卡av| 久久婷婷国产综合精品青草| 国产精品免费视频xxxx| 美女脱光内衣内裤视频久久影院| 亚洲欧美三级在线| 在线看国产日韩| 亚洲最新色图| 亚洲午夜小视频| 亚洲毛片av| 国产精品欧美日韩一区二区| 欧美日韩精品中文字幕| 欧美日韩大陆在线| 国产亚洲一区在线播放| 亚洲一区二区三区四区视频| 国产三区二区一区久久| 国产精品伦子伦免费视频| 欧美日韩亚洲一区二区三区在线| 国产精品久久二区| 欧美精品色网| 欧美日韩国产区一| 欧美性大战久久久久久久| 美女福利精品视频| 欧美理论大片| 国产精品极品美女粉嫩高清在线| 久久午夜av| 亚洲欧洲av一区二区| 国产日韩欧美一区二区| 亚洲国产另类 国产精品国产免费| 久久亚洲一区二区| 久久久www| 国产综合激情| 久久国内精品自在自线400部| 你懂的视频一区二区| 另类欧美日韩国产在线| 欧美一区二区三区日韩| 久久精品国产视频| 国产精品成人国产乱一区| 国产精品私拍pans大尺度在线| 久久精品一区二区三区不卡| 欧美一区二区三区电影在线观看| 欧美尤物一区| 欧美一区二区三区在线观看视频| 国产午夜一区二区三区| 久久漫画官网| 国产欧美在线观看一区| 久久亚洲精品一区| 欧美激情女人20p| 夜夜精品视频一区二区| 亚洲影院在线观看| 久久久久国产一区二区三区| 尤物九九久久国产精品的特点| 欧美亚洲专区| 亚洲第一区在线| 久久这里有精品15一区二区三区| 国产一区在线播放| 亚洲日韩欧美视频一区| 欧美一区二区三区免费在线看| 久久精品综合网| 免费欧美在线视频| 国产精品xxx在线观看www| 久色婷婷小香蕉久久| 91久久精品国产91久久性色tv| 欧美日韩大片| 欧美~级网站不卡| 伊人夜夜躁av伊人久久| 久久久精品999| 亚洲精品一区二区三区四区高清| 欧美电影免费观看高清完整版| 妖精视频成人观看www| 欧美日韩福利| 国产香蕉97碰碰久久人人| 亚洲午夜久久久久久久久电影院| 日韩一级黄色av| 国内精品嫩模av私拍在线观看| 久久国内精品自在自线400部| 最新国产精品拍自在线播放| 136国产福利精品导航网址| 老妇喷水一区二区三区| 黑丝一区二区三区| 国产情侣久久| 午夜欧美理论片| 欧美日韩国产成人在线免费| 欧美日韩中文字幕| 欧美日韩亚洲一区二区| 欧美在线观看视频一区二区三区| 99视频国产精品免费观看| 亚洲网站视频福利| 国内外成人免费激情在线视频| 亚洲欧美中文字幕| 欧美精品大片| 欧美中文字幕视频在线观看| 精品动漫av| 日韩写真视频在线观看| 国产九色精品成人porny| 亚洲福利视频一区二区| 黑人操亚洲美女惩罚| 国产精品国产三级国产aⅴ无密码| 久久国产一二区| 亚洲成色777777在线观看影院| 国产女主播一区| 久久精品91久久香蕉加勒比| 在线视频日韩| 欧美亚洲专区| 久久影院亚洲| 亚洲欧美高清| 性一交一乱一区二区洋洋av| 久久久精品tv| 欧美一区二区在线播放| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲高清资源综合久久精品| 久久天天躁狠狠躁夜夜爽蜜月| 久久久久久久久蜜桃| 亚洲欧美网站| 老司机免费视频一区二区| 欧美日韩一区二区国产| 蜜桃伊人久久| 夜夜嗨av一区二区三区四季av| 黑人操亚洲美女惩罚| 亚洲电影观看| 暖暖成人免费视频| 久久精品国产清自在天天线| 在线视频观看日韩| 久久久久国产精品一区二区| 欧美视频一区二区| 亚洲欧美激情四射在线日| 国产综合欧美| 久久国产精品毛片| 亚洲人成网在线播放| 国产精品卡一卡二卡三| 欧美高清在线视频观看不卡| 久热精品视频| 激情校园亚洲| 久久综合一区二区三区| 欧美激情第一页xxx| 欧美18av| 亚洲影视在线播放| 久久久国产一区二区三区| 亚洲第一视频网站| 欧美 日韩 国产 一区| 国内精品免费午夜毛片| 欧美一区二区三区在线观看视频| 亚洲最快最全在线视频| 伊人久久综合| 欧美午夜宅男影院在线观看| 国产欧美精品va在线观看| 久久精品99| 欧美久久一级| 亚洲电影专区| 国产中文一区二区| 国产欧美va欧美va香蕉在| 亚洲九九九在线观看| 欧美精品久久久久久久免费观看| 国内成+人亚洲| 一本色道久久综合狠狠躁篇的优点| 亚洲日本欧美天堂| 午夜精品在线| 国产精品videosex极品| 欧美日韩精品免费观看| 亚洲在线中文字幕| 亚洲免费伊人电影在线观看av| 久久精品国产精品亚洲精品| 激情校园亚洲| 亚洲视频网在线直播| 国产精品国产三级国产专区53| 欧美日韩视频一区二区| 亚洲女性喷水在线观看一区| 久热这里只精品99re8久| 制服丝袜亚洲播放| 国产精品视频九色porn| 亚洲一区一卡| 国产在线精品一区二区夜色| 国产乱码精品一区二区三区av| 韩国三级电影一区二区| 久久久免费精品视频| 久久久久久久久久久久久久一区| 一区二区三区国产精华| 国产一区在线播放| 国内不卡一区二区三区| 久久精品女人的天堂av| 中文有码久久| 美女黄色成人网| 久久婷婷麻豆| 日韩视频一区二区在线观看| 伊人色综合久久天天五月婷| 亚洲风情在线资源站| 欧美日韩国产欧美日美国产精品| 欧美国产精品一区| 狠狠色丁香久久婷婷综合丁香| 午夜精品网站| 136国产福利精品导航网址应用| 午夜精品久久久久久久99樱桃| 亚洲欧洲在线观看| 国产日韩在线一区二区三区| 久久久久成人精品免费播放动漫| 久久亚洲电影| 亚洲精品一区二区三区在线观看| 一本大道久久精品懂色aⅴ| 国产美女精品人人做人人爽| 欧美激情麻豆| 亚洲乱码国产乱码精品精天堂| 香蕉久久夜色精品国产使用方法| 午夜亚洲精品| 久久这里只精品最新地址| 久热成人在线视频| 一区精品在线播放| 香蕉国产精品偷在线观看不卡| 日韩视频一区二区三区在线播放免费观看| 国产精品女主播| 免费成人小视频| 久久综合网络一区二区| 久久久久女教师免费一区| 国产亚洲欧美激情| 1024精品一区二区三区| 欧美激情一区三区| 欧美成年人网| 久久综合九色欧美综合狠狠| 麻豆亚洲精品| 国产精品一国产精品k频道56| 欧美精品在线一区二区三区| 欧美日韩你懂的| 美女诱惑一区| 国内精品久久久久久久影视蜜臀| 国产精品欧美日韩| 亚洲午夜精品国产| 狠狠综合久久av一区二区小说| 久久久精品视频成人| 亚洲黄色成人久久久| 亚洲欧美一区二区三区极速播放| 亚洲激情成人网| 亚洲高清资源综合久久精品| 亚洲图片欧洲图片av| 国产日韩欧美亚洲| 国产精品影片在线观看| 国产老女人精品毛片久久| 国产精品免费福利| 好看的日韩视频| 免费人成网站在线观看欧美高清| 亚洲一区二区在线观看视频| 亚洲美女中出| 在线观看中文字幕亚洲| 欧美黄污视频| 日韩性生活视频| 国产视频精品va久久久久久| 国产精品视频久久一区| 欧美日韩国产小视频在线观看| 久久婷婷久久| 欧美福利一区二区三区| 日韩系列在线| 老司机午夜精品| 欧美国产精品日韩| 99成人免费视频| 亚洲一区二区三区免费在线观看| 亚洲国产欧美一区二区三区丁香婷| 91久久国产综合久久| 亚洲综合丁香| 欧美freesex交免费视频| 国产欧美韩日| 亚洲资源在线观看| 欧美在线国产| 亚洲精品国产精品乱码不99按摩| 国产精品久久久久久一区二区三区| 欧美色网在线| 亚洲激精日韩激精欧美精品| 国产裸体写真av一区二区| 欧美丝袜一区二区| 国产精品入口夜色视频大尺度| 欧美激情中文字幕乱码免费| 国产亚洲成精品久久|