OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6755|回复: 7

[ALTERA] 关于DDS驱动DAC芯片的困惑

[复制链接]

12

主题

16

帖子

0

精华

新手上路

积分
25
金钱
25
注册时间
2019-12-8
在线时间
11 小时
发表于 2020-7-27 13:06:25 | 显示全部楼层 |阅读模式
3金钱
请问我通过dds得到的正弦数据给dac 为什么改变幅值的时候会出现如下的情况 1.jpg 2.jpg
SET_Data[15:0]   <= 16'd32768 + ( SIN_DATA - 16'd32768 ) / 5 (这个数修改幅值);我使用这句代码修改幅值,有的波形没有问题 但有的就很奇怪

最佳答案

查看完整内容[请看2#楼]

哈哈没啥 我那个是仿真时的一点小问题 你这个的话 我猜你的sin_data应该是0-65535吧, 你想的是让他以327568为中值进行两边数值的扩散,可是fpga是不认识负数的你的sin_data在0-32767之间时,sin_data-32768你以为是负的 但是实际上fpga认定的是正值,并且这个正值随着sin_data的增大而增大 等sin_data到了32768时,瞬间变为零了 就产生了第一个波形中的突变,我是这么认为的 不知道对不对 你可以仿真康康set_data的值{:3_45 ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
126
金钱
126
注册时间
2019-12-13
在线时间
23 小时
发表于 2020-7-27 13:06:26 | 显示全部楼层
xu123321 发表于 2020-7-27 13:47
麻烦可以讲的详细一点吗,十六进制和十进制指的是sin.mif文件存储的类型吗?

哈哈没啥 我那个是仿真时的一点小问题   你这个的话 我猜你的sin_data应该是0-65535吧, 你想的是让他以327568为中值进行两边数值的扩散,可是fpga是不认识负数的你的sin_data在0-32767之间时,sin_data-32768你以为是负的 但是实际上fpga认定的是正值,并且这个正值随着sin_data的增大而增大  等sin_data到了32768时,瞬间变为零了 就产生了第一个波形中的突变,我是这么认为的  不知道对不对 你可以仿真康康set_data的值
回复

使用道具 举报

4

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
126
金钱
126
注册时间
2019-12-13
在线时间
23 小时
发表于 2020-7-27 13:30:39 | 显示全部楼层
我在做dds仿真的时候  如果最终的波形选择十六进制也会出现第一张图的情况  十进制 就正常  其中波形不正常时 那个跳变的部分 刚好是128 1000_0000,感觉和溢出有点关系
回复

使用道具 举报

12

主题

16

帖子

0

精华

新手上路

积分
25
金钱
25
注册时间
2019-12-8
在线时间
11 小时
 楼主| 发表于 2020-7-27 13:47:07 | 显示全部楼层
爱吃萝卜的柯基 发表于 2020-7-27 13:30
我在做dds仿真的时候  如果最终的波形选择十六进制也会出现第一张图的情况  十进制 就正常  其中波形不正常 ...

麻烦可以讲的详细一点吗,十六进制和十进制指的是sin.mif文件存储的类型吗?
回复

使用道具 举报

12

主题

16

帖子

0

精华

新手上路

积分
25
金钱
25
注册时间
2019-12-8
在线时间
11 小时
 楼主| 发表于 2020-7-27 14:44:04 | 显示全部楼层
爱吃萝卜的柯基 发表于 2020-7-27 14:36
哈哈没啥 我那个是仿真时的一点小问题   你这个的话 我猜你的sin_data应该是0-65535吧, 你想的是让他以3 ...

哇,非常感谢,您说的很有道理,我现在就想想该如何解决这个问题
回复

使用道具 举报

12

主题

16

帖子

0

精华

新手上路

积分
25
金钱
25
注册时间
2019-12-8
在线时间
11 小时
 楼主| 发表于 2020-7-27 14:56:55 | 显示全部楼层
爱吃萝卜的柯基 发表于 2020-7-27 14:36
哈哈没啥 我那个是仿真时的一点小问题   你这个的话 我猜你的sin_data应该是0-65535吧, 你想的是让他以3 ...

是不是我编写代码的时候  不要出现小数减大数得到负值这种情况就好了呀
回复

使用道具 举报

4

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
126
金钱
126
注册时间
2019-12-13
在线时间
23 小时
发表于 2020-7-27 15:00:50 | 显示全部楼层
xu123321 发表于 2020-7-27 14:56
是不是我编写代码的时候  不要出现小数减大数得到负值这种情况就好了呀

对sin_data进行一个大小判定 大于32768时 sin_data-32768小于时反过来   我比较好奇 为社么第二张波形是正常的 按理说 不会正常的
回复

使用道具 举报

3

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
80
金钱
80
注册时间
2018-6-7
在线时间
15 小时
发表于 2020-7-31 11:24:59 | 显示全部楼层
有符号的数据,传给无符号的DA,需要把数据转换一下
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-10-3 13:29

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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