当前位置: 首页 > news >正文

利用FPGA和CPLD数字逻辑实现模数转换器

数字系统的嵌入式工程师熟悉如何通过使用FPGA和CPLD在其印刷电路板上将各种处理器,存储器和标准功能组件粘合在一起来实现其数字设计的“剩余”。除了这些数字功能之外,FPGA和CPLD还可以使用LVDS输入,简单的电阻电容器(RC)电路和某些FPGA或CPLD数字逻辑元件来实现常见的模拟功能,以创建模数转换器(ADC)。

ADC是常见的模拟构建块,当将数字逻辑(例如FPGA或CPLD中的数字逻辑)连接到模拟传感器的“真实世界”时,几乎总是需要ADC。本文将说明如何使用Lattice Semiconductor提供的参考设计和演示板来实现低频(DC至1K Hz)和更高频率(高达50K Hz)ADC。

将检查每种设计的示例应用程序:一个用于网络交换机中的系统监视器,另一个用于音频通信系统中的频率检测。

模数转换器实施概述领取嵌入式物联网学习路线

通过在FPGA或CPLD的LVDS输入上增加一个小型RC电路,可以构建一个简单的模数转换器。如图1左下方所示,RC网络位于LVDS输入的一侧,而感兴趣的模拟输入位于另一侧。

LVDS输入将充当简单的模拟比较器,并且如果模拟输入电压高于RC网络的电压,则将输出数字“ 1”。通过更改RC电路输入上的电压(来自FPGA / CPLD的通用输出),LVDS比较器可用于分析模拟输入电压,以创建准确的数字表示。

根据模拟输入的频率,所需的分辨率和可用的逻辑资源,可以采用多种方式来实现模数控制模块。可以使用一个简单的逐次逼近寄存器来处理低频信号,如图1左上方的选项1所示。

可以使用delta sigma调制器功能实现更高频率的实现,如图1右上方所示,该功能由采样寄存器和级联集成梳状(CIC)滤波器组成。

构建完数字信号后,可以选择对数字输出进行滤波,以消除由系统噪声或反馈抖动(下面将详细介绍)引入的任何不需要的高频分量。

在可选的数字滤波器块之后,可以将可选的存储缓冲区用于调试/测试目的。数字输出可以由存储缓冲器采样,然后通过JTAG端口扫描到运行信号分析软件的个人计算机中。

要查看该图形的放大版本,请单击此处。领取嵌入式物联网学习路线

图1:模数转换器基本框图:低频和高频选项 低频/最小逻辑ADC实现说明

在低频/最小逻辑实现中,采样控制模块控制逐次逼近寄存器,从而改变将通用输出信号施加到RC电路的时间。因此,RC电路电压会根据通用输出的状态(变化量)而上升或下降。

LVDS输入将变化的RC电路电压与模拟输入进行比较。因此,RC电路电压用于“查找”模拟输入电压。图2显示了一个示例,其中静态模拟输入(由橙色虚线表示)设置为略低于整个输入电压范围的一半。垂直的黑色虚线表示SAR采样点之间的时钟数,显示为绿色虚线。

第一次测量需要8个时钟,接下来的4个时钟,依此类推。首先,通过在通用输出上施加逻辑“ 1”,将RC电路设置为上升至模拟输入全电压摆幅的一半。一旦电压达到一半,LVDS输入的输出将指示模拟输入值是高于还是低于RC电路电压。

如果模拟电压较高,则数字输出的最高有效位为逻辑“ 1”。如果模拟电压较低,则数字输出为逻辑“ 0”。SAR移至下一位,采样时间减半(为整个电压摆幅的四分之一)。重复该过程,直到达到所需的A / D转换器精度为止。

在图2的示例中,观察RC电路电压如何逐渐接近模拟输入值。在这个简单的示例中,SAR(0101)的4位数字输出显示在该图的底部。

图2:基于SAR的模数转换器操作示例

低频设计可用于监视代表各种电源电压和环境传感器输出的几个模拟电压电平。CPLD的实现可以监视PCB电源电压(3.3V,2.5V和1.8V)以及温度和湿度传感器以及开柜警报。

为了测量多个模拟输入,每个模拟电压将使用一个LVDS输入以及附加的RC电路。由于模拟电压变化缓慢,因此可以复用LVDS输出,以便可以在每个输入之间共享数字逻辑功能。低频/最小逻辑ADC测试结果

使用评估板在莱迪思MachXO CPLD中实现了不带可选数字滤波器的低频/最小逻辑电路,并使用了0Hz至3.3V摆幅的0.8Hz输入信号。

如图1所示,可选的存储器缓冲器与Lattice ispLever设计软件的Lattice Reveal Logic Analyzer功能结合使用。此功能将缓冲存储器以及控制数字信号捕获,数据缓冲以及通过JTAG电缆将数据导出到计算机所需的逻辑添加到目标设计中。在测试期间,使用凌力尔特公司(Linear Technology)的PScope软件对捕获的数据进行FFT。

电路对0.8Hz模拟输入的响应如下图3的上半部分所示。

要查看该图形的放大版本,请单击此处。

图3:模数转换器的结果:低频和高频选项

接收到的数字信号显示在PScope屏幕截图的顶部窗口中。垂直轴以代码步长(0到255)测量,水平轴以样本(在此示例中为1024个样本)测量。频率在右上侧边栏报告为f1(基本)频率。FFT的结果显示在下部窗口中,谐波频率通过纵轴根据其dB级别显示。

右下侧边栏显示了从FFT导出的关键参数的摘要,包括有效位数(ENOB)和信噪比(SNR)。这些结果表明输入信号已成功转换为具有出色分辨率和SNR的数字信号。

更高频率ADC的实现

图1右上方所示的较高频率ADC选件的前端仍使用RC电路和LVDS输入。过采样触发器从LVDS输入捕获比较器结果。该信号通过驱动RC电路的通用LVCMOS输出反馈。如果比较器输出为逻辑“ 1”,则表示模拟输入高于RC电路的电压。

触发器对逻辑“ 1”进行采样并反馈到RC电路,从而使RC电路电压上升。如果比较器的输出为逻辑“ 0”,则反馈信号将为逻辑“ 0”,并将驱动RC电压降低。通过这种简单的反馈机制,数字值可以“跟踪”模拟输入的频率。

图4右下方的图形以红色显示了采样模拟输入波形,并显示了采样触发器的输出:蓝色列表示逻辑“ 1”,白色列表示逻辑“ 0”。请注意,“ 1”和“ 0”以普通脉冲编码调制(PCM)格式变化的方式。

使用级联积分梳状(CIC)滤波器,可以将PCM输入数据转换为输出流,该输出流镜像模拟输入流的频率。CIC功能基本上对单个PCM信号进行积分(相加或相减),以生成所需位数的连续输出信号。

在图4底部的示例中,将蓝色位视为“ 1”,将白色位视为“ -1”,通过检查可以清楚地看到,求和(积分)操作将生成输入的数字表示波形 (请注意,输出波形将偏移半个周期,因为序列“ 1”将对应于数字值的增加,而在图4的图表中,序列“ 1”在“波形的高''部分,并在``低''部分产生一系列``0''。)

由于反馈环路产生的“跟踪”过程,RC电路的电压可能会在模拟输入电平附近振荡。当过采样触发器在“ 1”和“ 0”结果之间变化时,RC电路电压将从模拟输入电平的正上方移至正下方。这个过程一直持续到模拟输入电平改变为止。高频噪声可以通过使用可选的数字滤波器来消除。

图4:三角积分调制器转换阶段的结果

更高频率的设计可以监视用于传达操作和环境条件的多个音频侧栏信号。例如,可以定期发出5kHz和12kHz信号,以指示远程音频监视系统的状态。这些信号可以指示设备的环境条件(温度和湿度)。领取嵌入式物联网学习路线

与前面的示例一样,只需添加更多LVDS输入,即可支持多个模拟信号。该设计可能是最多8个模拟信号的集线器。通过对输入进行时分复用,只需要使用数字逻辑的一个副本。更高频率的ADC测试结果

较高频率的ADC电路已使用评估板在Lattice XP2-17 FPGA中实现。在测试期间,使用了0kHz至3.3V摆幅的15kHz输入信号。使用数字滤波器选件,使用图1所示的选件2电路处理模拟信号。

结果显示在上方图3的下半部分,顶部窗口显示接收信号,底部显示FFT,f1频率为15.1kHz最显着。下侧边栏中报告的结果显示ENOB为9,SNR为61 dB。这些结果表明输入信号已成功转换为具有出色分辨率和SNR的数字信号。

相关文章:

利用FPGA和CPLD数字逻辑实现模数转换器

数字系统的嵌入式工程师熟悉如何通过使用FPGA和CPLD在其印刷电路板上将各种处理器,存储器和标准功能组件粘合在一起来实现其数字设计的“剩余”。除了这些数字功能之外,FPGA和CPLD还可以使用LVDS输入,简单的电阻电容器(RC&#xf…...

上海亚商投顾:沪指震荡调整跌 减肥药、华为概念股持续活跃

上海亚商投顾前言:无惧大盘涨跌,解密龙虎榜资金,跟踪一线游资和机构资金动向,识别短期热点和强势个股。 市场情绪 沪指上个交易日低开后震荡调整,深成指、创业板指盘中跌超1%,宁德时代一度跌超3%&#xff…...

间歇性微服务问题...

在Kubernetes环境中,最近由于特定配置导致Pod调度失败。哪种 Kubernetes 资源类型(通常与节点约束相关)可能导致此故障,尤其是在未正确定义的情况下? 节点选择器资源配额优先级污点Pod 中断预算 已有 201 人回答了该…...

小程序开发平台源码系统+ 带前后端完整搭建教程

大家好,给大家分享一个小程序开发平台源码系统。这款小程序开发平台中有很多功能,今天主要来给大家介绍一下洗车行业小程序制作的功能。以下是部分核心代码图: 系统特色功能: LBS定位:小程序能够自动显示附近的共享洗…...

外部统一设置了::-webkit-scrollbar { display: none; }如何单独给特定元素开启滚动条设置样式-web页面滚动条样式设置

如果你在外部统一设置了​​::-webkit-scrollbar { display: none; }​​​来隐藏滚动条,但是想要在​​.lever​​元素中单独开启滚动条的样式,你可以使用CSS的级联选择器来覆盖外部样式。 以下是一个示例,展示如何给​​.lever​​单独开启…...

【计算机网络】网络原理

目录 1.网络的发展 2.协议 3.OSI七层网络模型 4.TCP/IP五层网络模型及作用 5.经典面试题 6.封装和分用 发送方(封装) 接收方(分用) 1.网络的发展 路由器:路由指的是最佳路径的选择。一般家用的是5个网口,1个WAN口4个LAN口(口:端口)。可…...

力扣第39题 组合总和 c++ 回溯剪枝题

题目 39. 组合总和 中等 相关标签 数组 回溯 给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target ,找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 ,并以列表形式返回。你可以按 任意顺序 返回这些组合。 cand…...

qt软件正常运行的崩溃了定位行号方法

软件(debug版exe或者release版exe)在正常运行状态下(不是gdb调试运行),如果软件崩掉,那么会直接闪退,软件什么也做不了,此时无法保存软件中的状态信息,此外,也…...

软件工程与计算总结(十五)详细设计中面向对象方法下的信息隐藏

软件工程与计算总结(十三)详细设计中的模块化与信息隐藏 之前的博客中,模块需要隐藏的决策主要由“职责的实现”and“实现的变更”两类,在面向对象方法中,需要做到的就是: 封装类的职责,隐藏职…...

鸿蒙初体验

下载与安装DevEco Studio 在HarmonyOS应用开发学习之前,需要进行一些准备工作,首先需要完成开发工具DevEco Studio的下载与安装以及环境配置。 进入DevEco Studio下载官网,单击“立即下载”进入下载页面。 DevEco Studio提供了Windows版本和…...

hive复合类型的数据查询

hive数据表创建-CSDN博客 --第一个名字以M开头的 访问数组array 数组( array) 引用方式 列名 [ 元素索引 _ 以 0 开始 ] select * from emp where emp_name[0] rlike "^M"; -- 出生日期是在 5 几年 访问 Map map 引用方式 列名 ["Key"] selec…...

Notes/Domino 14 Early Access Drop3发布

大家好,才是真的好。 其实上周,就是国庆假期的时候,HCL Notes/Domino 14 Early Access Drop3(以下简称EA3)就已经发布,而且和传说中的一样,带来了数项惊人的新特性。 我们先讲讲这一版本新特性…...

前端、后端开发者常用到的免费API整理

以下是我整理的前端、后端工程师在开发中经常使用到的API接口,希望能帮到大家~ 手机号码归属地:可根据手机号码查询其省市区、运营商区号行政区划代码等信息。 上亿条数据囊括最新的170、166、147等号段,更新及时、准确度高。空号检测&#…...

【LeetCode高频SQL50题-基础版】打卡第9天:第46~50题

文章目录 【LeetCode高频SQL50题-基础版】打卡第9天:第46~50题⛅前言患某种疾病的患者🔒题目🔑题解 第二高的薪水🔒题目🔑题解 按日期分组销售产品🔒题目🔑题解 列出指定时间段内所有的下单产品…...

中断机制-通过volatile实现线程中断停止

4.1.4 大厂面试题中断机制考点 如何停止中断运行中的线程? 通过一个volatile变量实现 package com.nanjing.gulimall.zhouyimo.test;import java.util.concurrent.TimeUnit;/*** author zhou* version 1.0* date 2023/10/15 2:34 下午*/ public class InterruptD…...

Elasticsearch 8.11 中的合并更少,摄取更快

作者:ADRIEN GRAND Elasticsearch 8.11 改进了管理索引缓存的方式,从而减少了段合并。 我们对 Elasticsearch 8.11 从索引缓存回收内存的方式进行了重大更改,这有助于减少合并开销,从而加快索引速度。 使用我们的日志跟踪&#x…...

算法村开篇

大家好我是苏麟从今天开始我将带来算法的一些习题和心得体会等等...... 算法村介绍 我们一步步地学习算法本专栏会以闯关的方式来学习算法 循序渐进地系统的学习算法并掌握大部分面试知识 , 期待和大家一起进步 . 索大祝大家学有所成 , 前程似锦....

Leetcode—136.只出现一次的数字【简单】

2023每日刷题&#xff08;二&#xff09; Leetcode—136.只出现一次的数字 位运算法 实现代码 int singleNumber(int* nums, int numsSize){int i 0;int res 0;for(; i < numsSize; i) {res ^ nums[i];}return res; }运行结果 之后我会持续更新&#xff0c;如果喜欢我的…...

关于RNNoise、webrtc_ns、三角带通滤波器、对数能量

语音特征参数MFCC提取过程详解 其中讲解了&#xff1a;三角带通滤波器 、计算每个滤波器组输出的对数能量、对数能量、经离散余弦变换&#xff08;DCT&#xff09;得到MFCC系数 推荐阅读某乎这位大佬的全部文章&#xff1a; 下面是几篇出自这位大佬的很好的文章&#xff1a; …...

c语言练习89:链表的使用

链表的使用 虽然有这么多的链表的结构&#xff0c;但是我们实际中最常⽤还是两种结构&#xff1a; 单链表 和 双向带头循环链表 1. ⽆头单向⾮循环链表&#xff1a;结构简单&#xff0c;⼀般不会单独⽤来存数据。实际中更多是作为其他数据结 构的⼦结构&#xff0c;如哈希桶、…...

【JavaEE】-- HTTP

1. HTTP是什么&#xff1f; HTTP&#xff08;全称为"超文本传输协议"&#xff09;是一种应用非常广泛的应用层协议&#xff0c;HTTP是基于TCP协议的一种应用层协议。 应用层协议&#xff1a;是计算机网络协议栈中最高层的协议&#xff0c;它定义了运行在不同主机上…...

【Linux】C语言执行shell指令

在C语言中执行Shell指令 在C语言中&#xff0c;有几种方法可以执行Shell指令&#xff1a; 1. 使用system()函数 这是最简单的方法&#xff0c;包含在stdlib.h头文件中&#xff1a; #include <stdlib.h>int main() {system("ls -l"); // 执行ls -l命令retu…...

基于数字孪生的水厂可视化平台建设:架构与实践

分享大纲&#xff1a; 1、数字孪生水厂可视化平台建设背景 2、数字孪生水厂可视化平台建设架构 3、数字孪生水厂可视化平台建设成效 近几年&#xff0c;数字孪生水厂的建设开展的如火如荼。作为提升水厂管理效率、优化资源的调度手段&#xff0c;基于数字孪生的水厂可视化平台的…...

Cinnamon修改面板小工具图标

Cinnamon开始菜单-CSDN博客 设置模块都是做好的&#xff0c;比GNOME简单得多&#xff01; 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...

Linux --进程控制

本文从以下五个方面来初步认识进程控制&#xff1a; 目录 进程创建 进程终止 进程等待 进程替换 模拟实现一个微型shell 进程创建 在Linux系统中我们可以在一个进程使用系统调用fork()来创建子进程&#xff0c;创建出来的进程就是子进程&#xff0c;原来的进程为父进程。…...

HarmonyOS运动开发:如何用mpchart绘制运动配速图表

##鸿蒙核心技术##运动开发##Sensor Service Kit&#xff08;传感器服务&#xff09;# 前言 在运动类应用中&#xff0c;运动数据的可视化是提升用户体验的重要环节。通过直观的图表展示运动过程中的关键数据&#xff0c;如配速、距离、卡路里消耗等&#xff0c;用户可以更清晰…...

短视频矩阵系统文案创作功能开发实践,定制化开发

在短视频行业迅猛发展的当下&#xff0c;企业和个人创作者为了扩大影响力、提升传播效果&#xff0c;纷纷采用短视频矩阵运营策略&#xff0c;同时管理多个平台、多个账号的内容发布。然而&#xff0c;频繁的文案创作需求让运营者疲于应对&#xff0c;如何高效产出高质量文案成…...

算法:模拟

1.替换所有的问号 1576. 替换所有的问号 - 力扣&#xff08;LeetCode&#xff09; ​遍历字符串​&#xff1a;通过外层循环逐一检查每个字符。​遇到 ? 时处理​&#xff1a; 内层循环遍历小写字母&#xff08;a 到 z&#xff09;。对每个字母检查是否满足&#xff1a; ​与…...

Linux 中如何提取压缩文件 ?

Linux 是一种流行的开源操作系统&#xff0c;它提供了许多工具来管理、压缩和解压缩文件。压缩文件有助于节省存储空间&#xff0c;使数据传输更快。本指南将向您展示如何在 Linux 中提取不同类型的压缩文件。 1. Unpacking ZIP Files ZIP 文件是非常常见的&#xff0c;要在 …...

【p2p、分布式,区块链笔记 MESH】Bluetooth蓝牙通信 BLE Mesh协议的拓扑结构 定向转发机制

目录 节点的功能承载层&#xff08;GATT/Adv&#xff09;局限性&#xff1a; 拓扑关系定向转发机制定向转发意义 CG 节点的功能 节点的功能由节点支持的特性和功能决定。所有节点都能够发送和接收网格消息。节点还可以选择支持一个或多个附加功能&#xff0c;如 Configuration …...