基于FPGA的双通道DDS信号发生器

目录

xiaowuzxc/基于FPGA的双通道DDS信号发生器

目录结构

├─hdk  
│  ├─Gerber_PCB.zip PCB制版文件  
│  └─Schematic.pdf 原理图  
├─math  
│  ├─text.m 波形生成测试  
│  └─wave.m 波形生成脚本  
├─rtl 主要的hdl文件  
└─gw_dds.rar 高云ide(gowin)的工程文件  

介绍

本项目以高云FPGA(GW1N-LV1)作为控制核心,外围搭建DAC、按键等电路,实现双通道DDS信号发生器。通过按键和拨码开关,可以独立调整每个通道的波形、频率、相位。通过电位器,可以调整每个通道最终输出波形的幅值。

技术指标

通道数:2
调制方式:DDS
波形类型:正弦波,方波,三角波,锯齿波
频率范围:1-65535Hz
频率步进:1Hz
相位范围:0-360度
相位步进:360/(2^8)度
输出幅值:0-3.3V
输出阻抗:50ohm

总体结构

本项目使用GW1N-LV1输出双通道DDS波形信号,模拟部分对信号进行滤波、幅度调节、输出缓冲。
DDS

原理分析

逻辑部分

信号发生器每个通道使用了4KB的ROM作为波形存储器
其中,每种波形(正弦波、方波、三角波、锯齿波)的一个周期的幅值信息占用1024字节,4种波形占用4096字节。 输出波形,首先需要根据波形种类确定基地址;其次,频率寄存器决定了偏移量自增的速度;相位寄存器决定了两个通道偏移量的差值;最后,基地址与偏移量相加,得到ROM中当前时刻波形输出的电压值。

波形参数是通过外部按键和拨码开关来设置的
8位的拨码开关是主要数据的输入接口,用于频率和相位具体参数的设定,数据范围是0x00-0xFF。频率输入按键分高位按键和低位按键,按下高位按键表示8位拨码开关的数据写入频率寄存器的高8位,按下低位按键表示8位拨码开关的数据写入频率寄存器的低8位,高低8位寄存器共16位,可以实现频率从1Hz到65535Hz的调整。 相位输入按键只有一个,相位的表示方式是将360度分割成256份,通过8位拨码开关设置当前波形的相位值。 Wave按键的作用是切换波形,按下按键,波形会以空闲、正弦波、方波、三角波、锯齿波的顺序循环切换。CH端口连接的是拨动开关,其高低电平指示频率、相位、Wave按键按下后,参数应当写入哪一个通道。

计数型按键消抖模块
很多MCU的软件消抖逻辑是:采样到电平变化后,隔一小段时间再采样一次,如果两次电平相同则认为按键稳定。这种方法适用于通用处理器,但是放硬件逻辑上不太合适。 本项目设计了一个计数型消抖模块。定义一个位宽为[n:0]的计数器,n的大小决定了消抖的程度,应根据按键的特性来选择,太大会导致反应迟缓,太小则不足以消抖。 按键的高低电平决定了计数器在每个时钟周期是数值+1还是-1,计数器的最高位作为消抖后的输出。当计数器为全0,则停止-1;当计数器为全1,则停止+1。按键抖动会被计数器的计数过程消除,最高位01变换的分界点是计数器的中间值。

模拟部分

波形信号是以8位并行的方式从FPGA输出,然后进入8位的R2R电阻网络进行数模转换。转换后的信号是0~3.3V的高输出阻抗模拟电压信号,需要进入运放和电位器进行幅值调整和输出缓冲。

打赏?

取消

不用哦

扫码支持
这里只有暗黑赛钱箱

深邃♂黑暗♂幻想

>