当前位置:首页 > 嵌入式培训 > 嵌入式学习 > 讲师博文 > 利用FPGA和CPLD数字逻辑实现模数转换器

利用FPGA和CPLD数字逻辑实现模数转换器 时间:2020-06-01      来源:原创

数字系统的嵌入式工程师熟悉如何通过使用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的数字信号。

上一篇:调优C / C ++编译器以在多核应用程序中获得最佳并行性能:第一部分

下一篇:嵌入式实时Java VM支持Java 6 Standard Edition

热点文章推荐
华清学员就业榜单
高薪学员经验分享
热点新闻推荐
前台专线:010-82525158 企业培训洽谈专线:010-82525379 院校合作洽谈专线:010-82525379 Copyright © 2004-2022 北京华清远见科技集团有限公司 版权所有 ,京ICP备16055225号-5京公海网安备11010802025203号

回到顶部