在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 7042|回复: 5

[求助] 正弦信号源如何调节峰峰值?(FPGA+PWM+DDS实现)

[复制链接]
发表于 2016-7-28 22:34:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
本帖最后由 fangzr 于 2016-7-30 16:37 编辑

最近想了好一阵子这个课程设计,谢谢各位帮助,解决了频率调节问题,但是我不是很理解如何调节输出信号峰峰值0.1V~2V

有人说“在正弦值乘上幅度系数来缩放”,但是我直接修改dds的out,结果综合分析出现时序不满足的问题 1.png


就是这样: Out <= (sinTable[addr[PHASE_W - 1 : PHASE_W - TABLE_AW]])/20*Amplitude;//Amplitude是我在top用按键可调的reg

最后下载到xilinx板子上,用ILA调试的结果很奇怪,之前没加上调幅的amplitude还是正弦波。。。
波形.png


最后贴上问题源代码吧!




  1. module dds
  2. #(
  3.     parameter PHASE_W = 24,
  4.     parameter DATA_W = 12,
  5.     parameter TABLE_AW = 12,
  6.     parameter MEM_FILE = "SineTable.dat"
  7. )
  8. (
  9.     input [PHASE_W - 1 : 0] FreqWord,
  10.     input [PHASE_W - 1 : 0] PhaseShift,
  11.     input Clock,
  12.     input ClkEn,
  13.     input   [5:0]Amplitude,   //amplitude control
  14.     output reg signed [DATA_W - 1 : 0] Out
  15. );

  16.     reg signed [DATA_W - 1 : 0] sinTable[2 ** TABLE_AW - 1 : 0]; // Sine table ROM
  17.     reg [PHASE_W - 1 : 0] phase; // Phase Accumulater
  18.     wire [PHASE_W - 1 : 0] addr = phase + PhaseShift; // Phase Shift
  19.    
  20.     initial
  21.     begin
  22.         phase = 0; Out = 0;
  23.         $readmemh(MEM_FILE, sinTable); // Initialize the ROM
  24.     end
  25.    
  26.     always@(posedge Clock)
  27.     begin
  28.         if(ClkEn)
  29.             phase <= phase + FreqWord;
  30.     end
  31.    
  32.     always@(posedge Clock)
  33.     begin
  34.         if(ClkEn)
  35.             Out <= (sinTable[addr[PHASE_W - 1 : PHASE_W - TABLE_AW]])/20*Amplitude; // Look up the table
  36.     end
  37.    
  38. endmodule


复制代码
 楼主| 发表于 2016-7-29 07:46:59 | 显示全部楼层
本帖最后由 fangzr 于 2016-7-30 16:42 编辑

相关源代码: 搜狗截图20160730163857.png

搜狗截图20160730164113.png

搜狗截图20160730163920.png
 楼主| 发表于 2016-7-30 17:09:05 | 显示全部楼层
完全不理解,为什么直接在verilog对out乘除就会让它时序不满足
发表于 2016-7-31 23:55:22 | 显示全部楼层
你的查找表内容少了一个点吧,比如四分之一周期是512个点,你应该按照513个点来实现。细节你多考虑下
 楼主| 发表于 2016-8-3 12:37:21 | 显示全部楼层
回复 4# hector_wu


   时序不满足是因为时钟要跑100M,不能简单用除法,而是应该用位移运算符
 楼主| 发表于 2016-8-3 12:40:56 | 显示全部楼层
我的问题其实应该是这样的:我的信号发生器不用硬件的增益反馈,而是通过乘法器将输出幅度控制!但是现在是左位移会丢失高位,只能右位移,意味着只有小于或等于1Vpp的值
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-11-24 21:22 , Processed in 0.026023 second(s), 10 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表