久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3147|回復: 0
打印 上一主題 下一主題
收起左側

基于FPGA的DDS調幅信號發生器程序,四種波形可調,頻率相位可調,(1-999999hz)(...

[復制鏈接]
跳轉到指定樓層
樓主
基于FPGA的信號發生器,四種波形可調,頻率相位可調,(1-999999hz)(幅度+-5V)正弦 三角 方波 鋸齒這里使用了某寶的高速的DA模塊。所以是在數據發送的時候是并行發送的,至于輸出-+5是模塊自身集成了放大器和減法器使得移動到-+5

源程序如下:
  1. `timescale 1ns / 1ps
  2. //////////////////////////////////////////////////////////////////////////////////
  3. // Company:
  4. // Engineer:
  5. //
  6. // Create Date:    15:17:29 05/31/2019
  7. // Design Name:
  8. // Module Name:    FV
  9. // Project Name:
  10. // Target Devices:
  11. // Tool versions:
  12. // Description:
  13. //
  14. // Dependencies:
  15. //
  16. // Revision:
  17. // Revision 0.01 - File Created
  18. // Additional Comments:
  19. //
  20. //////////////////////////////////////////////////////////////////////////////////
  21. module FV(
  22.         Clk,
  23.         Rst_n,
  24.         k6,
  25.         k5,
  26.         k4,
  27.         k3,
  28.         FV_word
  29. );
  30.         input Clk;
  31.         input Rst_n;
  32.         input k6;
  33.         input k5;
  34.         input k4;
  35.         input k3;
  36.         output [7:0]FV_word;
  37.         
  38.         reg[3:0]ge,shi;
  39.         /*----------按鍵模塊實例化-------*/        
  40.         //k5 個位 +
  41.         wire key_flag, key_state;
  42.         key_filter key_filter0(
  43.                 .Clk(Clk),
  44.                 .Rst_n(Rst_n),
  45.                 .key_in(k5),
  46.                 .key_flag(key_flag),
  47.                 .key_state(key_state)
  48.         );
  49.         //k6 個位  -
  50.         wire key_flag1, key_state1;
  51.         key_filter key_filter1(
  52.                 .Clk(Clk),
  53.                 .Rst_n(Rst_n),
  54.                 .key_in(k6),
  55.                 .key_flag(key_flag1),
  56.                 .key_state(key_state1)
  57.         );
  58.         always@(posedge Clk or negedge Rst_n)begin
  59.         if(!Rst_n)
  60.                 ge <= 4'd1;
  61.         else if(key_flag && (!key_state))begin
  62.                 if((shi!=0))begin
  63.                         if(ge==4'd10)begin
  64.                                 ge <=ge;
  65.                         end
  66.                         else begin
  67.                                 ge <= ge + 1'b1;
  68.                         end
  69.                 end        
  70.                 else if(ge==4'd10)begin
  71.                         ge <=ge;
  72.                 end
  73.                 else begin
  74.                         ge <= ge + 1'b1;
  75.                 end        
  76.         end
  77.         else if(key_flag1 && (!key_state1))begin
  78.                 if((shi!=0))begin
  79.                         if(ge==4'd1)begin
  80.                                 ge <= ge;
  81.                         end
  82.                         else begin
  83.                                 ge <= ge - 1'b1;
  84.                         end
  85.                 end        
  86.                 else if(ge==4'd1)begin
  87.                         ge <= ge;
  88.                 end
  89.                 else begin
  90.                         ge <= ge - 1'b1;
  91.                 end        
  92.         end
  93.         else
  94.                 ge <= ge;               
  95.         end
  96.         
  97.         //k4
  98.         wire key_flag0, key_state0;
  99.         key_filter key_filter2(
  100.                 .Clk(Clk),
  101.                 .Rst_n(Rst_n),
  102.                 .key_in(k3),
  103.                 .key_flag(key_flag0),
  104.                 .key_state(key_state0)
  105.         );
  106.         wire key_flag2, key_state2;
  107.         key_filter key_filter3(
  108.                 .Clk(Clk),
  109.                 .Rst_n(Rst_n),
  110.                 .key_in(k4),
  111.                 .key_flag(key_flag2),
  112.                 .key_state(key_state2)
  113.         );
  114.         
  115.         always@(posedge Clk or negedge Rst_n)begin
  116.         if(!Rst_n)
  117.                 shi <= 4'd0;
  118.         else if(key_flag0 && (!key_state0))begin
  119.                 if(shi==4'd9)begin
  120.                         shi <=shi;
  121.                         end
  122.                 else begin
  123.                         shi <= shi + 1'b1;
  124.                 end        
  125.         end
  126.         else if(key_flag2 && (!key_state2))begin
  127.                 if(shi==4'd0)begin
  128.                         shi <=shi;
  129.                         end
  130.                 else begin
  131.                         shi <= shi - 1'b1;
  132.                 end        
  133.         end
  134.         else
  135.                 shi <= shi;               
  136.         end
  137.         /*----------幅度控制-------*/
  138.         assign FV_word=ge*5+shi*21'd10;
  139. endmodule
復制代碼

所有資料51hei提供下載:
FPGADDS調幅.7z (4.22 MB, 下載次數: 75)

評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 久久久久久久电影 | 久久999 | 中文字幕综合 | 精产嫩模国品一二三区 | 最新日韩在线视频 | 中文字幕在线免费观看 | 天天干天天操天天射 | 欧美综合网| 欧美精品一区二区三区四区 在线 | 精品www | 欧美一区2区三区4区公司二百 | 一区在线播放 | 成人在线精品 | 黄免费在线| 欧美 日韩 中文 | 亚洲精品免费视频 | 91社区在线观看播放 | 亚洲免费久久久 | 91在线视频国产 | 一级看片免费视频 | 久久国产精品一区 | 中文字幕免费视频 | 国产精品一码二码三码在线 | 久久99精品久久久久久国产越南 | 欧美成人在线免费 | 久久国产精品视频 | 成人免费视频观看视频 | 精品日韩 | 在线视频国产一区 | 国产在线观看免费 | 国产亚洲一区二区三区在线 | 婷婷综合色 | 日韩成人中文字幕 | 国产精品成人一区二区三区 | 911精品国产| 精品久久久久久久久久久久久久 | 久久久久久久一区二区 | 免费三级黄 | 日韩成人性视频 | 精品视频在线观看 | 懂色tv|