[FPGA] ISE DDS IP核简单记录使用

需要使用DDS IP核生成正弦波进行仿真验证,简单记录一下使用方法。

右键项目选择New Source。

先选择添加IP核,然后命令文件名,最后选择存放路径。

搜索框中搜索DDS会出来很多DDS Compiler,但其实只有两个一个是DDS Compiler 4.0(老版本,适合没有AXI总线的),另一个是DDS Compiler 5.0(新版本,适合给Zynq带AXI总线的系统用的)。选择4.0即可。

Configuration Options:

  • DDS 的工作模式,决定 IP 核内部有哪些模块、输出哪些信号。
    • Phase Generator and SIN COS LUT:包含相位累加器 + 正弦 / 余弦查找表,直接输出 SINE 和 COSINE 两路信号
    • Phase Generator only:只输出相位地址,不包含正弦 / 余弦 LUT,需要自己外接 ROM
    • SIN COS LUT only:只有正弦 / 余弦 LUT,需要自己给相位输入

System Clock:DDS IP 的工作时钟频率,单位 MHz

Number of Channels:同时生成的载波通道数

Frequency per Channel (Fs):采样率

Parameter Selection:我选择的是Hardware Parameters,需要设置相位累加器位宽Phase Width,输出位宽Output Width。

Phase Increment Programmability:能不能动态改频率的选项

  • Fixed:频率固定,IP 在生成时就把频率控制字烧进去了,运行时不能改
  • Programmable:运行时可以通过寄存器接口动态修改频率
  • Streaming:通过数据流接口实时更新频率

Phase Offset Programmability:能不能动态调整载波相位

  • None:不使用相位偏移,相位固定为 0。
  • Fixed:固定相位偏移,IP 生成时配置好。
  • Programmable:运行时可以动态修改相位。

Output Selection:IP 输出哪些波形信号

  • Sine and Cosine:同时输出正弦和余弦信号。
  • Sine:只输出正弦信号。
  • Cosine:只输出余弦信号。

Polarity:极性

  • Negative Sine :输出-sin(θ)
  • Negative Cosine :输出-cos(θ)

Amptitude Mode:幅度模式

  • Full Range:输出使用完整的有符号数范围,如12位,范围就是-2048~+2047
  • Unit Circle: 输出的数值是归一化的,范围大约是 -1 ~ +1

我不需要相位输出,将Has Phase Out取消。

这里不需要设置,因为Phase Increment Programmability选的Programmable,可以例化的时候传参进去。

这里的Frequency Resolution要注意,这是频率分辨率,具体运算是20M/(2^16)

例化:

cpp 复制代码
`timescale 1ns / 1ps
module data(
	input clk,
	output signed [11:0] d_out
	);

	wire signed [11:0] sine_0_5, sine_2;
	 

	wave(
	  .clk(clk), // input clk
	  .we(1'b1), // input we
	  .data(16'd3277), // 1MHz
	  .sine(sine_2) // output [11 : 0] sine
	);
	

endmodule

3277这么计算出来,要生成1M的波形,1M/频率分辨率 = 1M / (20M/(2^16));等于3277,实际生成的频率为3277 * (20M/(2^16) = 1000061.03515625,如果想要更准,那么就提升system clock和Phase Width

相关推荐
坏孩子的诺亚方舟3 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐3 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐3 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH4 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
zlinear数据采集卡4 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安4 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐5 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯5 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客5 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c
Hello-FPGA5 天前
Xilinx KU040 FPGA Camera Link 图像采集
c++·fpga开发