VIVADO的IP核 DDS快速使用——生成正弦波,线性调频波

本文帮助大家快速配置DDS核,并给出相应的仿真代码观察相应的波形。没有多余的讲解,先用起来再说。

DDS核产生正弦波

产生的正弦波效果如图:

是一个1M的正弦波

对IP核的配置

第一页

第二页第三页默认就行

第四页
仿真代码如下:

cpp 复制代码
module sys_sim(
    );
    
    
    // 定义信号
reg aclk_0;
wire [7:0] M_AXIS_DATA_0_tdata;
wire M_AXIS_DATA_0_tvalid;
wire [31:0] M_AXIS_PHASE_0_tdata;
wire M_AXIS_PHASE_0_tvalid;
wire [7:0] sin;
wire [7:0]cos;
// 实例化被测模块
design_1_wrapper dut (
    .M_AXIS_DATA_0_tdata(M_AXIS_DATA_0_tdata),
    .M_AXIS_DATA_0_tvalid(M_AXIS_DATA_0_tvalid),
    .M_AXIS_PHASE_0_tdata(M_AXIS_PHASE_0_tdata),
    .M_AXIS_PHASE_0_tvalid(M_AXIS_PHASE_0_tvalid),
    .aclk_0(aclk_0)
);

// 生成100MHz时钟 (周期=10ns)
initial begin
    aclk_0 = 0;
    forever #5 aclk_0 = ~aclk_0;  // 每5ns翻转一次
end


endmodule

生成单一频率的正弦波配置确实很简单,可以直接设置自己想要的频率。

DSS核产生线性调频波

下图为线性调频波的生成效果

不断的产生100HZ到100Khz的线性调频波,周期为10ms。

要生成这样的波形,IP核要做如下的配置

第一页

第二页

上面的红框是设置IP核可以在运行过程中修改输出的频率,下面的红框是把相位的输出关掉了。

第三页

仿真代码如下:

cpp 复制代码
module sys_sim(
    );

// 定义信号
reg aclk_0;
reg [31:0] S_AXIS_PHASE_0_tdata;
reg S_AXIS_PHASE_0_tvalid;
wire [15:0] M_AXIS_DATA_0_tdata;
wire M_AXIS_DATA_0_tvalid;


// 实例化被测模块
design_1_wrapper dut (
    .M_AXIS_DATA_0_tdata(M_AXIS_DATA_0_tdata),
    .M_AXIS_DATA_0_tvalid(M_AXIS_DATA_0_tvalid),
    .S_AXIS_PHASE_0_tdata(S_AXIS_PHASE_0_tdata),
    .S_AXIS_PHASE_0_tvalid(S_AXIS_PHASE_0_tvalid),
    .aclk_0(aclk_0)
);

    
    // 开始生成线性调频波
 // 参数计算
parameter TOTAL_CYCLES = 1_000_000; // 10ms @ 100MHz 这个参数设置线性调频波的周期
parameter PINC_START = 167;          //这个参数设置起始频率,计算公式为 (START_FREQ * (2**相位累加器宽度)) / 时钟频率;
parameter PINC_END = 16777;         //这个参数设置结束频率,计算公式为 (END_FREQ * (2**相位累加器宽度)) / 时钟频率;
parameter PINC_DELTA = PINC_END - PINC_START;

// 每K个周期更新一次PINC
parameter UPDATE_INTERVAL = 1000; // 这个参数设置你频率改变的速度,值越小速度越快
parameter NUM_UPDATES = TOTAL_CYCLES / UPDATE_INTERVAL;
parameter PINC_STEP = PINC_DELTA / NUM_UPDATES;



// 生成100MHz时钟 (周期=10ns)
initial begin
    S_AXIS_PHASE_0_tdata <= 167;
    S_AXIS_PHASE_0_tvalid<=1;
    aclk_0 = 0;
    forever #5 aclk_0 = ~aclk_0;
end

// 控制逻辑
reg [31:0] cycle_count=0;
reg [31:0] count=0;
always @(posedge aclk_0) begin
 if (cycle_count < NUM_UPDATES)begin
        if (count ==UPDATE_INTERVAL) begin
            // 更新PINC值
            count<=1;
            cycle_count <= cycle_count + 1;
            S_AXIS_PHASE_0_tdata <= S_AXIS_PHASE_0_tdata + PINC_STEP;
        end
        else    
        count<=count+1;
        end
    else begin
      S_AXIS_PHASE_0_tdata <= PINC_START;
      cycle_count<=0;
    end
end
    
endmodule

写在最后

希望这篇文章可以帮大家快速的使用DDS这个IP核,下篇文章我会根据一些实际的需求教大家怎么改参数,大家有什么问题欢迎留言讨论。如果配置还是有困难也可以私聊我发你工程。

相关推荐
UVM_ERROR16 小时前
硬件设计实战:解决Valid单拍采样失效问题(附非阻塞赋值与时序对齐核心要点)
驱动开发·fpga开发·github·芯片
brave and determined16 小时前
可编程逻辑器件学习(day36):从沙粒到智能核心:芯片设计、制造与封装的万字全景解析
fpga开发·制造·verilog·fpga·芯片设计·硬件设计·芯片制造
步达硬件1 天前
【FPGA】FPGA开发流程
fpga开发
我爱C编程2 天前
【仿真测试】基于FPGA的完整16QAM通信链路实现,含频偏锁定,帧同步,定时点,Viterbi译码,信道,误码统计
fpga开发·16qam·帧同步·卷积编码·viterbi译码·维特比译码·频偏锁定
s09071362 天前
ZYNQ DMA to UDP 数据传输系统设计文档
网络协议·fpga开发·udp
燎原星火*3 天前
QSPI IP核 基本参数
fpga开发
XINVRY-FPGA3 天前
XCVU9P-2FLGC2104I Xilinx AMD Virtex UltraScale+ FPGA
嵌入式硬件·机器学习·计算机视觉·fpga开发·硬件工程·dsp开发·fpga
FPGA_小田老师3 天前
FPGA Debug:PCIE一直自动重启(link up一直高低切换)
fpga开发·pcie debug·pcie初始化问题
hexiaoyan8273 天前
视频信号检测板卡:208-Base Camera Link 图像信号模拟器
fpga开发·图像信号模拟器·视频信号检测·视频信号分析·智能图像分析
竹君子3 天前
新能源知识库(151) RTDS和RT-LAB比较
fpga开发