FPGA练习———DDS波形发生器

简介:使用DDS波形发生器可以在fpga上生成方波、正弦波等波形,其具体方法是计算相位的变化,然后根据数据表的数值进行数模转化改变波形。

DDS的第一步是生成一个相位加法器

相位加法器

在生成一个波,例如正弦波时,我们要设定波发生的频率,例如一个正弦波为1hz,也就是一秒钟发生一次。

在确定了波的发生频率后,由于fpga是数字电路,我们需要将数字转化为波形,这就需要借助数模转化将数值和一个数值表进行比较(这个数值表中每个数值都对应一个电压,如果表中的数值和需要转化为波形的数值相等,那么就输出这个电压),依靠这样的方法就可以实现数模转换。

由于这个表保存的数据是离散的再加上芯片处理数据时每次计算都有时间间隔,所以我们将一个波均分为很多小点,最后将这些小点连起来就相当于一个连续的波形了。

相位加法器即可判断在波的一个周期内需要分多少个小点以及波的频率。

我们用verilog代码实现,下面代码通过改变输入K的值即可改变每个点的频率,K取值应该小于myAdd寄存器最大值,当myAdd寄存器溢出时它的所有位都会变为0,利用这种特性我们就实现了波的重复生成。

为什么要用myRom取myAdd的前10位,这是因为myAdd的位数乘上每次时钟消耗时间为每次波一个周期时间,但是其中有17位数据,如果我们每个数据都拿来生成点所消耗的资源太多了,只取高位然后等低位不断进位会大大降低资源消耗,虽然这样每个点的间隔变大了,但是实际生成波形效果还是非常好(奈奎斯特准则)。

cpp 复制代码
module ph_adder (
    input clk,
    input [12:0] K,           //K取最大值时,波的频率大概5Mhz
    output reg [9:0] myRom,
    output reg [16:0] myAdd
);
    always @(posedge clk) begin
        myAdd <= myAdd + K;
        myRom <= myAdd[16:7];  //myAdd的低位每次进位后,myRom加1
    end
endmodule

方波发生器

在生成波时,我们需要知道每个点对应的值,我们可以将该值放在寄存器中或者使用脚本将该值导入寄存器中。为了简单体现效果,我这里使用了方波发生器,因为方波的点对应的数值只有两种即0、1。

cpp 复制代码
module sq_wave (
    input clk,
    input Rst,
    input [16:0] myAdd,
    output reg [11:0] sq
);
    always@(posedge clk)begin
        if(!Rst)
            sq=0;
        else begin
            if(myAdd<=17'h0FFFF)//第一位为0,相当于把地址平分为2半
                sq=12'hFFF;
            else
                sq=0;
        end
    end
    
endmodule

100Mhz锁相环

由于我的时钟频率是50mhz,我想得到100Mhz的波形,通过在quartus上调用IP核即可实现。

按照上述图片所示配置即可。

顶层模块设计

依次调用模块即可。

cpp 复制代码
module DDS_top (
    input clk_50,
    input Rst,
    input [12:0] K,
    output [11:0] sq,     //方波输出值
    output LED
);
	 wire clk_100;
    PLL PLL_inst(
        .inclk0 (clk_50),
        .c0 (clk_100),
        .locked (LEDG)
    );
    wire [16:0] myAdd;
    wire [9:0] myRom;
    ph_adder ph_adder_inst(clk_100,K,myRom,myAdd);
    sq_wave sq_wave_inst(clk_100,Rst,myAdd,sq);
endmodule

仿真模拟实验

1.在quartusII中新建vmf文件,调节波的取值,实验效果如下

2.使用quartusII中的逻辑分析仪,配置好引脚选择观察的寄存器,实验效果如下

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