找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1179|回复: 0
打印 上一主题 下一主题
收起左侧

DDS AM FM

[复制链接]
跳转到指定楼层
楼主
ID:365577 发表于 2018-7-5 14:09 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
module DDS
(
input clk,
input rst_n,
output [15:0]SineOut,
input wire [31:0] KW//=32'd42950//1KHZ
);
// fc = 100MHz
//输出频率 fo = 1kHz(根据需要可以设为任意值)
//控制参数 KW  = (fo*2^N)/fc = 42950
//参数 N = 2^32,(32为计数器的位宽)
//****************************************/
//wire [31:0] KW=32'd42950;//1KHZ
wire [15:0] Sine;
DDS_Core DDS_Core_inst
(
.clk(clk) , // input  clk_sig
.rst_n(rst_n) , // input  rst_n_sig
.KW(KW) , // input [31:0] KW_sig
.Sine(Sine)  // output [15:0] Sine_sig
);
assign SineOut=Sine+16'h8000;//有符号

endmodule



module DDS_Core
(
input clk,
input rst_n,
input [31:0] KW,
output [15:0] Sine
);
reg [31:0] cnt;
always @(posedge clk,negedge rst_n)
  begin
   if(!rst_n) cnt<=32'd0;
   else cnt<=cnt+KW;
  end
wire [13:0] addr=cnt[31:18];
dds_rom dds_rom_inst (
.address ( addr),
.clock ( clk ),
.q ( Sine )
);
endmodule

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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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