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

2021-08-22 16:38:44      索炜达电子      687     

项目编号:E433

文件大小:933K

源码说明:带中文注释

开发环境:Verilog

简要概述

目录结构

-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波形信号,模拟部分对信号进行滤波、幅度调节、输出缓冲。

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

原理分析

(1)逻辑部分

1.信号发生器每个通道使用了4KB的ROM作为波形存储器。

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

2.波形参数是通过外部按键和拨码开关来设置的。

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

3.计数型按键消抖模块。

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

(2)模拟部分

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

目录│文件列表:

 └ gowin_dds

    │ gw_dds.rar

    ├ hdk

    │  │ .keep

    │  │ Gerber_PCB.zip

    │  │ PCB.pdf

    │  └ Schematic.pdf

    ├ math

    │  │ test.m

    │  │ test.txt

    │  │ wave.m

    │  └ wave.txt

    └ rtl

       │ .keep

       │ dds.v

       │ key_control.v

       │ key_filter.v

       └ top.v

TAG信号发生器
  • 9 次
  • 1 分