当前位置:首页 > 工业控制 > 电路设计项目集锦
[导读]我们都熟悉RFSoC和与ZYNQ MPSoC结合的高速ADC和DAC。但是,您可能不知道所有赛灵思七系列及以上都有XADC / Sysmon ADC,这是监测内部电压轨和模具温度的电缆。

为MicroZed 7010/20和IO载波卡创建PYNQ映像。用XADC进行信号处理

我们都熟悉RFSoC和与ZYNQ MPSoC结合的高速ADC和DAC。但是,您可能不知道所有赛灵思七系列及以上都有XADC / Sysmon ADC,这是监测内部电压轨和模具温度的电缆。

XADC / Sysmon还能够监控外部模拟信号,与Zynq 7000相比,它能够以高达1 MSPS的速度采样,这使得它对于简单的信号处理应用非常有趣。

我还看到一些应用程序使用PYNQ从XADC捕获数据,因此在本项目中,我们将创建一个简单的XADC作用域应用程序。

Pynq

为了开始,我们需要一个PYNQ映像,因为MicroZed没有官方的PYNQ映像(7010或20),首先要做的是创建一个PYNQ映像。因为这样的事情是一个独立的项目,我们已经做过很多次了,我将参考你以前的项目(Zybo, Snickerdoodle和Cora),并在这里提供图像。

Vivado

首先,我们需要开发一个覆盖层,它使用AXI流接口和DMA将XADC连接到处理器系统。这使我们能够从Vp/Vn专用模拟输入中捕获连续的数据流。

•我们需要做的第一件事是创建一个新项目

•定义项目的名称和位置

•选择RTL项目并稍后定义源

•选择MicroZed板的选择。

•创建新项目。

•随着新项目的创建,创建一个新的框图。

•在新的模块设计中加入了处理器系统

•运行块自动化配置MicroZed板的处理器。

•配置好处理器后,添加XADC块。

•定制XADC模块,使其在连续模式下运行,单通道并启用AXI流。为了实现1000 ksps的采样率,我们需要将DClk设置为104 MHz,因为XADC内部采用4个时钟周期进行采集,26个时钟周期进行转换。

•禁用所有告警,单击“确定”

•添加时钟向导,因为Zynq fabric时钟无法生成所需的104 MHz时钟。

•将时钟向导的频率设置为104mhz,并将active low设置为Reset。

•配置了时钟向导后,我们需要重新定制处理系统,以提供一个主AXI接口,以便使用AXI lite在PL中配置IP。还应该实现从AXI端口,以使高带宽XADC数据能够传输到PS DDR内存进行分析。

•XADC输出AXI流不包括TLast信号,该信号需要与DMA传输一起使用。因此,应该将AXI流子集转换器添加到框图中。在主接口上启用TLast输出,并允许系统每128个事务生成一次TLast信号。

•运行连接自动化来实现AXI Lite网络,并将AXI子集转换器的AXI流输出连接到Zynq PS上的AXI MM输入。

•Vivado将自动实现AXI DMA基础架构。

•如果要更改AXI DMA中的缓冲区大小,请更改DMA设置中的缓冲区长度寄存器的设置。

•完成的框图如下所示。

•一旦完成,我们就可以构建比特流并导出XSA文件,以便在Vitis中使用。

•保持文件名和导出位置不变

•导出硬件。

Vitis

在创建PYNQ平台之前,我喜欢确保设计具有预期的功能。在本例中,我们可以使用Vitis和裸机方法来测试XADC和DMA配置。

•创建一个新的VITIS应用程序项目

•导入先前从Vivado导出的XSA

•创建一个新的应用程序项目

•创建一个新域

•选择Hello World模板

一旦完成,我们将看到创建了一个新项目,打开hello_world.C文件并将内容替换为下面的内容

运行这段代码将显示XADC的内容被传输到DDR内存中,这可以在调试系统时观察到。

现在我们很高兴平台可以工作了,下一步是创建PYNQ应用程序。

PYNQ

将MicroZed PYNQ映像写入SD卡后,我们可以引导连接到IOCC的MicroZed。一旦PYNQ启动,我们可以在PYNQ板中映射到计算机目录并创建一个新的Overlay。为此,我们需要

•由Vivado生成的位文件

•Viviado生成的HWH文件

•__init__.py初始化脚本

•Xadc_scope.py类定义

py脚本需要手工编写

__init__ . py

xadc_scope.py

有了创建的覆盖层,我们可以创建一个简单的笔记本来捕获XADC信号。

记住,DMA以字节为单位工作,XADC每个样本输出2字节。

运行下面的代码将显示捕获到的正弦波的输出

有了这个正弦波,我们可以输入转换因子,如果我们愿意的话,从原始值到电压。

PYNQ下的XADC控制

使用Vp/Vn输入,我们不需要对XADC的配置进行任何更改,但是,如果我们想要更改XADC的配置。我们可以使用标准的AXI接口来读写用UG480定义的寄存器

结论

这个项目很好地展示了我们如何使用PYNQ, XADC使用像MicroZed这样的板。MicroZed和SoM概念是快速开发硬件应用程序的一个很好的平台。该板的PYNQ映像将提供更快加速设计的能力。

本文编译自hackster.io

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭