找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

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

[復制鏈接]
跳轉到指定樓層
樓主
ID:344546 發(fā)表于 2020-5-30 11:59 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
基于FPGA的信號發(fā)生器,四種波形可調,頻率相位可調,(1-999999hz)(幅度+-5V)正弦 三角 方波 鋸齒這里使用了某寶的高速的DA模塊。所以是在數據發(fā)送的時候是并行發(fā)送的,至于輸出-+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空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表