基于FPGA的简易 DDS 信号发生器的设计

发布者:自在自由最新更新时间:2022-07-01 来源: csdn关键字:FPGA  DDS  信号发生器 手机看文章 扫描二维码
随时随地手机看文章

前言

DDS 是直接数字式频率合成器(Direct Digital Synthesizer)的英文缩写,是一项关键的数字化技术。与传统的频率合成器相比, DDS 具有低成本、低功耗、高分辨率和快速转换时间等优点,广泛使用在电信与电子仪器领域,是实现设备全数字化的一个关键技术。作为设计人员,我们习惯称它为信号发生器,一般用它产生正弦、锯齿、方波等不同波形或不同频率的信号波形,在电子设计和测试中得到广泛应用


提示:以下是本篇文章正文内容,下面案例可供参考


一、pandas是什么?

DDS 技术是一种全新的频率合成方法,其具有低成本、低功耗、高分辨率和快速转换时间等优点, 对数字信号处理及其硬件实现有着很重要的作用。DDS 的基本结构主要由相位累加器、相位调制器、波形数据表 ROM、 D/A 转换器等四大结构组成,其中较多设计还会在数模转换器之后增加一个低通滤波器。 DDS 结构示意图

在这里插入图片描述

上图是不含低通滤波器的 DDS 结构示意图,图中主要包括相位累加器、相位调制器、波形存储器、数模(D/A)转换器等四大结构。接下来我们会结合 DDS 结构示意图,为大家讲解一下 DDS 的工作原理。在讲解之前,先来对其中各参数做一下说明。系统时钟 CLK 为整个系统的工作时钟,频率为 fCLK;频率字输入 F_WORD,一般为整数,数值大小控制输出信号的频率大小,数值越大输出信号频率越高,反之,输出信号频率越低,后文中用 K 表示;相位字输入P_WORD,为整数,数值大小控制输出信号的相位偏移,主要用于相位的信号调制,后文用 P 表示;设输出信号CLK_OUT,频率为 fOUT。


图中所展示的四大结构中,相位累加器是整个 DDS 的核心,在这里完成相位累加,生成相位码。相位累加器的输入为频率字输入 K,表示相位增量,设其位宽为 N,满足等式K = 2N * fOUT / fCLK 。其在输入相位累加器之前,在系统时钟同步下做数据寄存,数据改变时不会干扰相位累加器的正常工作。相位调制器接收相位累加器输出的相位码, 在这里加上一个相位偏移值 P, 主要用于信号的相位调制, 如应用于通信方面的相移键控等, 不使用此部分时可以去掉, 或者将其设为一个常数输入, 同样相位字输入也要做寄存。波形数据表 ROM 中存有一个完整周期的正弦波信号。假设波形数据 ROM 的地址位宽为 12 位,存储数据位宽为 8 位,即 ROM 有 212 = 4096 个存储空间,每个存储空间可存储 1字节数据。将一个周期的正弦波信号,沿横轴等间隔采样 212 = 4096 次,每次采集的信号幅度用 1 字节数据表示,最大值为 255,最小值为 0。将 4096 次采样结果按顺序写入 ROM的 4096 个存储单元, 一个完整周期正弦波的数字幅度信号写入了波形数据表 ROM 中。波形数据表 ROM 以相位调制器传入的相位码为 ROM 读地址,将地址对应存储单元中的电压幅值数字量输出。D/A 转 换 器 将 输 入 的 电 压 幅 值 数 字 量 转 换 为 模 拟 量 输 出 , 就 得 到 输 出 信 号CLK_OUT。输出信号 CLK_OUT 的信号频率 fOUT = K * fCLK / 2N。当 K = 1 时,可得 DDS 最小分辨率为: fOUT = fCLK / 2N,此时输出信号频率最低。根据采样定理, K 的最大值应小于 2N /2。


对于 N 位的相位累加器,它对应的相位累加值为 2N,如果正弦 ROM 中存储单元的个数也是 2N 的话,这个问题就很好解决,但是这对 ROM 的对存储容量的要求较高。在实际操作中,我们使用相位累加值的高几位对 ROM 进行寻址,也就是说并不是每个系统时钟都对 ROM 进行数据取,而是多个时钟读取一次,因为这样能保证相位累加器溢出时,从正ROM 表中取出正好一个正弦周期的样点。因此,相位累加器每计数 2N 次,对应一个正弦周期。而相位累加器 1 秒钟计数 fCLK次,在 k=1 时, DDS 输出的时钟频率就是频率分辨率。频率控制字 K 增加时,相位累加器溢出的频率增加,对应 DDS 输出信号 CLK_OUT 频率变为 K 倍的DDS 频率分辨率。


二、ROM 内波形数据写入

1.MIF

我们设计的 DDS 简易信号发生器想要实现正弦波、方波、三角波和锯齿波 4 种波形的输出,需要事先在波形数据表 ROM 中存入 4 种波形信号各自的完整周期波形数据。 ROM作为只读存储器,在进行 IP 核设置时需要指定初始化文件, 我们将波形数据作为初始化文件写入其中,文件格式为 MIF 文件。使用 MatLab 绘制 4 种信号波形,对波形进行等间隔样,以采样次数作为 ROM 存储地址,将采集的波形幅值数据做为存储数据写入存储地址对应的存储空间。

在这里插入图片描述

2.DDS 模块参考代码

代码如下(示例):


//********************************************************************//

//fre_add:相位累加器

always@(posedge sys_clk or negedge sys_rst_n)

    if(sys_rst_n == 1'b0)

        fre_add <=  32'd0;

    else

        fre_add <=  fre_add + FREQ_CTRL;


//rom_addr:ROM读地址

always@(posedge sys_clk or negedge sys_rst_n)

    if(sys_rst_n == 1'b0)

        rom_addr <= 14'd0;

    else

    case(wave_select)

        sin_wave:

            begin

                rom_addr_reg    <=  fre_add[31:20] + PHASE_CTRL;

                rom_addr        <=  rom_addr_reg;

            end     //正弦波

        squ_wave:

            begin

                rom_addr_reg    <=  fre_add[31:20] + PHASE_CTRL;

                rom_addr        <=  rom_addr_reg + 14'd4096;

            end     //方波

        tri_wave:

            begin

                rom_addr_reg    <=  fre_add[31:20] + PHASE_CTRL;

                rom_addr        <=  rom_addr_reg + 14'd8192;

            end     //三角波

        saw_wave:

        begin

                rom_addr_reg    <=  fre_add[31:20] + PHASE_CTRL;

                rom_addr        <=  rom_addr_reg + 14'd12288;

            end     //锯齿波

        default:

            begin

                rom_addr_reg    <=  fre_add[31:20] + PHASE_CTRL;

                rom_addr        <=  rom_addr_reg;

            end     //正弦波

    endcase


//********************************************************************//


波形仿真

在这里插入图片描述

关键字:FPGA  DDS  信号发生器 引用地址:基于FPGA的简易 DDS 信号发生器的设计

上一篇:基于FPGA的DDS 信号发生器(三)
下一篇:EDA(Quartus II)——正弦信号发生器的设计

推荐阅读最新更新时间:2024-11-11 10:38

FPGA动态探头与数字VSA对DSP设计实时分析
随着 FPGA 在数字通信设计领域(蜂窝基站、卫星通信和雷达)的高性能信号处理电路中成为可行的选择,分析和调试工具必须包括能帮助您在最短时间内得到电路最佳性能的新技术。 虽然现在已经有多种连接仿真与射频模拟信号的信号分析工具,但重要的是要能够测量 FPGA 子电路中的信号质量[谱图、I-Q 星座图、误差矢量幅度(EVM)]。将安捷伦(Agilent)的 89601A 矢量信号分析(VSA)软件与逻辑分析仪产品(1680、1690 和 16900 家族)连接构成数字 VSA 工具。当这一工具与Xilinx ChipScope Pro 及 Agilent 跟踪内核一起使用时,就能快速和容易地对 FPGA 设计中的任何地方进行信号分析。
[测试测量]
用<font color='red'>FPGA</font>动态探头与数字VSA对DSP设计实时分析
黄仁勋:游戏、AI以及数据中心业务都是大生意
网易科技讯11月11日消息,据VentureBeat报道,芯片巨头英伟达已经公布了截至10月31日的最新季度财报。英伟达本季度营收达到26亿美元,其中15亿美元来自于游戏个人电脑的显卡。但该公司对人工智能(AI)芯片的投资正在获得回报,数据中心营收也首次超过5亿美元。 英伟达首席执行官黄仁勋(Jensen Huang)表示,他的公司7年前开始投资AI,其最新AI芯片是数千名工程师多年工作的成果。他说,这帮助公司在AI领域占据优势,而其他竞争对手也在争相跟上。在最新财报电话会议结束后,黄仁勋接受了科技媒体VentureBeat的采访,并讨论了从无人驾驶汽车预测到加密货币开采等各种问题。以下就是经过编辑的采访记录: Ventu
[半导体设计/制造]
Microchip PolarFire® FPGA单芯片加密设计流程 成功通过英国国家网络安全中心审查
Microchip PolarFire® FPGA单芯片加密设计流程 成功通过英国国家网络安全中心审查 此次审查确认了 PolarFire FPGA 安全解决方案的优势 安全当前已成为各垂直市场所有设计的当务之急。今天,有进一步证据向系统架构师和设计人员证明,使用Microchip Technology Inc.(美国微芯科技公司)的PolarFire FPGA 可有力保障通信、工业、航空航天、国防、核及其他系统的安全性。英国政府的国家网络安全中心(NCSC)根据严格的器件级弹性要求,对采用单芯片加密设计流程的PolarFire FPGA器件进行了审查。 Microchip FPGA 业务部技术研究员 Tim Mor
[嵌入式]
Microchip PolarFire® <font color='red'>FPGA</font>单芯片加密设计流程   成功通过英国国家网络安全中心审查
基于FPGA的数字日历设计
  基于FPGA 设计数字日历可以实现以软件方式设计硬件的目的,无需购买专用数字芯片,从而克服了传统利用多片数字集成电路设计数字日历存在焊接麻烦、调试繁琐、成本较高等问题。而且,基于FPGA 的数字日历与传统系统相比,在设计灵活、开发速度、降低成本、计时精度、功能实现上都得到大幅度提升,能够更好地满足人们日常生活的需要。   本文介绍如何利用VHDL 硬件描述语言设计一个具有年、月、日、星期、时、分、秒计时显示功能,时间调整功能和整点报时功能的数字日历。在Quartus Ⅱ开发环境下,采用自顶向下的设计方法,建立各个基本模块,再构建成一个完整的基于FPGA 设计的数字日历的顶层模块,然后对其进行编译、仿真、引脚锁定,最终下载到可编
[电源管理]
基于<font color='red'>FPGA</font>的数字日历设计
基于AVR单片机的数控移相信号发生器设计
1 前 言 移相信号发生器属于信号源的一个重要组成部分,但传统的模拟移相有许多不足,如移相输出波形易受输入波形的影响,移相角度与负载的大小和性质有关,移相精度不高,分辨率较低等。而且,传统的模拟移相不能实现任意波形的移相,这主要是因为传统的模拟移相由移相电路的幅相特性所决定,对于方波、三角波、锯齿波等非正弦信号各次谐波的相移、幅值衰减不一致,从而导致输出波形发生畸变。目前利用DDS技术产生信号源的方法得到了广泛的应用,但是专用DDS芯片由于采用特定的集成工艺,内部数字信号抖动很小,不可以输出高质量的模拟信号。随着现代电子技术的发展,特别是随单片机和可编程技术的发展而兴起的数字移相技术却很好地解决了这一问题。在众多的单片机之中,AV
[单片机]
基于AVR单片机的数控移相<font color='red'>信号发生器</font>设计
ARM+FPGA开发板基于FFMPEG的网络视频播放终端——米尔NXP I.MX 8M
ARM+FPGA开发板基于FFMPEG的网络视频播放终端——米尔NXP I.MX 8M MINI+ARTIX-7处理器开发板 本篇测评由优秀测评者“qinyunti”提供。 01.前言 米尔这款ARM+fpga开发板具备高性能的ARM MPU+多媒体能力,采用i.MX 8M Mini+Artix-7处理器,特别适合多媒体终端开发。本篇就体验搭建ffmpeg开发环境,并进行性能测试,进行视频播放,演示网络视频播放器等。 02.编译过程 交叉编译 ./configure --cross-prefix=aarch64-linux-gnu- --enable-cross-compile --target-os=l
[嵌入式]
莱迪思推出适用于ADAS的FPGA,提供高速MIPI性能
莱迪思半导体公司,低功耗可编程器件的领先供应商,宣布拓展其屡获殊荣的Crosslink™-NX系列产品,推出专门用于高级驾驶辅助系统(ADAS)和车载娱乐信息系统等汽车应用的全新FPGA。全新CrossLink-NX FPGA将在技术先进的汽车行业为其嵌入式视觉应用带来业界领先的低功耗、小尺寸设计、高性能IO和高稳定性。莱迪思CrossLink-NX FPGA器件目前是同类产品中唯一支持速率高达10 Gbps嵌入式MIPI D-PHY接口的FPGA。 汽车行业正越来越多地采用新技术来增强车辆的功能,预计到2030年,仅ADAS传感器市场规模就将增长到408亿美元,2020年至2030年间的复合年增长率达11.7%。1这些雷达、
[嵌入式]
基于SOPC的雷达多功能接口模块的设计与实现
为了满足高性能和小型化的要求,采用SoPC技术在一片FPGA上实现了多个嵌入式系统来完成1553B通信和显示处理等航电接口功能,特别是用VHDL语言实现了软件可配置的彩色调色板和分层叠加显示技术,使得系统具有集成度高、配置灵活、可靠性高等优点。详细介绍了各子模块的主要功能、工作原理和关键技术,该模块已经成功应用于实际系统中。 0 引言 机载火控雷达的接口模块要承担数据处理机所有的接口任务,包括与雷达外部的航空电子系统总线、与雷达内部其他分系统(如发射机等)的通信以及输出雷达视频信号给航空电子综合显示器。这些接口功能有的比较复杂,如显示处理接口要将雷达数据处理机送来的目标、天线、航迹和地图等数据经过处理后形成符合标准的视频信号输
[电源管理]
基于SOPC的雷达多功能接口模块的设计与实现
小广播
最新测试测量文章
换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved