Veristand学习札记(3)- CD的开发

1 CustomDevice开发

CD的开发必须遵照NI提供的模板进行。安装完Veristand之后,会在LabVIEW 安装目录下的vi.lib文件下生成【NI Veristand】目录,例如我安装的LabVIEW2015在D盘下,需要的工具就在D:\Program Files(x86)\National Instruments\LabVIEW 2015\vi.lib\NI Veristand\Custom DeviceTools\Custom Device Template Tool\ Custom Device Template Tool.vi。打开这个VI,使用它生成一个工程。

1.1 工程生成工具:Custom Device Template Tool.vi

图12 CD工程生成工具VI

新建一个工程,设置名称为【485 comm】,设置工程存储路径后,设置参数Execution Mode,是别的,这个还没有闹明白是什么意思。保持默认。

1.2 Custom Device Types

1.2.1 AsynchronousCustom Devices

 已参见帮助文档,待补充。

1.2.2  简历工程

运行后看效果。

图13 CD工程

竟然是个LabVIEW的工程。工程名后面自动追加“Custom Device Project”,同时生成两个lvlib库和一个xml文件,库中的VI名称自动命名,不能修改。

最重要的四个文件如下:

图14 四个VI

Initialization VI.vi 实现的功能是当 Veristand 中创建该 Custom Device 时,为Custom Device 创建相对应的属性和输入/输出通道; Main Page.vi 实现的功能是在Veristand 中显示 Custom Device 相对应的通道和属性信息; RTDriver.vi 实现的是当Veristand 将 Custom Device 部署到 Real-Time 系统之后, Custom Device Loop 中 Custom Device如何执行自己的工作。因此可以看出,前两者(Initialization和main page)运行的环境是上位机(Windows开发程序平台),可以加入“弹出对话框”等调试方式,后者的主要操作环境是 Real-Time,如果要输出调试信息,就要
采用前面提到的 Print NI VeriStand Debug String。

1.3 Initialization VI

默认的框架是这样的。

图15 Initialization框架

这个框架的主要功能就是定义你的设备的输入、输出和一些属性。整个VI的输入输出是固定的了。最常用三个VI:

:创建设备的输入和输出通道功能类型,并指定其属性和page,其中输入和输出的数据都是浮点数。这里定义的输入和输出是指的板卡或者设备本身的,相对于Veristand这个要调用他的平台,设备的输出是要给到平台的输入。

:具体指定输入和输出的通道名称、单位、默认值等信息。

图16 设定输入、输出通道

:设置自定义设备的属性和属性的值类型,默认可选择。

属性和输入/输出的区别在于:属性在配置好之后, Veristand Custom Device Loop 中只会很有限次数的访问该信息,而输入/输出在 Custom Device Loop 的每一次循环中都会被使用到;属性的数据类型包含的种类很多,比如布尔,数值,字符串,数组、变体(簇转换)等;输入/输出的数据类型在Veristand 中被限定为Double,不能更改。

根据以上信息,设定我的串口通信设备通道和属性如下:

图17 通道设置

创建了一个输入,两个输出,三个属性,但是这些是如何和板卡、Veristand联系起来的呢?

先搁置不说,等做完一个CD之后,导入到Veristand中再看。

1.4 Main page

Main page的作用是将Initlizantion中设置的属性应用起来,在Veristand中的界面展示。

图18 main page初始化前面板

在这里放置属性配置所需要的控件。当前CD中,属性有三个:串口配置参数和两个端口号。

图19 放置控件

在程序面板中,通过控件值变化的事件结构,将控件值赋给之前设置好的属性。程序中属性名称要和之前得一致。

:给属性赋值。具体实现在事件结构中,如下图所示。

图20 串口设置赋值

图21 Port1赋值

图22 Port2赋值

1.5 RT Driver

这个就是和板卡相关的了。设置的属性和输入输出通道,怎么作用于板卡,如何将数据上传到Veristand,就在这里实现。

首先,先看下整个大过程的数据流是如何执行的。初始化给了两个队列引用进来。

图23 输入、输出队列引用

1.5.1 DeviceOutputs FIFO

设备采集到的值给系统传送队列,对应的板卡采集/读取等操作,将获取到的数据以数组的形式通过这个队列发送到系统中。

图24 板卡的采集区域

同理,Input队列就是从系统中获取到要操作的值,写入板卡中。

图25 板卡写操作区

在此之前,板卡需要初始化、打开等操作。板卡的配置参数就从属性节点中获取到。

图26 获取属性值后配置串口并打开

图27 板卡写操作

图28 板卡度操作

读写部分完成之后,在最后面退出本VI时关闭资源。

图29 关闭板卡

以上,就完成了板卡的操作,并将数据通过队列与系统进行交互。

1.6 发布CD

图30 程序生成规范

在工程中,自动生成一个程序生成规范,最后生成的路径要选择在C:\Users\Public\Documents\NationalInstruments\NI VeriStand 2015\Custom Devices下才能被Veristand识别。

生成规范里面,目标目录不要修改,否则在加载之后会出现错误。

图31 生成路径

源程序和目标程序都使用默认的设置即可。

 

图32 CD发布

1.7 在Veristand中的应用

新建Veristand工程“485CD Test”,进行系统配置,

图33 在Veristand中导入

导入之后,自动加载配置的属性和通道。

图34 通道和属性节点

由上图可以看出,在Initialization VI中设置的通道名、属性名称和默认值都在这里显示,两个功能块,一个输入两个输出通道,属性面板上就是main page VI 的控件。

### 解决 VeriStand API 遇到的意外错误 当处理 VeriStand API 中遇到的意外错误时,重要的是要遵循系统的调试流程来定位并解决问题。以下是针对此类问题的具体建议: #### 错误日志分析 任何API调用失败通常会在运行环境中留下详细的错误信息或日志记录。这些日志可以帮助识别具体发生了什么以及可能的原因所在[^2]。 对于无法加载特定数据文件的情况(如 `.vs` 文件),应仔细检查该文件的内容及其路径是否正确无误。特别是注意是否有非法字符存在于字符串中,这可能是导致读取失败的一个常见原因。 #### 工具链验证 确保所有必要的开发工具已经正确安装并且版本兼容是非常重要的一步。例如,在使用 MATLAB 和 Simulink 进行模型转换至 VeriStand 的过程中,确认已安装了 Embedded Coder、Simulink Coder 及其他相关支持包[^3]。 此外,如果涉及到编译器的选择,则需保证所使用的 MinGW-w64 编译器环境设置得当,并能正常工作于当前项目之中[^1]。 #### 实现自定义逻辑扩展 尽管 VeriStand 提供了一套完整的解决方案用于大多数实时测试应用场景;然而有时仍需要通过集成第三方库或者编写额外代码实现某些特殊需求。此时可考虑利用 LabVIEW 或者直接采用C/C++语言进行更深层次的功能定制化开发[^5]。 ```c++ // 示例:简单的C函数作为接口层的一部分 #include <stdio.h> void customFunction() { printf("Custom function called.\n"); } ``` #### 文档与社区资源查询 官方文档往往是最好的求助起点之一。查阅有关 VeriStand 官方手册中的章节能够获得关于配置 workspace 添加控件等方面的知识指导[^4]。同时也可以访问在线论坛和技术交流平台寻求更多帮助和支持。
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值