跳转到主要内容

数字信号处理(一):Xilinx Vivado DDS IP核设计实例

judy 提交于

本文转载自:<span id="profileBt"><a href="https://blog.csdn.net/gslscyx/article/details/104024041?spm=1001.2014.3…技术实战的CSDN博客</a></span>

<strong>前言</strong>
在数字信号处理时我们经常会用到数字变频,包数字下变频(DDC)和数字上变频(DUC),这其中会用到Xilinx公司的DDS IP核或者Altera公司的NCO IP核来产生本振频率,以现数字域信号频谱搬移。本文我们通过例化Xilinx公司的DDS IP核来产生混频器本振输入频率,并给出Modelsim仿真测试结果。

<strong>1、Xilinx DDS IP简介</strong>
Xilinx公司的DDS IP核使用AXI4接口实现高性能、优化的相位产生和正弦波电路。
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图1、DDS IP核架构</strong></p>

在图1中我们看到DDS IP核主要包括5部分组成,其中DDS核心为相位累加器(标记1所示)和LUT查找表(标记2所示)。相位累加器实现查找表地址的产生,LUT查找表用来存储输出波形。图1标记3部分为抖动产生器和泰勒级数矫正产生模块,主要用来改善SFDR,两者改善的效果、使用的逻辑资源存在差异。标记4部分则为AXI4接口,实现相位累加字配置,多通道配置,相位累加器输出和波形数据输出。标记5部分则在多通道DDS输出时使用。 DDS IP核可以配置为三种模式:相位产生器、SIN/COS LUT或者相位累加器和SIN/COS LUT(即DDS)。

<strong>2、DDS IP核工程例程及仿真测试</strong>
本例程例化两个IP,一个实现单通道DDS输出,一个实现4通道DDS输出,用于对比测试单通道和多通道DDS IP差异以及了解如何进行参数配置。参数配置表如下所示。
|IP核模式 | 系统时钟 | SFDR | 频率分辨率 | 输出频率 | 相位累加器 |
| 单通道 | 100MHz | 110dB | 0.4Hz | 1MHz | Fixed |
| 四通道 | 100MHz | 110dB | 0.4Hz | 1MHz | Programable |

<strong>2.1 单通道DDS IP核参数配置</strong>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图2</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图3</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图4</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图5</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图6</strong></p>

<strong>2.2 四通道DDS IP核参数配置</strong>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图7</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图8</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图9</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图10</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图11</strong></p>

<strong>2.3 Vivado 工程建立及FPGA代码编写</strong>
DDS测试FPGA工程结构及部分代码如图11、12所示。
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图12、DDS工程结构</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图13</strong></p>

<strong>2.4 Vivado仿真测试文件编写</strong>
仿真文件代码编写
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图14、仿真测试文件代码</strong></p>

<strong>2.5 Modelsim仿真测试</strong>
利用Modelsim软件联合Vivado软件仿真,测试结果如图所示。
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图15、 单通DDS输出</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图16、多通道DDS配置字时序</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2022-08/%E5%8D%9A%E5%AE%A2/100563231-26…; alt=""></center>
<p align="center"><strong>图17、四通道DDS波形输出</strong></p>

<strong>3、总结</strong>
Xilinx DDS核经常在数字变频及软件无线电调制解调中应用,我们可以利用IP核来实现,也完全可以自己编写HDL语言来实现复杂波形的产生。对于DDS的实现原理,网络有非常丰富的资料可以查找学习,本文不再详细阐述。