基于FPGA的直接数字频率合成器verilog实现,包含testbench

news/2025/1/8 21:59:55/文章来源:https://www.cnblogs.com/matlabworld/p/18660675

1.算法运行效果图预览

(完整程序运行后无水印)

 

 

2.算法运行软件版本

vivado2019.2

 

3.部分核心程序

(完整版代码包含详细中文注释和操作步骤视频)

//sin,cos相位累加器的控制
always @(posedge i_clk)//时钟上边沿触发
beginif(i_rst)//系统复位begino_sin_add<=8'd0;o_cos_add<=8'd0;end
else begino_sin_add<=o_sin_add+{i_sin_value[5],i_sin_value[5],i_sin_value};//相位累加o_cos_add<=o_cos_add+{i_cos_value[5],i_cos_value[5],i_cos_value};//相位累加   end
end//sin查找表模块的调用
DDS_ROM1 DDS_ROM_sin(.clka  (i_clk),.rsta  (i_rst|~sin_enable),.addra (o_sin_add),.douta (o_sin),.rsta_busy());//cos查找表模块的调用
DDS_ROM2 DDS_ROM_cos(.clka  (i_clk),.rsta  (i_rst|~cos_enable),.addra (o_cos_add),.douta (o_cos),.rsta_busy());//  .clka(clka),            // input wire clka
//  .rsta(rsta),            // input wire rsta
//  .addra(addra),          // input wire [7 : 0] addra
//  .douta(douta),          // output wire [8 : 0] douta
//  .rsta_busy(rsta_busy)  // output wire rsta_busy
//);
endmodule
35_007m

  

 

4.算法理论概述

       直接数字频率合成器(Direct Digital Synthesizer,DDS)是一种全数字的频率合成技术,具有频率分辨率高、频率切换速度快、相位噪声低等优点。随着现场可编程门阵列(Field Programmable Gate Array,FPGA)技术的不断发展,基于 FPGA 的 DDS 成为了现代电子系统中一种重要的频率合成解决方案。

 

       DDS 的基本原理是基于数字信号处理技术,通过对一个固定频率的时钟信号进行数字处理,产生一个具有特定频率和相位的正弦波信号。DDS 主要由相位累加器、正弦查找表和数模转换器(Digital-to-Analog Converter,DAC)组成。相位累加器在每个时钟周期内对输入的频率控制字进行累加,得到当前的相位值。正弦查找表根据相位值输出对应的正弦波幅度值。DAC 将数字幅度值转换为模拟电压信号,从而产生正弦波输出。

 

4.1 相位累加器

       相位累加器是 DDS 的核心部件之一,它由加法器和寄存器组成。在每个时钟周期内,加法器将频率控制字与寄存器中的当前相位值相加,得到新的相位值,并将其存储在寄存器中。为了提高相位累加器的速度和精度,可以采用流水线结构或并行加法器结构。同时,为了避免相位累加器溢出,可以对其输出进行取模运算,将相位值限制在到之间。

 

4.2 正弦查找表

      正弦查找表是一个存储了正弦波幅度值的存储器,它根据相位累加器输出的相位值,通过地址映射的方式输出对应的正弦波幅度值。正弦查找表的存储容量和地址宽度取决于相位累加器的位数和正弦波的幅度量化位数。通常,可以采用 ROM(Read-Only Memory)、RAM(Random Access Memory)或 FPGA 内部的查找表(Look-Up Table,LUT)资源来实现正弦查找表。为了提高正弦查找表的访问速度和效率,可以采用流水线结构或并行访问方式。同时,为了减小存储容量,可以采用压缩存储技术,如对称存储、插值存储等。

 

4.3 控制逻辑

       控制逻辑是 DDS 的控制中心,它负责接收外部输入的频率控制字、相位控制字等参数,并将其传输给相位累加器和正弦查找表。同时,控制逻辑还负责控制 DAC 的输出,实现 DDS 的频率切换、相位调制等功能。在 FPGA 设计中,可以采用状态机、计数器等逻辑电路来实现控制逻辑。同时,为了提高控制逻辑的灵活性和可扩展性,可以采用参数化设计和模块化设计方法。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/866105.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

G1原理—1.G1回收器的分区机制

大纲 1.G1垃圾回收器的分区(Region大小+G1分区+Region过大过小和计算) 2.Region大小的计算原理(先转字节然后确定2的n次幂再通过1左移n位) 3.新生代分区及自动扩展(新生代动态扩展机制) 4.停顿预测模型(衰减算法)保证预期停顿时间1.G1垃圾回收器的分区(Region大小+G1分区+Regio…

你不知道的 AI 提示词,都在这里!

你不知道的 AI 提示词,都在这里! ​​ 使用场景AI 提示词,即英文 AI Prompt,它犹如人类与大模型之间的“沟通语言”,堪称人机交互的重要通道。其形式既可以是简短的指令,也可以是一个问题,甚至是一个词,其目的就在于清晰地告知 AI 期望得到的结果。从原理上来看,提示词…

学习 - Linux - CentOS安装Tomcat8.5.85

CentOS安装Tomcat8.5.85 1、保证已经安装了jdk运行环境 java -version如果没有,请参考Centos安装jdk 2、从 Apache 官方网站下载 Tomcat 8 cd /opt sudo wget https://archive.apache.org/dist/tomcat/tomcat-8/v8.5.85/bin/apache-tomcat-8.5.85.tar.gz 3、载完成后,解压缩 …

Win32汇编学习笔记07.筛选器异常

Win32汇编学习笔记07.筛选器异常-C/C++基础-断点社区-专业的老牌游戏安全技术交流社区 - BpSend.net 钢琴 od调试老师给的多媒体钢琴运行找到Piano的过程函数里去找到处理WM_KEYDOWN消息的那下个断点,然后按键断下来在这分析上图汇编代码:mov eax,dword ptr [ebp+10] 拿wParm…

Axure RP 10 for Mac v10.0.0.3924原型设计软件 中文

Axure RP 10 for Mac v10.0.0.3924原型设计软件 中文 Axure RP 10 for Mac,是一个专业的原型设计和线框图工具,广泛应用于用户体验设计(UX)和用户界面设计(UI)领域,为设计师、产品经理、开发人员提供了强大的功能,帮助其在项目早期阶段快速创建互动原型和详细的设计文档…

EndNote 21 for Mac v21.5 文献管理软件安装

EndNote 21 for Mac v21.5 文献管理软件安装 EndNote for mac,是一款文献管理软件,支持国际期刊的参考文献格式有3776种,写作模板几百种,涵盖各个领域的杂志。EndNote mac不仅仅局限于投稿论文的写作,对于研究生毕业论文的写作也会起到很好的助手作用。

BurpSuite实操之漏洞扫描

一、BurpSuite的常见功能仪表盘:仪表盘,扫描启动、暂停,用于显示任务、日志信息等目标:设置工作的目标范围(URL),以及报文过滤、报文展示等功能代理:拦截HTTP/S请求的代理服务器,作为web浏览器与服务器的中间人,允许拦截、修改数据流测试器:入侵功能,对web应用程序进…

Python在多个Excel文件中找出缺失数据行数多的文件

本文介绍基于Python语言,针对一个文件夹下大量的Excel表格文件,基于其中每一个文件内、某一列数据的特征,对其加以筛选,并将符合要求与不符合要求的文件分别复制到另外两个新的文件夹中的方法~本文介绍基于Python语言,针对一个文件夹下大量的Excel表格文件,基于其中每一个…

【模拟电子技术】02-PN结的形成

【模拟电子技术】02-PN结的形成半导体就是导电能力介于导体和半导体之间的东西, 本征半导体即纯净的半导体。导电靠自由电子,可看到自由电子即使是本征激发也少,导电能力也不够。自由电子撞在空穴中,就是复合(与本征激发相反),两者发生的频率决定着载流子的浓度,其实是…

【字符串排序】C#和前端js排序问题

前言 前端请求时做了个参数验证,就是简单的计算md5,但是与后端计算的结果始终不一致 发现是前后端对字符串排序的默认规则有区别 测试代码 前端 1、示例代码,可以在浏览器的控制台中直接运行e=["","你","1","a","d",&quo…

C# 调用YoloSharp.Gpu,调用Microsoft.ML.OnnxRuntime.Gpu出错126

今天使用C#调用YoloSharp.Gpu,加载onnx模型,然后检测,代码很简单。 // Load the YOLO predictor predictor ??= new YoloPredictor(@"path to your.onnx");// Run model var result = predictor.Detect(@"path to your image");一运行就爆错ONNXRunti…

charls 安卓apk抓包证书配置

一:证书制作 将证书保存到本地:charles.pem OpenSSL签发证书制作: 安装openssl方法 打开网址,https://slproweb.com/products/Win32OpenSSL.html openssl x509 -subject_hash_old -in d:\CA\charles.pem修改文件 2bd25718.0(后缀名为0)二:证书导入 模拟器设置可写入 …