找回密码
 注册
关于网站域名变更的通知
查看: 144|回复: 3
打印 上一主题 下一主题

基于FPGA的DDS设计方案介绍

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2022-8-15 11:01 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

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

x
1、DDS技术简介
. X; B! U/ a  I( D* D' y2 q: T# H●随着电子技术的不断发展,传统的频率合成技术逐渐不能满足人们对于频率转换速度、频率分辨率等方面的追求,直接数字频率合成技术应运而生。
- B6 i9 H/ y  }! O' b9 ~. Y5 d●直接数字频率合成技术(DDS) 是把一系列数据量形式的信号通过D/A转换器转换成模拟量形式的信号合成技术。DDS具有很多优点,比如:频率转换快、频率分辨率高、相位连续、低功耗、低成本与控制方便。0 @7 `( H" I( H0 t4 v4 h: k" P
●DDS技术满足了人们对于速度稳定性的需求,但是在一些控制较为复杂的系统中,DDS专用芯片不能很好的贴合要求。利用现场可编程门阵列(FPGA)实现DDS具有很大的灵活性,基本能满足现在通信系统的使用要求。
! D1 ^& ~& G& z# ]. g2 \! r4 ~" y) i; d+ A1 w
2、DDS结构原理  L, B+ `4 f! i; F8 O
2.1 基本结构( ?1 G8 M! d0 |7 L7 `! L: ^, k; W
DDS基本结构框图主要由参考频率源、相位累加器、ROM查找表、DAC转换器、低通滤波器等构成。
* K& Z$ W% X4 g8 w5 D 2 N# M7 h( s  j3 D
相位累加器以一定的步长做累加, 而波形函数存储在ROM查找表中, 将相位累加器输出的相位值作为地址,寻找存储在ROM查找表中的波形函数的幅度值,从而完成相位到幅值的转换。其中,参考频率源一般是一个晶体振荡器,要求具有高稳定性,用于DDS中各部件之间的同步。5 b4 _' C0 F+ o: }" w7 Q
% C9 f; Z# @+ D
2.2 基本原理
) V, R0 ^2 \4 V2 Y # x* R( O" L7 f+ }- h
上图为DDS Core结构图,∆θ是相位增量(对应图1中的频率控制字K),B∆θ 为相位累加器的位数,clk是参考时钟(对应图1中的参考频率源),A1、D1构成积分器(相位累加器),θ(n)是相位累加器输出的相位,Q1为量化器,用于将相位累加器位数与查找表地址之间的匹配,ϑ(n)为查找表输入地址,Bϑ(n) 为查找表输入地址位数,T1为查找表。
2 A2 t6 i% Z& Y# s下面介绍DDS设计过程中常用到的公式,主要是输出频率公式及其变形。6 a- z! @1 Y; k4 r
* r6 `' h, I3 B+ m7 q

; W' i( G) s5 B* D3、基于FPGA的 DDS实现
+ }8 q2 n2 M. W+ }For example:
& H$ G: e# w/ G! O  Y5 E设计一个参考时钟为100MHz,频率分辨率要求能够达到0.03Hz,输出sin信号频率为5.00000005MHz、查找表地址12位;
3 r* o$ X. Z8 |! E- V9 S理论分析:
/ B* R" W0 G- O# @已知频率分辨率∆f与参考时钟f_clk,带入相位累加器位数公式计算
  u2 [1 N( V. y# ^# i    B∆θ = 31.634318+ n% i. h4 f5 Y: b" w, x6 N- c
由于位数为整数,取整数32,所以实际的频率分辨率为
3 c8 K- `5 R) @" L2 L    ∆f = 0.023283064365386962890625Hz
& P+ e& |0 l8 {- \% Z2 P将其带入相位增量公式计算,取整数, _/ o0 Y/ V" s0 n9 u' W& ]
    ∆θ = 21474836694.7483648≈21474836, k0 ]1 j4 S% R* J
相位累加器输出32位,而查找表输入地址为12位,取相位累加器高12位作为查找表输入地址
, E0 c; c7 [1 Z
* }6 w% }  H. u7 u3.1 利用RTL实现DDS
/ h8 J' I* g" |3 `4 [使用matlab产生sin⁡(θ)数据,θϵ[0,π],点数为2^12=4096,并保存在FPGA的memory中。4 g) }1 p3 o8 P. {2 G
wid = 12;
! o0 z0 V* ^( I$ M+ ^len = 2^wid;
. B+ ~; Y; B# X9 d  m0 [& R. r- Iamp = 10000;( N6 W- V# I! f, z( P7 r
t=0:2*pi/len:2*pi - 2*pi/len;  y5 V& R+ x4 u  x* m5 M( y" z- ^
y = round(sin(t)*amp);0 C' E# U3 p% d& ^# z0 G
plot(y);& O& B% g& V  k4 e/ v) \
相位累加器就是一个积分器,很容易用FPGA实现。最终FPGA仿真结果如下,clk为参考时钟,phase为相位累加器输出,addr为查找表地址,cos_i、sin_q为信号输出。
2 m! ?& r  \4 B3 Q" Y) G
# S- n5 e# _& {- C

基于FPGA的DDS设计方案.pdf

487.4 KB, 下载次数: 1, 下载积分: 威望 -5

  • TA的每日心情
    开心
    2025-10-2 15:42
  • 签到天数: 1185 天

    [LV.10]以坛为家III

    2#
    发表于 2022-8-15 11:20 | 只看该作者
    不错不错,很是美味且地道,尝鲜一下

    该用户从未签到

    3#
    发表于 2022-8-15 11:30 | 只看该作者
    谢谢楼主,实在是好东西啊

    该用户从未签到

    4#
    发表于 2022-8-15 14:16 | 只看该作者
    不错 是我想要的。
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-10-6 18:59 , Processed in 0.156250 second(s), 26 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

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