FPGA-DDS信号发生器

article/2025/8/16 14:24:50

FPGA-DDS信号发生器

DDS基本原理

​ FPGA实现的DDS(直接数字频率合成)波形生成器是一种高效、灵活的数字信号生成技术,广泛应用于通信、雷达和测试设备中。其核心原理是通过数字计算生成特定频率的波形。

​ DDS通过相位累加、查找表(LUT)和数模转换(DAC) 三个步骤生成波形:

  • 相位累加器: 以固定时钟频率 F c l k F_{clk} Fclk运行,每个时钟周期将当前相位值增加一个频率控制字M。相位值决定了波形的瞬时相位;
  • 查找表(LUT): 存储预先计算的波形样本(如正弦波的离散幅度值)。相位累加器的输出作为地址索引,从LUT中读取对应幅值;
  • 数模转换(DAC): 将数字幅值转换为模拟信号(需外部DAC)。若仅需数字输出(如仿真或数字处理),可省略DAC;
  • 其输出频率公式为: F o u t = M 2 N F c l k F_{out}=\frac{M}{2^N}F_{clk} Fout=2NMFclk,其中N为累加器的位数。

ACM9767 DAC模块

​ ACM9767是一个高速双通道DAC模块,每个通道数据分辨率为14位,输出电压为±5V,且转换速率高达125MHz,非常适合信号发生器、数字调制通信等应用。

在这里插入图片描述

​ 其引脚如下图所示,每个通道有14个数据引脚,1个时钟输入(CLK),一个写入使能(WRT),其中写入使能与CLK保持一致即可(根据芯片手册描述,CLK信号的上升沿必须提前或恰好和 WRT 信号的上升沿一起出现)。
在这里插入图片描述

总体设计

​ 每个通道分别通过三个按键控制其生成信号的波形,频率和相位。其中频率的可选范围在1Hz-10MHz,每次按动按钮频率提高十倍。波形分为正弦波、三角波和方波。

​ DDS相关设计分三层。最底层为基本原理层,用三个ROM保存不同波形的信息,根据输入的频率字和相位字,输出一定频率的14位的Data。中间层模块中预设好能够选择的频率和相位,根据输入的频率选择字和相位选择字,得到对应的频率字和相位字,再调用最底层模块得到相应的Data输出。顶层模块例化两个中间层模块作为通道A和B,并例化6个按键,对两个通道的波形、频率和相位进行控制。

ACM9767模块

ACM9767模块为最底层模块,实现DDS信号发生器最底层的原理。主要实现的功能如图所示。其中D/A转换器的功能由外接硬件模块实现。

在这里插入图片描述

波形数据表ROM

​ 首先生成对应波形的LUT,LUT的深度为4096,也就是由4096个数据构成完整的波形,数据的位宽为14位(跟ACM9767的14位分辨率对应),波形用厂商提供的软件生成。如下图所示,生成正弦波形的数据。

在这里插入图片描述
​ 然后创建ROM IP核,将LUT存储到ROM中。

​ 具体步骤为,打开IP Catalog,然后搜索rom,双击Block Memory …

在这里插入图片描述

​ 然后选择存储器类型为单口ROM,并将IP核名字改成rom_sin

在这里插入图片描述
​ 配置数据位宽为14,深度为4096,使能配置为一直使能即可
在这里插入图片描述

​ 最后载入波形数据即可

在这里插入图片描述

按照以上方法生成方波和三角波的波形和ROM

ACM9767.v

​ 需要注意这里相位累加器(Freq_ACC)的位数设为32位,相位控制器的位数为12(因为数据的深度为 4096 = 2 12 4096=2^{12} 4096=212),则输出波形的频率为:
F o u t = M 2 32 ∗ F c l k F_{out}=\frac{M}{2^{32}}*F_{clk} Fout=232MFclk

  • Note: 实际中使用时, F c l k F_{clk} Fclk通过锁相环产生125MHz频率的时钟信号,但仿真文件中始终信号波形为50MHz
module ACM9767(  Clk, Reset_n,Model_Sel[1:0],  // 选择时钟Fword[31:0],      // 频率控制字Pword[11:0],     // 相位控制字Data[13:0]        // 输出数据);input Clk;input Reset_n;input [1:0] Model_Sel;input [31:0] Fword;input [11:0] Pword;output reg [13:0] Data;// 频率控制字同步寄存器reg [31:0] Fword_r;always@(posedge Clk or negedge Reset_n)if(!Reset_n)Fword_r <= 0;elseFword_r <= Fword;// 相位控制字同步寄存器reg [11: 0] Pword_r;always@(posedge Clk or negedge Reset_n)if(!Reset_n)Pword_r <= 0;elsePword_r <= Pword;// 相位累加器reg [31:0] Freq_ACC;always@(posedge Clk or negedge Reset_n)if(!Reset_n)Freq_ACC <= 0;elseFreq_ACC <= Fword_r + Freq_ACC;// 波形数据表地址wire [11:0] Rom_Addr;assign Rom_Addr = Freq_ACC[31:20] + Pword_r;// 三角波wire [13: 0] Data_Tri;rom_triangular rom_triangular_ins(.clka(Clk),.addra(Rom_Addr),.douta(Data_Tri));// 正弦波wire [13: 0] Data_Sin;rom_sin rom_sin_ins(.clka(Clk),.addra(Rom_Addr),.douta(Data_Sin));// 方波wire [13:0] Data_Squ;rom_square rom_square_ins(.clka(Clk),.addra(Rom_Addr),.douta(Data_Squ));// 输出波形选择always@(posedge Clk or negedge Reset_n)if(!Reset_n)Data <= 0;else begincase(Model_Sel)0: Data <= Data_Tri;1: Data <= Data_Sin;2: Data <= Data_Squ;3: Data <= 0;endcaseend
endmodule
ACM9767_tb.v
`timescale 1ns / 1nsmodule ACM9767_tb();reg Clk;reg Reset_n;reg [1:0] Model_Sel;reg [31:0] Fword;reg [11:0] Pword;wire [13:0] Data;ACM9767 ACM9767_ins(.Clk(Clk), .Reset_n(Reset_n),.Model_Sel(Model_Sel),  // 选择时钟.Fword(Fword),      // 频率控制字.Pword(Pword),     // 相位控制字.Data(Data)        // 输出数据);initial Clk = 1;always #10 Clk = !Clk;initial beginReset_n = 0;#201;Reset_n = 1;Model_Sel = 0;Fword = 85899;   // 1khz  1msPword  = 0;#20000000;$stop;end
endmodule

DDS_ACM9767模块

​ DDS_ACM9767为中间模块,主要功能为根据计算出的频率字和相位字,预设频率和相位,并能通过频率选择字、相位选择字进行选择。

  • Note: 该模块仿真中设定的 F c l k F_{clk} Fclk为125MHz
DDS_ACM9767.v
// 时钟为125MHz
module DDS_ACM9767(Clk,Reset_n,Model_Sel[1:0],Fword_Sel[2:0],Pword_Sel[2:0],Data[13:0]);input Clk;input Reset_n;input [1:0] Model_Sel;input [2:0] Fword_Sel;input [2:0] Pword_Sel;output wire [13:0] Data;// Fwordreg [31:0] Fword;always@(posedge Clk or negedge Reset_n)if(!Reset_n)Fword <= 0;else begincase(Fword_Sel)0: Fword <= 34;    // 1Hz  1/(125MHz)/2^{32}1: Fword <= 344;  // 10Hz2: Fword <= 3436;  // 100Hz3: Fword <= 34360;  // 1KHz4: Fword <= 343597;  // 10KHz5: Fword <= 3435974; // 100KHZ6: Fword <= 34359738;  // 1MHz7: Fword <= 343597384;  // 10MHzdefault: Fword <= 0;endcaseend// Pwordreg [11:0] Pword;always@(posedge Clk or negedge Reset_n)if(!Reset_n)Pword <= 0;else begincase(Pword_Sel)0: Pword <= 0;   // 01: Pword <= 341;  // 30      4096 / 122: Pword <= 683; // 603: Pword <= 1024;  // 904: Pword <= 1707;  // 1505: Pword <= 2048;  // 1806: Pword <= 3072;  // 2707: Pword <= 3641;  // 320default: Pword <= 0;endcaseendACM9767 ACM9767_Ins(.Clk(Clk), .Reset_n(Reset_n),.Model_Sel(Model_Sel),  // 波形选择.Fword(Fword),      // 频率控制字.Pword(Pword),     // 相位控制字.Data(Data)        // 输出数据);
endmodule
DDS_ACM9767_tb.v
`timescale 1ns / 1nsmodule DDS_ACM9767_tb();reg Clk;reg Reset_n;reg [1:0] Model_Sel_A;reg [2:0] Fword_Sel_A;reg [2:0] Pword_Sel_A;wire [13: 0] DataA;reg [1:0] Model_Sel_B;reg [2:0] Fword_Sel_B;reg [2:0] Pword_Sel_B;wire [13: 0] DataB;DDS_ACM9767 DDS_ACM9767_Ins_A(.Clk(Clk),.Reset_n(Reset_n),.Model_Sel(Model_Sel_A),.Fword_Sel(Fword_Sel_A),.Pword_Sel(Pword_Sel_A),.Data(DataA));DDS_ACM9767 DDS_ACM9767_Ins_B(.Clk(Clk),.Reset_n(Reset_n),.Model_Sel(Model_Sel_B),.Fword_Sel(Fword_Sel_B),.Pword_Sel(Pword_Sel_B),.Data(DataB));initial Clk = 1;always #4 Clk = !Clk;   //125MHzinitial beginReset_n = 0;#201;Reset_n = 1;Model_Sel_A = 0;Fword_Sel_A = 6;  // 1MHzPword_Sel_A = 0;Model_Sel_B = 0;Fword_Sel_B = 6;  // 1MHzPword_Sel_B = 3;  // 90#2000000;Reset_n = 0;#201;Reset_n = 1;Model_Sel_A = 1;Fword_Sel_A = 5;  // 1MHzPword_Sel_A = 0;#2000000;$stop;end
endmodule

DDS_Module模块

​ 该模块为顶层模块,例化两个DDS_ACM9767模块,并例化六个按键用于控制波形、频率和相位。由于晶振为50MHz有源晶振,要想使用125MHz的时钟信号来驱动ACM9767运行,需要通过锁相环(PLL)对基频信号进行倍频分频,锁相环的配置可通过时钟管理单元IP核进行。

  • Note: 用按键触发信号,作为DDS_ACM9767模块的复位信号,当按下按键改变设置时,相应参数也重新复原。
时钟管理单元IP核

​ 由于开发板上晶振为50MHz,需要使用时钟管理单元,生成125MHz信号。

​ 在IP Catlalog中找到Clocking Wizard

在这里插入图片描述

​ 输入信号频率设为50MHz

在这里插入图片描述

​ 输出信号频率设为125MHz

在这里插入图片描述

​ 复位类型选择低电平触发(根据开发板硬件设计)

在这里插入图片描述

DDS_Module.v
module DSS_Module(Clk,Reset_n,ClkA,SkeyA,FkeyA,PkeyA,WrtA,ClkB,SkeyB,FkeyB,PkeyB,WrtB,DataA[13:0],DataB[13:0]);input Clk;input Reset_n;input SkeyA;input FkeyA;input PkeyA;input SkeyB;input FkeyB;input PkeyB;output wire ClkA;output wire ClkB;output wire WrtA;output wire WrtB;output wire [13:0] DataA;output wire [13:0] DataB;// clockwire Clk125MHz;wire locked;// DDS_ACM9767reg [1:0] Model_Sel_A;reg [2:0] Fword_Sel_A;reg [2:0] Pword_Sel_A;reg [1:0] Model_Sel_B;reg [2:0] Fword_Sel_B;reg [2:0] Pword_Sel_B;// keywire Press_Flag_SkeyA;wire Release_Flag_SkeyA;wire filter_state_SkeyA;wire Press_Flag_FkeyA;wire Release_Flag_FkeyA;wire filter_state_FkeyA;wire Press_Flag_PkeyA;wire Release_Flag_PkeyA;wire filter_state_PkeyA;wire Press_Flag_SkeyB;wire Release_Flag_SkeyB;wire [1:0] filter_state_SkeyB;wire Press_Flag_FkeyB;wire Release_Flag_FkeyB;wire [1:0] filter_state_FkeyB;wire Press_Flag_PkeyB;wire Release_Flag_PkeyB;wire [1:0] filter_state_PkeyB;wire Reset_A;wire Reset_B;assign Reset_A = Release_Flag_SkeyA | Release_Flag_FkeyA | Release_Flag_PkeyA;assign Reset_B = Release_Flag_SkeyB | Release_Flag_FkeyB | Release_Flag_PkeyB;assign ClkA = Clk125MHz;assign ClkB = Clk125MHz;assign WrtA = ClkA;assign WrtB = ClkB;// 时钟管理单元生成125MHz时钟clk_wiz_0 clk_125_ins(.Clk125MHz(Clk125MHz),     // output Clk125MHz.resetn(Reset_n), // input rese    .locked(locked),       // output locked// Clock in ports.clk_in1(Clk));      // 例化DDS_ACM9767DDS_ACM9767 DDS_ACM9767_Ins_A(.Clk(Clk125MHz),.Reset_n(!Reset_A),
//            .Reset_n(Reset_n),.Model_Sel(Model_Sel_A),.Fword_Sel(Fword_Sel_A),.Pword_Sel(Pword_Sel_A),.Data(DataA));DDS_ACM9767 DDS_ACM9767_Ins_B(.Clk(Clk125MHz),.Reset_n(!Reset_B),
//            .Reset_n(Reset_n),.Model_Sel(Model_Sel_B),.Fword_Sel(Fword_Sel_B),.Pword_Sel(Pword_Sel_B),.Data(DataB));// 例化Key_Filterkey_filter key_filter_SkeyA(.Clk(Clk125MHz),.Reset_n(Reset_n),.signal(SkeyA),.Press_Flag(Press_Flag_SkeyA),.Release_Flag(Release_Flag_SkeyA),.filter_state(filter_state_SkeyA),.result());key_filter key_filter_FkeyA(.Clk(Clk125MHz),.Reset_n(Reset_n),.signal(FkeyA),.Press_Flag(Press_Flag_FkeyA),.Release_Flag(Release_Flag_FkeyA),.filter_state(filter_state_FkeyA),.result());key_filter key_filter_PkeyA(.Clk(Clk125MHz),.Reset_n(Reset_n),.signal(PkeyA),.Press_Flag(Press_Flag_PkeyA),.Release_Flag(Release_Flag_PkeyA),.filter_state(filter_state_PkeyA),.result());key_filter key_filter_SkeyB(.Clk(Clk125MHz),.Reset_n(Reset_n),.signal(SkeyB),.Press_Flag(Press_Flag_SkeyB),.Release_Flag(Release_Flag_SkeyB),.filter_state(filter_state_SkeyB),.result());key_filter key_filter_FkeyB(.Clk(Clk125MHz),.Reset_n(Reset_n),.signal(FkeyB),.Press_Flag(Press_Flag_FkeyB),.Release_Flag(Release_Flag_FkeyB),.filter_state(filter_state_FkeyB),.result());key_filter key_filter_PkeyB(.Clk(Clk125MHz),.Reset_n(Reset_n),.signal(PkeyB),.Press_Flag(Press_Flag_PkeyB),.Release_Flag(Release_Flag_PkeyB),.filter_state(filter_state_PkeyB),.result());// Model_Sel_Aalways@(posedge Clk125MHz or negedge Reset_n)if(!Reset_n)Model_Sel_A <= 0;else if(Release_Flag_SkeyA && (filter_state_SkeyA == 0))Model_Sel_A <= Model_Sel_A + 1;// Fword_Sel_Aalways@(posedge Clk125MHz or negedge Reset_n)if(!Reset_n)Fword_Sel_A <= 3;  // 1khzelse if(Release_Flag_FkeyA && (filter_state_FkeyA == 0))Fword_Sel_A <= Fword_Sel_A + 1;// Pword_Sel_Aalways@(posedge Clk125MHz or negedge Reset_n)if(!Reset_n)Pword_Sel_A<= 0;else if(Release_Flag_PkeyA && (filter_state_PkeyA == 0))Pword_Sel_A <=Pword_Sel_A + 1;// Model_Sel_Balways@(posedge Clk125MHz or negedge Reset_n)if(!Reset_n)Model_Sel_B <= 1;else if(Release_Flag_SkeyB && (filter_state_SkeyB == 0))Model_Sel_B <= Model_Sel_B + 1;// Fword_Sel_Balways@(posedge Clk125MHz or negedge Reset_n)if(!Reset_n)Fword_Sel_B <= 3;else if(Release_Flag_FkeyB && (filter_state_FkeyB == 0))Fword_Sel_B <= Fword_Sel_B + 1;// Pword_Sel_Balways@(posedge Clk125MHz or negedge Reset_n)if(!Reset_n)Pword_Sel_B<= 0;else if(Release_Flag_PkeyB && (filter_state_PkeyB == 0))Pword_Sel_B <= Pword_Sel_B + 1;
endmodule
DDS_Module_tb.v
  • Note: 由于信号较多,软件仿真的速度很慢,不利于调试,仅供参考,推荐使用ILA硬件调试。(ILA硬件调试方法会在后面小节具体介绍)
`timescale 1ns / 1ns
// Not in use
module DDS_Module_tb();reg Clk;reg Reset_n;reg SkeyA;reg FkeyA;reg PkeyA;reg SkeyB;reg FkeyB;reg PkeyB;wire ClkA;wire ClkB;wire [13:0] DataA;wire [13:0] DataB;DSS_Module DSS_Module_ins(.Clk(Clk),.Reset_n(Reset_n),.ClkA(ClkA),.SkeyA(SkeyA),.FkeyA(FkeyA),.PkeyA(PkeyA),.WrtA(),.ClkB(ClkB),.SkeyB(SkeyB),.FkeyB(FkeyB),.PkeyB(PkeyB),.WrtB(),.DataA(DataA),.DataB(DataB));initial Clk = 1;always #10 Clk = !Clk;reg [31: 0] rand;initial beginReset_n = 0;#201;Reset_n = 1;press_skeyA(0);press_pkeyA(0);press_fkeyA(0);$stop;endtask press_skeyA;input [3:0] seed;beginSkeyA = 1;#20000000;repeat(5)beginrand = {$random} % 10000000;   // 10ms以内的抖动#rand SkeyA = ~SkeyA;endSkeyA = 0;#20000000;repeat(5)beginrand = {$random} % 10000000;   // 10ms以内的抖动#rand SkeyA = ~SkeyA;endSkeyA = 1;#20000000;#20000000;endendtasktask press_fkeyA;input [3:0] seed;beginFkeyA = 1;#20000000;repeat(5)beginrand = {$random} % 10000000;   // 10ms以内的抖动#rand FkeyA = ~FkeyA;endFkeyA = 0;#20000000;repeat(5)beginrand = {$random} % 10000000;   // 10ms以内的抖动#rand FkeyA = ~FkeyA;endFkeyA = 1;#20000000;#20000000;endendtasktask press_pkeyA;input [3:0] seed;beginPkeyA = 1;#20000000;repeat(5)beginrand = {$random} % 10000000;   // 10ms以内的抖动#rand PkeyA = ~PkeyA;endPkeyA = 0;#20000000;repeat(5)beginrand = {$random} % 10000000;   // 10ms以内的抖动#rand PkeyA = ~PkeyA;endPkeyA = 1;#20000000;#20000000;endendtask
endmodule

key_filter模块

​ 按键模块,进行20ms的消抖处理,若时钟频率改变,则需要修改对于计数器的最大计数值,这里支持的是125MHz的频率。

key_filter.v
// 按键消抖  等待按键按下(下降沿) --->消抖,20ms没出现上升沿 ---> 按键已按下---?等待释放 ---> 20ms? --->已释放
module key_filter(Clk,Reset_n,signal,Press_Flag,Release_Flag,filter_state,result);input Clk;input Reset_n;input signal;output reg Press_Flag;output reg Release_Flag;output reg [1:0] filter_state;output reg result;// 多级寄存器缓解亚稳态现象reg [1: 0] sync_reg;always@(posedge Clk or negedge Reset_n)if(!Reset_n)sync_reg <= 0;elsesync_reg <= {sync_reg[0], signal};// 边缘检测器reg [1:0] edge_reg;    always@(posedge Clk or negedge Reset_n)if(!Reset_n)edge_reg <= 0;elseedge_reg <= {edge_reg[0], sync_reg[1]};wire pos_edge;assign pos_edge = (edge_reg == 2'b01);wire neg_edge;assign neg_edge = (edge_reg == 2'b10);reg [23:0] cnt;// filter_statealways@(posedge Clk or negedge Reset_n)if(!Reset_n)filter_state <= 0;else if(filter_state == 0)beginif(neg_edge)filter_state <= 1;endelse if(filter_state == 1)beginif(pos_edge)filter_state <= 0;  // 回到等待状态else if(cnt == 2500000 - 1)// 20msfilter_state <= 2;endelse if(filter_state == 2)beginif(pos_edge)    // 出现上升沿filter_state <= 3;  // 进入释放消抖endelse if(filter_state == 3)beginif(neg_edge)filter_state <= 2;else if(cnt == 2500000 - 1)filter_state <= 0;end// Press_Flagalways@(posedge Clk or negedge Reset_n)if(!Reset_n)Press_Flag <= 0;else if(filter_state == 1 && (cnt == 2500000 - 1))Press_Flag <= 1;else if(filter_state == 2)Press_Flag <= 0;// Release_Flagalways@(posedge Clk or negedge Reset_n)if(!Reset_n)Release_Flag <= 0;else if(filter_state == 0)Release_Flag <= 0;else if(filter_state == 3 && (cnt == 2500000 - 1)) Release_Flag <= 1;// resultalways@(posedge Clk or negedge Reset_n)if(!Reset_n)result <= 1;else if(filter_state == 1 && (cnt == 2500000 - 1))result <= 0;else if(filter_state == 3 && (cnt == 2500000 - 1))result <= 1;// cntalways@(posedge Clk or negedge Reset_n)if(!Reset_n)cnt <= 0;else if(filter_state == 1)begincnt <= cnt + 1;if(pos_edge)cnt <= 0;else if(cnt == 2500000 - 1)cnt <= 0;endelse if(filter_state == 3)begincnt <= cnt + 1;if(neg_edge)cnt <= 0;       else if(cnt == 2500000 - 1)cnt <= 0;end
endmodule
key_filter_tb.v
`timescale 1ns / 1ns
module key_filter_tb();reg Clk;reg Reset_n;reg signal;wire Press_Flag;wire Release_Flag;wire [1:0] filter_state;wire result;key_filter key_filter_ins(.Clk(Clk),.Reset_n(Reset_n),.signal(signal),.Press_Flag(Press_Flag),.Release_Flag(Release_Flag),.filter_state(filter_state),.result(result));initial Clk = 1;always #4 Clk = !Clk;reg [31: 0] rand;initial beginReset_n = 0;#201;Reset_n = 1;#20;press_key(0);$stop;endtask press_key;input [3:0] seed;beginsignal = 1;#20000000;repeat(5)beginrand = {$random} % 10000000;   // 10ms以内的抖动#rand signal = ~signal;endsignal = 0;#20000000;repeat(5)beginrand = {$random} % 10000000;   // 10ms以内的抖动#rand signal = ~signal;endsignal = 1;#20000000;#20000000;endendtask
endmodule

ILA硬件调试方法

​ ILA的使用方式有很多,这里就讲一种我比较喜欢的方式。

​ 首先,运行综合,后打开综合设计器。

在这里插入图片描述

​ 然后在netlist里面,可以选择感兴趣的信号设置debug,被选中的信号左边会有个小爬虫

​ 右上角选择Debug界面
在这里插入图片描述

​ 在Debug界面为没有分配ILA IP核的信号,创建或分配一个探针
在这里插入图片描述

​ 进入到ILA IP核向导界面
在这里插入图片描述

​ 跟着向导走,直到来到以下界面,该界面可以配置需要debug信号探针的类型,DataTrigger Data&Trigger,触发类型信号,设置触发条件后,当达到触发条件时,ILA会对信号进行采样。这里我们只想看看按键按下后,对应的选择字位有没有变化,因此设置成Data类型的探针就好,当按下开发板按键后,手动触发信号采样。

  • PkeyA_IBUF: 是为了展示使用ILA过程。
    在这里插入图片描述
    然后选择合适的深度,就是一次采样中,采样点的个数
    在这里插入图片描述

设置完成后,正常流程生产比特流文件即可。然后当连接到硬件时,Vivado会将比特流文件和调试文件一起烧录到开发板中。
在这里插入图片描述
​ 然后可以看到ILA的界面,点击触发按钮手动触发一次采样。
在这里插入图片描述

​ 可以看到采样到的值
在这里插入图片描述
​ 按下开发板上的按键,再重新手动触发采样,看看值是否有改变,若改变,则说明按键部分的功能实现无误。
在这里插入图片描述

​ ILA还能设置触发条件进行采样,在有些应用中只能通过该方法进行调试,具体方法自行了解。

实验现象

看看效果

FPGA-DDS

相关硬件

小梅哥FPGA ACX720
FPGA芯片型号: XC7A35TFGG484ABX2l
DMA: ACM9767
示波器: 正点原子


http://www.hkcw.cn/article/RvyMwLxmuF.shtml

相关文章

紫光同创FPGA实现AD9280数据采集转UDP网络传输,分享PDS工程源码和技术支持和QT上位机

目录 1、前言工程概述免责声明 2、相关方案推荐我已有的所有工程源码总目录----方便你快速找到自己喜欢的项目紫光同创FPGA相关方案推荐我这里已有的以太网方案本方案在Xilinx系列FPGA的应用方案 3、设计思路框架工程设计原理框图AD输入源AD9280数据采集AD9280数据缓存控制模块…

不用官方EDA怎么开发FPGA?

目前FPGA的开发和官方的EDA工具是高度绑定的&#xff0c;用哪家的芯片只能用其配套的EDA工具进行开发&#xff08;综合可选工具&#xff0c;布局布线没有可选的工具&#xff09;&#xff0c;那么有没有其他的开发方式呢&#xff1f;今天就介绍一个使用开源工具链来开发FPGA的方…

群体智能优化算法-沙丁鱼群优化算法(Salp Swarm Algorithm (SSA,含Matlab源代码)

摘要 Salp Swarm Algorithm&#xff08;SSA&#xff0c;沙丁鱼群优化算法&#xff09;是一种基于群体智能的元启发式优化算法&#xff0c;灵感来自沙丁鱼群在水中的游动模式。SSA 在求解复杂优化问题时表现出良好的全局搜索能力和收敛性能。本文详细介绍SSA的数学原理&#xf…

Linux网络基础全面解析:从协议分层到局域网通信原理

Linux系列 文章目录 Linux系列前言一、计算机网络背景1.1 认识网络1.2 认识协议 二、网络协议初识2.1 协议分层2.2 OSI七层模型2.3 TCP/IP协议栈2.4 网络协议栈与OS的关系2.5 网络协议在网络传输时的作用 三、网络通信局域网通信的安全隐患与应对总结 前言 Linux系统部分的学习…

【网络协议】一文带你搞懂Tcp和Udp(万字详解)

文章目录 前言一、端口号端口号的范围划分 二、UDP和TCP2.1 UDP2.2 UDP的特点 三、TCP四、TCP的十个核心机制1.确认应答机制2.超时重传3.连接管理--三次握手 四次挥手**三次握手**四次挥手 4.滑动窗口5.流量控制6.阻塞控制7.延迟应答8.捎带应答9.粘包问题10.异常情况 前言 再上…

Kile5报错—>Target ‘Target 1‘ uses ARM-Compiler ‘Default Compiler Version 5‘ which is not available

一、错误分析 出现这个报错Target l uses ARM-Compiler Default Compiler Version 5 which is not available.是因为使用的 ARM 编译器“ Use Default Compiler Version 5”不可用&#xff0c;这是因为最新版本Keil5不再自动提供编译器&#xff08;旧版本是自动安装编译器的&…

假水玩具超半数硼迁移超标 安全隐患引担忧

网红“假水”在部分中小学校园周边和电商平台热销,这种颜色丰富、黏性强的起泡胶玩具,别称史莱姆、水晶泥或“不沾手的水”,因其解压特性和价格低廉受到欢迎。然而,这类玩具存在安全隐患。电商平台上的“假水”名称和内容五花八门,价格低廉且销量大。六一儿童节前夕,从多…

美国提出伊核协议新方案 伊朗将回应 基于国家利益

伊朗外交部长阿巴斯阿拉格齐表示,阿曼外交大臣赛义德巴德尔布赛义迪访问了德黑兰,并介绍了美国提出的新伊核协议部分内容。伊朗将根据原则、国家利益和人民权利对美方提议作出回应。美国白宫新闻秘书卡罗琳莱维特称,美国中东问题特使史蒂文威特科夫已向伊朗发出一份详细的可…

印军高官称赞印巴两国军人都很理性 避免核冲突风险

在新加坡出席香格里拉对话会的印度国防参谋长阿尼尔乔汉5月31日在接受媒体采访时,称赞印度和巴基斯坦军人都很理性,不会因常规冲突诱发核冲突。他表示,当冲突发生时,最理性的人是身穿制服的人,因为他们明白冲突可能朝任何一方倾斜,并且理解这种冲突的后果。此前,乔汉在接…

买基金亏损30万状告银行 法院判了 二审驳回投资者请求

一位年过八旬的投资者在2021年投入105万元购买了一只公募基金产品,两年多时间亏损约30万元,随后将相关代销银行告上法庭,要求赔偿损失。案件经过两次审理,一审法院判决银行承担70%的损失赔偿责任并支付利息,但二审法院认为投资者自主决定购买理财产品,且亏损原因是金融市…

江苏省城市足球联赛 全民足球热潮席卷江苏

虎扑App紧急新增了“江苏联”频道。在“苏超”第三轮于5月31日开打之前,一票难求和诸梗风行的情势深度交织,让越来越多的网友沉醉其间。玩梗层出不穷:“我从来不关心足球,这次特别关注”“我都不是球迷,我就是为了争口气”“没有假球,全是世仇”“比赛第一,友谊第十四”…

安徽4300多万亩小麦丰收 生产形势良好

安徽省农业农村厅发布的信息显示,2024年安徽小麦收获期间天气状况良好,有利于机械化收割。截至5月31日17时,全省已收割小麦超过3833万亩,进度接近九成。安徽作为中国农村改革的发源地之一,是中国主要的粮食生产和调出省份,其粮食种植面积和产量一直位居全国前列。2024年,…

孙中山长孙女孙穗瑛去世 享年103岁 家人举办追思会

2025年5月,孙穗瑛的家人在美国加州为她举办了追思会。孙中山长孙女孙穗瑛于2025年3月24日在美国去世,享年103岁。孙穗瑛出生于1922年1月16日,出生地为中国广州,父亲是时任广州市长的孙科,母亲为陈淑英。她的两位兄长孙治平、孙治强以及妹妹孙穗华此前均已辞世。童年时期,…

知情人回应迪士尼情侣和一家三口扭打 因拍照起冲突

5月31日,有网友发布视频称,上海迪士尼内一对情侣和一家三口发生冲突并扭打起来,此事引发热议。视频显示,双方在现场激烈争执,周围游客纷纷上前劝阻。据了解,事件发生在5月31日,地点并非排队区域,而是游客自由打卡拍照的地方。情侣与一家三口因拍照问题产生矛盾,进而发…

2025年渗透测试面试题总结-匿名[校招]渗透测试工程师(题目+回答)

安全领域各种资源&#xff0c;学习文档&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具&#xff0c;欢迎关注。 目录 匿名[校招]渗透测试工程师 1. 自我介绍 2. 印象深刻的一次渗透 3. 渗透测试流程 4. SQL注入原理及Payl…

“公安英模”邱建军雕像揭幕 缅怀英烈激励警心

6月1日是邱建军牺牲一周年,当天,他的雕像回到了汉兴派出所,仿佛又将大家带回到他保护群众安全而壮烈牺牲的那一瞬间,诉说着往昔的故事。为缅怀英烈、弘扬楷模精神,激励担当作为、凝聚奋进力量,江汉区公安分局邀请武汉泥塑艺术家胡作林制作了邱建军的雕像,并将其存放在汉…

硬核龙舟祝福端午 粽香飘飘竞渡忙

今天,端午节粽香飘飘、龙舟竞渡在守护家国安宁的“赛道”上战士们时刻奋楫争先硬核端午壁纸上新,请查收↓责任编辑:zhangxiaohua

专家谈以色列在约旦河西岸行事激进 侵蚀“两国方案”基础

当地时间5月30日,以色列国防部长卡茨宣布将在约旦河西岸地区建立“犹太人以色列国家”。此前,以色列安全内阁已决定在该地区新建22处犹太人定居点。中国国际问题研究院助理研究员李子昕指出,当前以色列的激进做法源于国内形势。以色列在加沙地带和约旦河西岸继续开展军事行动…

回顾香港演员方刚经典作品 致敬“第一恶人”

香港影坛“第一恶人”方刚于5月30日去世,享年78岁。方刚原名梁芳纲,曾是无线电视及亚视电视演员,出演过多部经典作品如《人在边缘》《豪门》《胜者为王lll王者之战》等。方刚1947年11月出生,学生时代就热爱舞台表演,12岁时开始客串影视作品。22岁时参演武侠电影《黑豹》和…

圆明园端午“十二花神”亮相 沉浸式体验传统文化魅力

端午节期间,圆明园变身为“东方美学乐园”。5月31日,“爱在海淀 曲动端阳”2025圆明园端午文化活动拉开帷幕,市民可以一站式体验传统民俗、非遗手作、汉服乐舞和创意市集,感受中华文化的魅力。《胤禛美人图》中的古典美人仿佛从画卷中走出,化身“十二花神”来到圆明园。她…