【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理

这篇具有很好参考价值的文章主要介绍了【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

于NI kb摘录

1.概述

        对于NI RIO系列设备(CompactRIO、sbRIO、myRIO等)进行编程时,需要注意有三个不同的组件。

  • 人机界面 (HMI) 。有时称为“主机”,为用户提供图形用户界面(GUI),用于监控系统状态和设置操作参数。使用 HMI 是可选的,因为 RIO 产品可以编程为无头运行,并且有些产品可以直接连接到嵌入式用户界面,但是当实施 HMI 时,它们可以采用 Windows 台式计算机、平板电脑或触摸面板的形式以计算机为例。
  • 实时(RT)处理器:RT 处理器运行主要的实时程序,并且允许 RIO 可靠地执行具有特定时序要求的程序。
  • 现场壳编程门阵列:FPGA是一种可重新编程的硅芯片,是嵌入式系统的核心。FPGA 将机箱 I/O 直接连接到 RT 处理器,无需通过总线,与其他控制器架构相比,系统响应的控制延迟非常低。由于 FPGA 通过 LabVIEW FPGA 模块在硬件而不是软件中运行其代码,因此其速度和可靠性通常用于使用高速缓冲 I/O、快速控制循环或自定义信号过滤的应用。

        HMI、RT 和 FPGA 在 LabVIEW 项目中都有自己独特的编程位置,并且每个组件内部和组件之间的通信方法也不同。本白皮书阐述了这些方法及其差异。下图显示了这些组件如何交互(假定 PC 用作 HMI)。

【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理,NI-RIO入门【CompactRIO】,CompactRIO

2.调用IO

        在深入研究不同的通信方法之前,了解数据如何从 RIO 目标上的物理输入和输出端口传输到嵌入式系统组件非常重要。使用CompactRIO时,可以通过三种方式访问​​I/O:

  1. 对于实时(NI-DAQmx)模式,数据通过处理器通过 NI-DAQmx VI 读取。
  2. 对于实时扫描(IO变量)模式,数据通过FPGA发送,但最终通过将IO节点拖放到实时VI来在处理器上访问。
  3. 对于LabVIEW FPGA模式,通过将IO节点拖放到FPGA VI中,可以直接从FPGA内部读取I/O。

        编程模式由 LabVIEW 项目中模块旁边的文本指示。

        下图显示了每种模式如何通过不重叠的唯一路径发送 I/O 数据。

【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理,NI-RIO入门【CompactRIO】,CompactRIO

        请注意,并非所有 CompactRIO 都支持使用 NI-DAQmx 进行编程。请参阅文档了解哪些型号的 CompactRIO 支持使用 NI-DAQmx 进行编程。 

3.标签、流、消息

        对 RIO 目标进行编程时,了解三种通信范例非常重要: 

        标签类型有时称为当前值类型,用于传达最新值。标签的一个示例是操作员通过 HMI 给出的控制设定点。该标签不需要传达控制设定点的所有历史数据,而只需传达操作员输入的最新值。此外,由于不需要所有先前设定点的历史数据,因此不能保证标签传输。无保证传输的这一方面有时被称为“有损”通信。 

        相比之下,流类型使用缓冲来传输每个数据点,其中吞吐量比延迟更重要。流通信的一种用例是通过 FPGA 将所有温度数据传输到 RT 处理器以记录到文件中。在这种情况下,历史数据是必要的,因此每个数据点的传输都得到保证。有保证的传输的这个方面被称为“无损”通信。 

        当需要保证信息的传递并且具有低延迟时,使用最后一种通信类型,即消息。紧急停止命令是消息通信类型的一个示例。在下表中,通信选项将指定为标签、流或消息类型。在大多数情况下,由于该选项的保证传递方面,可以支持流类型的通信选项也将支持消息类型。下表总结了这些通信类型。 

通讯类型 基本特征 可选功能 表现
标签 仅当前值,定期读取 动态查找、分组管理 低延迟、高通道数
缓冲、阻塞(超时) 多层缓冲 高吞吐量
消息 缓冲、阻塞(超时) 确认数据传输 低延迟

 4.通信选型摘要

        

        下表提供了 HMI、RT 处理器和 FPGA 之间不同通信选项的最高级别概述。适用时请参阅更详细的表格。单击各个链接可查找有关该通信选项的更多详细信息。

From\To HMI RT FPGA
HMI

Tag

  • Local Variable
  • Global Variable
  • Notifiers
  • Functional Global Variable (FGV)

Stream

  • Queues
  • Channel Wires (as of 2016)

Message

  • User Events
详情看RT/HMI通信 T用于 FPGA 和 RT 处理器之间通信的相同通信方法也可用于 FPGA 和 HMI 之间的通信。然而,这种情况不太常见,因为一旦通过以太网与 HMI 进行通信,就无法保证确定性。 
RT

   

详情看RT/HMI通信

详情看RT进程间通信

Tag

  • Read/Write Control 
  • User Defined Variables
  • Interrupts

Stream

  • DMA FIFO
  • Host Memory Buffer
FPGA 用于 FPGA 和 RT 处理器之间通信的相同通信方法也可用于 FPGA 和 HMI 之间的通信。然而,这种情况不太常见,因为一旦通过以太网与 HMI 进行通信,就无法保证确定性

Tag

  • Read/Write Control 
  • User Defined Variable 
  • Interrupts

Stream

  • DMA FIFO
  • Host Memory Buffer

  

 详情查看FPGA进程间通信

 

RT进程间通信

        下表概述了 RT 程序上不同进程之间进行通信时可用的通信选项。该表分为在确定性循环(例如定时循环)与非确定性循环之间通信或在非确定性循环与另一个非确定性循环之间通信时可用的选项。最佳实践是,实时处理器上的每个内核仅运行一个确定性循环,以避免优先级冲突。

通讯类型 确定性循环到非确定性循环 非确定性循环到非确定性循环
标签
  • 启用 RT FIFO 的单进程共享变量(单个元素)
  • 单进程共享变量
  • 局部变量
  • FGV
  • 通知者
流、消息
  • RT 先进先出功能
  • 尾巴
  • 用户事件(仅限消息)

RT/HMI 通讯

        下表概述了实时程序与 Windows PC 上运行的 HMI 之间进行通信时可用的不同通信选项。该表还列出了通信选项是否支持一个或多个 RT 处理器或 HMI 之间的通信。值得注意的是,我们的 CompactRIO 目标运行 64 位 NI Linux Real-Time 操作系统,有一个嵌入式 UI 选项,允许显示 Real-Time VI 的前面板。在这种情况下,无需对 HMI 进行编程。

通讯类型 通讯选项 RT 目标数量:HMI 数量
标签 网络发布的共享变量 1:1、1:N、N:1
TCP/IP 1:1
UDP协议 1:N 或 N:1
网页服务 1:1、1:N
流、消息 网络流 1:1
TCP/IP(仅消息) 1:1

 FPGA 进程间通信

        

通讯类型 通讯选项 常用
标签 局部/全局变量 分享最新数据
记忆项目 分享最新数据
注册项目 分享最新数据
流、消息 握手 建立持续通信的参数
FIFO(触发器)

传输缓冲数据

(FIFO < 100 字节)

FIFO(查找表)

传输缓冲数据

(100 字节 ≤ FIFO ≤ 300 字节)

FIFO(块存储器)

传输缓冲数据

(FIFO > 300 字节)

*可用块存储器的上限由FPGA目标指定

        下表概述了 FPGA 上不同进程之间进行通信时可用的通信选项。有多种方法可以在两个不同的 FPGA 之间进行通信,但这里不讨论这些选项。 

5.RIO开发人员必备指南 

        此链接必看,文档范例皆有:RIO Developer Essentials Guide for Academia

 6.FPGA、实时处理器和分布式系统之间的通信范例

Communicate Between FPGA, Real-Time Processor, and Distributed Systems - NI

其他

        初学者可以先看一下NI对于每个工具包的说明文档,这个对于知识盲区打开有一定的帮助。

                LabVIEW Real Time Module: 产品文档 - NI      

                LabVIEW FPGA Module:产品文档 - NI

       

LabVIEW Real-Time和LabVIEW FPGA项目范例

嵌入式系统通常需要具有可靠性和确定性的架构。因此,许多嵌入式应用需要专门处理系统状态监测、错误处理和看门狗定时器。针对CompactRIO和PXI RT DAQ的LabVIEW项目范例提供了推荐的软件架构,可用于各种嵌入式控制与监控系统,这是满足这些需求的最佳实践。这些项目范例还给出了数据通信、网络连接、控制例程、数据记录等的最佳实践。

为了在LabVIEW中查看这些模板,您必须安装LabVIEW Real-Time和/或LabVIEW FPGA模块。

CompactRIO项目范例

【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理,NI-RIO入门【CompactRIO】,CompactRIO

CompactRIO的LabVIEW FPGA控制

此项目范例专为需要高性能控制和/或基于硬件的安全逻辑的应用程序而设计。控制通过FPGA架构实现,而并非在软件中运行控制算法,使控制循环速率能够达到10 kHz以上,且抖动极小。FPGA VI还包含安全逻辑,可在出现严重错误或者实时软件故障时立即将所有输出设置成安全状态,从而更大限度地确保系统的可靠性。

参阅相关文档 | 参阅NI社区的详细指南

【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理,NI-RIO入门【CompactRIO】,CompactRIO

CompactRIO的LabVIEW Real-Time控制(RIO扫描接口)

此项目范例专为需要确定性控制性能的控制应用而设计,其单点I/O速率不超过100 Hz。此项目范例不使用FPGA硬件,而是使用确定性的实时处理器进行系统控制。此范例使用RIO扫描接口(RSI)在实时应用中获取I/O数据,如同变量一样。

【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理,NI-RIO入门【CompactRIO】,CompactRIO

CompactRIO的LabVIEW FPGA波形采集与记录

此项目范例包含基于FPGA的可自定义高速模拟采集,并可在满足触发条件时,将采集到的数据记录至实时系统的磁盘。此项目范例可以自主运行,或者连接到所提供的可选用户界面。

【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理,NI-RIO入门【CompactRIO】,CompactRIO

CompactRIO的LabVIEW Real-Time序列生成器

此项目范例可实现序列引擎,可针对控制应用在LabVIEW Real-Time中执行用户自定义的序列或方法。它包括一个基于Windows的用户界面,该界面能够生成用户定义的序列,将此类序列部署到CompactRIO,以及监测序列引擎状态。用户界面动态加载子面板,展示了高效、响应流畅的用户界面架构。

查看视频教程

Real-Time项目范例(使用DAQmx)

LabVIEW Real-Time (NI-DAQmx)项目范例专为实时控制和/或波形采集与记录应用而设计。

【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理,NI-RIO入门【CompactRIO】,CompactRIO

LabVIEW Real-Time控制(NI-DAQmx)

实现基于软件的确定性设备控制。此项目范例采用NI-DAQmx,并专为使用NI Real-Time PXI控制器和NI DAQ且需要确定性DAQ控制I/O的控制应用而设计。

参阅相关文档文章来源地址https://www.toymoban.com/news/detail-771495.html

【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理,NI-RIO入门【CompactRIO】,CompactRIO

LabVIEW Real-Time波形采集与记录(NI-DAQmx)

采集连续波形数据并将数据记录至磁盘。此项目范例采用NI-DAQmx,包含模拟数据采集,并在可满足触发条件时,将采集到的数据记录至实时系统的磁盘。此项目范例可以自主运行,或者连接到所提供的可选用户界面。此范例专为使用NI Real-Time PXI控制器和NI DAQ或者NI独立式CompactDAQ的应用而设计。

参阅相关文档

到了这里,关于【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • Elasticsearch 中的“近实时”(Near Real-time)全面解析

    Elasticsearch(ES)作为一款流行的分布式搜索引擎,以其近实时(Near Real-Time, NRT)特性著称。这种特性使得ES能够在数据写入后极短的时间内(通常在毫秒至秒级别)使其可被搜索到,虽然不是绝对意义上的实时,但对于大多数应用而言已经足够接近实时,从而满足了对快速响

    2024年04月25日
    浏览(9)
  • Training-Time-Friendly Network for Real-Time Object Detection 论文学习

    Training-Time-Friendly Network for Real-Time Object Detection 论文学习

    目前的目标检测器很少能做到快速训练、快速推理,并同时保持准确率。直觉上,推理越快的检测器应该训练也很快,但大多数的实时检测器反而需要更长的训练时间。准确率高的检测器大致可分为两类:推理时间久的的训练时间久的。 推理时间久的检测器一般依赖于复杂的

    2024年02月15日
    浏览(17)
  • Why choose Flink for real-time processing

    Why choose Flink for real-time processing

    Why choose Flink [1] Streaming data more truly reflects our lifestyle (real-time chat); [2] Traditional data architecture is based on limited data sets (Spark is based on micro-batch data processing); [3] Our goal: low latency, high throughput (distributed architecture, there may be confusion in the order, for example, within 1 hour of statistics, some data

    2024年03月20日
    浏览(9)
  • 【论文阅读】【yolo系列】YOLACT Real-time Instance Segmentation

    【论文阅读】【yolo系列】YOLACT Real-time Instance Segmentation

    论文链接:https://arxiv.org/pdf/1904.02689.pdf 【 实例分割 】 鉴于其重要性,大量的研究投入到实例分割的准确性。 两阶段 :Mask-RCNN [18]是一种具有代表性的两阶段实例分割方法,它首先生成候选感兴趣区域(roi),然后在第二阶段对这些roi进行分类和分割。后续工作试图通过提

    2024年02月16日
    浏览(7)
  • Publishing real-time financial data feeds using Kafka

    Good morning and welcome to this session on publishing real time financial data feeds using CCA. If you\\\'re a data feed provider, you may already have customers who are asking you to deliver your feed directly on AWS. And by the time we end this session, you should have a pretty good understanding of how to do that. My name is Rana. I am a Principal Solutions

    2024年02月03日
    浏览(13)
  • DETRs Beat YOLOs on Real-time Object Detection

    DETRs Beat YOLOs on Real-time Object Detection

    DETRs在实时目标检测中击败YOLO 问题:DETR的高计算成本,实时检测效果有待提高 解决:提出了一个实时的目标检测器 具体来说,设计了一个高效的混合编码器,通过解耦尺度内的交互和跨尺度融合来有效处理多尺度特征,并提出IoU感知查询选择,通过提供更高质量的初始对象

    2024年02月09日
    浏览(10)
  • 【USRP X310】如何将你的X310转化为USRP RIO 可以用于FPGA编程

    【USRP X310】如何将你的X310转化为USRP RIO 可以用于FPGA编程

    NI-USRP Ettus X310 USRP-2940R X310 + WBX (x2) USRP-2942R X310 + SBX (x2) USRP-2943R X310 + CBX (x2) USRP-2944R X310 + UBX (x2) USRP-2945R X310 + TwinRX (x2) USRP-2950R X310 + WBX (x2) + GPSDO USRP-2952R X310 + SBX (x2) + GPSDO USRP-2953R X310 + CBX (x2) + GPSDO USRP-2954R X310 + UBX (x2) + GPSDO USRP-2955R X310 + TwinRX (x2) + GPSDO NI发布的USRP版本事封

    2024年02月05日
    浏览(8)
  • 【语音增强论文解读 03】TCNN: TEMPORAL CONVOLUTIONAL NEURAL NETWORK FOR REAL-TIME SPEECHENHANCEMENT IN THE TIME

    【语音增强论文解读 03】TCNN: TEMPORAL CONVOLUTIONAL NEURAL NETWORK FOR REAL-TIME SPEECHENHANCEMENT IN THE TIME

    作者:Ashutosh Pandey and DeLiang Wang 文末附文章地址及其开源代码地址         尽管使用 T-F 表示是最流行的方法,但它也有一些缺点。首先,这些方法通常忽略干净的相位信息,并使用噪声相位进行时域信号重建。         受成功实现用于序列建模的 TCNN 以及基于编解码

    2024年02月02日
    浏览(12)
  • 3D Gaussian Splatting for Real-Time Radiance Field Rendering 阅读笔记

    3D Gaussian Splatting for Real-Time Radiance Field Rendering 阅读笔记

    感谢B站意の茗的讲解。 论文地址:https://arxiv.org/abs/2308.04079 项目主页:https://repo-sam.inria.fr/fungraph/3d-gaussian-splatting/ 从已有点云模型出发(sfm),以每个点为中心建立可学习的3D高斯表达,Splatting方法进行渲染,实现高分辨率实时渲染。(推动NERF加速方向) 能用训练好的点云

    2024年01月16日
    浏览(26)
  • 【读论文】3D Gaussian Splatting for Real-Time Radiance Field Rendering

    【读论文】3D Gaussian Splatting for Real-Time Radiance Field Rendering

    What kind of thing is this article going to do (from the abstract and conclusion, try to summarize it in one sentence) To simultaneously satisfy the requirements of efficiency and quality, this article begins by establishing a foundation with sparse points using 3D Gaussian distributions to preserve desirable space. It then progresses to optimizing anisotrop

    2024年04月09日
    浏览(10)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包