dds原理相关书,DDS原理及实现(总6页).doc

资源说明:

《DDS原理及实现(总6页).doc》由会员分享,可在线阅读,更多相关《DDS原理及实现(总6页).doc(6页珍藏版)》请在新文库网上搜索。

1、1 DDS原理简介数字频率合成器(Direct Digital Synthesizer)是从相位概念出发直接合成所需波形的一种频率合成技术。一个直接数字频率合成器由相位累加器、加法器、波形存储ROM、D/A转换器和低通滤波器(LPF)构成。DDS的原理框图如图1.2所示:图1.2 DDS原理框图其中K为频率控制字、P为相位控制字、W为波形控制字、为参考时钟频率,N为相位累加器的字长,D为ROM数据位及D/A转换器的字长。相位累加器在时钟的控制下以步长K作累加,输出的N位二进制码与相位控制字P、波形控制字W相加后作为波形ROM的地址,对波形ROM进行寻址,波形ROM输出D位的幅度码S(n)经过D

2、/A转换器变成阶梯波S(t),再经过低通滤波器平滑后就可以得到合成的信号波形。合成的信号波形的形状取决于波形ROM中存放的幅度值,因此用DDS可以产生任意波形。这里我们用DDS实现正弦波的合成。A) 频率预置与调节电路K被称为频率控制字,也叫相位增量.DDS方程为: ,为输出频率,为时钟频率。当K=1时,DDS输出最低频率(也即频率分辨率)为,而DDS的最大输出频率由Nyquist采样定理决定,即,也就是说K最大值为。因此,只要N足够大,DDS可以得到很细的频率间隔。要改变DDS的输出频率,只要改变频率控制字K即可。B) 累加器 相位累加器由N位加法器与N位寄存器级联构成。每来一个时钟脉冲,加

3、法器将频率控制字K与寄存器输出的累加相位数据相加,再把相加后的结果送至寄存器的数据输入端。寄存器将加法器在上一个时钟作用后所产生的相位数据反馈到加法器的输入端;以使加法器在下一个时钟的作用下继续与频率控制字进行相加。这样,相位累加器在时钟作用下,进行相位累加。当相位累加器累加满量里就会产生一次溢出,完成一个周期性的动作。C) 控制相位的累加器通过改变相位控制字P可以控制输出信号的相位参数。令相位加法器的字长为N,当相位控制字由0跃变到P(P0)时,波形存储器的输入为相位累加器的输出与相位控制字P之和,因而其输出的幅度编码相位会增加,从而使最后输出的信号产生相移。D) 控制波形的加法器通过改变波

4、形控制字W可以控制输出信号的波形。由于波形存储器中的不同波形是分块存储的,所以当波形控制字改变时,波形存储器的输入为改变相位后的地址与波形控制字W(波形地址)之和,从而使最后输出的信号产生相移。E)波形存储器用相位累加器输出的数据作为波形存储器的取样地址,进行波形的相位幅值转换,即可以给定的时间上确定输出的波形的抽样幅值。N位的寻址ROM相当于把0360的正弦信号离散成具有个样值的序列,若波形ROM有D位数据位,则个样值的幅值以D位二进制数值固化在ROM中,按照地址的不同可以输出相应相位的正弦信号的幅值。E) D/A转换器D/A转换器的作用是把合成的正弦波数字量转换成模拟量。正弦幅度量化序列S

5、(n)经D/A转换后变成了包络为正弦波的阶梯波S(t)。需要注意的是,频率合成器对D/A转换器的分辨率有一定的要求,D/A转换器的分辨率越高,合成的正弦波S(t)台阶数就越多,输出波形的精度也就越高。F) 低通滤波器对D/A输出的阶梯波S(t)进行频谱分析,可以S(t)中除了主频外,还相存在分布在,2两边正负处的非谐波分量,幅值包络为辛格函数。因此,为了取出主频,必须在D/A转换器的输出端接入截止频率为/2的低通滤波器。2 FPGA 的DDS载波实现方法实现通信中不少信道都不能直接传送基带信号,必须用基带信号对载波波形的某些参量进行控制,使载波的这些参量随基带信号的变化而变化,即所谓正弦载波调

6、制。从原理上来说,受调载波的波形可以是任意的,只要已调信号适合于信道传输就可以了。但实际上,在大多数数字通信系统中,都选择正弦信号作为载波。这是因为正弦信号形式简单,便于产生及接收。方法一:用ROM核来实现 说明:将载波一个周期的采样值直接写入V代码中的,而不是用ROM核。(利用ROM核需要将载波一个周期的采样值写入COE文件中,插入ROM核中) 优点:用不同的初始值寻址可以输出不同频率和不同初始相位的载波。方法二:用DDS核来实现 优点:频率和初始相位都可以任意设定。 缺点:在使用时比较难控制方法三:用Sine-Cosine Look-up Table核来实现l 代码:module sine

7、_cosine(clk,reset,in_rdy,desine,decosine,out_rdy); input clk,reset,in_rdy; output 7:0 desine,decosine; output out_rdy; wire out_rdy; wire RFD,RDY; reg ND; reg3:0 THETA;always (posedge clk)beginif(reset) begin ND=0;THETA=0;end else if(in_rdy) begin THETA=THETA+1; ND=in_rdy; end end、/核例化 sinecosine si

8、necosine( .THETA(THETA), / Bus 3 : 0 .CLK(clk), .SCLR(reset), .ND(ND), .RFD(RFD), .RDY(out_rdy), .SINE(desine), / Bus 7 : 0 .COSINE(decosine); / Bus 7 : 0 endmodulel 仿真图: 第一路为正弦波,第二路为余弦波l 说明:可以对THETA赋不同初始值即可以实现不同初始相位的载波。 此正弦波和余弦波一个周期是采样16个点,可以在IP核进行参数设置修改的。其频率为,输出位宽为8位宽。优点:载波频率是时钟频率的 其中N在IP核中可设置,设置很

9、简单,初始相位也可以通过修改THETA参数来实现,实现起来很方便。也比较容易控制。方法四:将载波一个周期的采样点值写入代码中来实现。l 代码:module sine(clk,reset,en,out_rdy,out);input clk,reset,en;output out_rdy;output 7:0 out;reg out_rdy;reg 7:0 out;reg2:0 addr;always (posedge clk)begin:initial_controlif(reset) begin addr=3d0; endelse if(en) begin addr=addr+1; enden

10、dalways (posedge clk)begin:Red_sigif(en) case(addr) 4d0:begin out=8d45;out_rdy=1; end 4d1:begin out=8d64;out_rdy=1; end 4d2:begin out=8d45;out_rdy=1; end 4d3:begin out=8d0;out_rdy=1; end 4d4:begin out=8d211;out_rdy=1;end 4d5:begin out=8d192;out_rdy=1; end 4d6:begin out=8d211;out_rdy=1; end 4d7:begin

11、 out=8d0;out_rdy=1; end endcase endendmodulel 仿真图:l 说明:此正弦载波一个周期是采样8个点,即频率为 其输出位宽为8位宽。 若想产生余弦载波的话,只需将Red_sig中out的值改变即可。 优点:与模块使能信号en同时输出,没有延时。在设计调制解调时,不用设计基带信号与载波同步。相对于用核产生要方便一些,因为用核产生时,因为设置了握手信号,载波较使能信号都有固定时间的延时,例如用Sine-Cosine Look-up Table核来实现载波时,一般都有2或3个系统时钟的延时,致使载波与基带信号不同步,需将基带信号延时以使两路信号同步。 缺点:若载波的一个周期采样多个点的话,将采样值直接写入V代码中,就有点麻烦了。

DDS原理及实现(总6页).doc-新文库网DDS原理详细介绍_DDS原理-嵌入式文档类资源-CSDN文库DDS原理(中文介绍)_dds技术原理-电信文档类资源-CSDN文库数字信号发生器原理.pdf-数据挖掘文档类资源-CSDN文库课件:DDS原理与应用.ppt直接数字频率合成(DDS)基本原理-面包板社区(EDA)基于FPGA的DDS信号源设计说明书.doc简述DDS原理及其基于FPGA的实现 - 21ic电子网基于FPGA的DDS信号发生器设计 - FPGA/ASIC技术 - 电子 ...800多套单片机毕业设计Vivado 滤波器使用(一)C++进阶学习 FPGA 经验与书籍分享转载的java面试题(值得推荐)锁相环环路滤波器分析单片机应用技术选编(6).(北航出版.何立民)【.Net Framework 体积大?】不安装.net framework 也能运行!?原理简介-2(补充)...学习 FPGA 经验与书籍分享。直接数字频率合成+白居宪编著 淘宝买的,网上找不到下载二阶数字锁相环仿真(内附MATLAB代码)软件定义汽车 新一代技术发展电路中的信噪比相关云数据迁移(Cloud Data Migration,CDM)沉迷机器人操作系统的一个理由和四种修仙秘籍(更新ROS 2.0内容)自动驾驶技术笔记:ROS系统“领导力培训”纪要整理基于51单片机的函数信号发生器ROSCon 2019 机器人操作系统国际盛会FPGA嵌入式项目开发实战 随光盘…基于Xilinx Artix7的PCB设计总结使用MATLAB一键制作mif文件关于高速AD/DAC测量及设计中82个疑难问题的解答周问题回复:20180624使用ROS2和Autoware的自动驾驶汽车免费在线进阶课 译值得关注的开源软件推荐现代DSP技术(面向21世纪高等学校信息工程类专业系列教材)
超级经典好看的现代重生小说很纯很美好漫画下拉式酷漫屋中文在线股票为什么跌跌不休歌手栾树多大了邮箱管理功能大全萝卜的卜是几声英雄事迹的感想50字高端情侣网名英文网名三星scx 4321怎么加粉全身肌肉萎缩是什么病废物利用改造书桌