于NI kb摘录
? ? ? ? 对于NI RIO系列设备(CompactRIO、sbRIO、myRIO等)进行编程时,需要注意有三个不同的组件。
????????HMI、RT 和 FPGA 在 LabVIEW 项目中都有自己独特的编程位置,并且每个组件内部和组件之间的通信方法也不同。本白皮书阐述了这些方法及其差异。下图显示了这些组件如何交互(假定 PC 用作 HMI)。
????????在深入研究不同的通信方法之前,了解数据如何从 RIO 目标上的物理输入和输出端口传输到嵌入式系统组件非常重要。使用CompactRIO时,可以通过三种方式访问??I/O:
????????编程模式由 LabVIEW 项目中模块旁边的文本指示。
????????下图显示了每种模式如何通过不重叠的唯一路径发送 I/O 数据。
????????请注意,并非所有 CompactRIO 都支持使用 NI-DAQmx 进行编程。请参阅文档了解哪些型号的 CompactRIO 支持使用 NI-DAQmx 进行编程。?
????????对 RIO 目标进行编程时,了解三种通信范例非常重要:?
????????标签类型有时称为当前值类型,用于传达最新值。标签的一个示例是操作员通过 HMI 给出的控制设定点。该标签不需要传达控制设定点的所有历史数据,而只需传达操作员输入的最新值。此外,由于不需要所有先前设定点的历史数据,因此不能保证标签传输。无保证传输的这一方面有时被称为“有损”通信。?
????????相比之下,流类型使用缓冲来传输每个数据点,其中吞吐量比延迟更重要。流通信的一种用例是通过 FPGA 将所有温度数据传输到 RT 处理器以记录到文件中。在这种情况下,历史数据是必要的,因此每个数据点的传输都得到保证。有保证的传输的这个方面被称为“无损”通信。?
????????当需要保证信息的传递并且具有低延迟时,使用最后一种通信类型,即消息。紧急停止命令是消息通信类型的一个示例。在下表中,通信选项将指定为标签、流或消息类型。在大多数情况下,由于该选项的保证传递方面,可以支持流类型的通信选项也将支持消息类型。下表总结了这些通信类型。?
通讯类型 | 基本特征 | 可选功能 | 表现 |
标签 | 仅当前值,定期读取 | 动态查找、分组管理 | 低延迟、高通道数 |
流 | 缓冲、阻塞(超时) | 多层缓冲 | 高吞吐量 |
消息 | 缓冲、阻塞(超时) | 确认数据传输 | 低延迟 |
????????
????????下表提供了 HMI、RT 处理器和 FPGA 之间不同通信选项的最高级别概述。适用时请参阅更详细的表格。单击各个链接可查找有关该通信选项的更多详细信息。
From\To | HMI | RT | FPGA |
HMI | Tag Stream Message | 详情看RT/HMI通信 | T用于 FPGA 和 RT 处理器之间通信的相同通信方法也可用于 FPGA 和 HMI 之间的通信。然而,这种情况不太常见,因为一旦通过以太网与 HMI 进行通信,就无法保证确定性。? |
RT | ??? 详情看RT/HMI通信 | 详情看RT进程间通信 | Tag Stream |
FPGA | 用于 FPGA 和 RT 处理器之间通信的相同通信方法也可用于 FPGA 和 HMI 之间的通信。然而,这种情况不太常见,因为一旦通过以太网与 HMI 进行通信,就无法保证确定性 | Tag Stream | ?? ?详情查看FPGA进程间通信 |
?
????????下表概述了 RT 程序上不同进程之间进行通信时可用的通信选项。该表分为在确定性循环(例如定时循环)与非确定性循环之间通信或在非确定性循环与另一个非确定性循环之间通信时可用的选项。最佳实践是,实时处理器上的每个内核仅运行一个确定性循环,以避免优先级冲突。
通讯类型 | 确定性循环到非确定性循环 | 非确定性循环到非确定性循环 |
标签 | ||
流、消息 |
????????下表概述了实时程序与 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 |
????????
通讯类型 | 通讯选项 | 常用 |
标签 | 局部/全局变量 | 分享最新数据 |
记忆项目 | 分享最新数据 | |
注册项目 | 分享最新数据 | |
流、消息 | 握手 | 建立持续通信的参数 |
FIFO(触发器) | 传输缓冲数据 (FIFO < 100 字节) | |
FIFO(查找表) | 传输缓冲数据 (100 字节 ≤ FIFO ≤ 300 字节) | |
FIFO(块存储器) | 传输缓冲数据 (FIFO > 300 字节) *可用块存储器的上限由FPGA目标指定 |
????????下表概述了 FPGA 上不同进程之间进行通信时可用的通信选项。有多种方法可以在两个不同的 FPGA 之间进行通信,但这里不讨论这些选项。?
? ? ? ? 此链接必看,文档范例皆有:RIO Developer Essentials Guide for Academia
Communicate Between FPGA, Real-Time Processor, and Distributed Systems - NI
????????初学者可以先看一下NI对于每个工具包的说明文档,这个对于知识盲区打开有一定的帮助。
????????????????LabVIEW Real Time Module:?产品文档 - NI ? ? ?
????????????????LabVIEW FPGA Module:产品文档 - NI
???????
嵌入式系统通常需要具有可靠性和确定性的架构。因此,许多嵌入式应用需要专门处理系统状态监测、错误处理和看门狗定时器。针对CompactRIO和PXI RT DAQ的LabVIEW项目范例提供了推荐的软件架构,可用于各种嵌入式控制与监控系统,这是满足这些需求的最佳实践。这些项目范例还给出了数据通信、网络连接、控制例程、数据记录等的最佳实践。
为了在LabVIEW中查看这些模板,您必须安装LabVIEW Real-Time和/或LabVIEW FPGA模块。
CompactRIO的LabVIEW FPGA控制 此项目范例专为需要高性能控制和/或基于硬件的安全逻辑的应用程序而设计。控制通过FPGA架构实现,而并非在软件中运行控制算法,使控制循环速率能够达到10 kHz以上,且抖动极小。FPGA VI还包含安全逻辑,可在出现严重错误或者实时软件故障时立即将所有输出设置成安全状态,从而更大限度地确保系统的可靠性。 | |
CompactRIO的LabVIEW Real-Time控制(RIO扫描接口) 此项目范例专为需要确定性控制性能的控制应用而设计,其单点I/O速率不超过100 Hz。此项目范例不使用FPGA硬件,而是使用确定性的实时处理器进行系统控制。此范例使用RIO扫描接口(RSI)在实时应用中获取I/O数据,如同变量一样。 | |
CompactRIO的LabVIEW FPGA波形采集与记录 此项目范例包含基于FPGA的可自定义高速模拟采集,并可在满足触发条件时,将采集到的数据记录至实时系统的磁盘。此项目范例可以自主运行,或者连接到所提供的可选用户界面。 | |
CompactRIO的LabVIEW Real-Time序列生成器 此项目范例可实现序列引擎,可针对控制应用在LabVIEW Real-Time中执行用户自定义的序列或方法。它包括一个基于Windows的用户界面,该界面能够生成用户定义的序列,将此类序列部署到CompactRIO,以及监测序列引擎状态。用户界面动态加载子面板,展示了高效、响应流畅的用户界面架构。 |
LabVIEW Real-Time (NI-DAQmx)项目范例专为实时控制和/或波形采集与记录应用而设计。
LabVIEW Real-Time控制(NI-DAQmx) 实现基于软件的确定性设备控制。此项目范例采用NI-DAQmx,并专为使用NI Real-Time PXI控制器和NI DAQ且需要确定性DAQ控制I/O的控制应用而设计。 | |
LabVIEW Real-Time波形采集与记录(NI-DAQmx) 采集连续波形数据并将数据记录至磁盘。此项目范例采用NI-DAQmx,包含模拟数据采集,并在可满足触发条件时,将采集到的数据记录至实时系统的磁盘。此项目范例可以自主运行,或者连接到所提供的可选用户界面。此范例专为使用NI Real-Time PXI控制器和NI DAQ或者NI独立式CompactDAQ的应用而设计。 |