找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2636|回复: 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, 下载次数: 68)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表