博客写作背景----项目中解决的问题
最近遇到一个使用stm32单片机多路采集信号的项目,还需要在上位机进行波形的查看,信号算法的处理,初步定为使用labview编写上位机程序进行处理。为啥用labview呢,因为LabVIEW是美国国家仪器公司(NI)的创新软件产品,其全称是实验室虚拟仪器工程平台(Laboratory Virtual Instrument Engineering Workbench),是一种基于G语言(Graphics Language,图形化编程语言)的测试系统软件开发平台。LabVIEW并不局限于虚拟仪器的开发,它的作用是为大型复杂测试系统提供通用的软件开发平台。目前,LabVIEW已经成为测试领域应用最广泛和最有前途的软件开发平台之一。
下面是我最近写程序的一些知识,进行了部分的整理,发出来和大家一起分享,也方便我以后查找自己的编程过程。
编程知识点–做题思路
触发VI为DAQmx Trigger. vi,该VI配置一个触发器使DAQ设备完成一个特定的动作,最为常用的动作是Start Trigger(启动触发)和Reference Trigger(参考触发)。启动触发初始化一个采集或生成,参考触发则在采样集中的位置设置一个参考点,在那里触发前数据采集结束,而触发后数据采集开始。这些触发都可以配置成发生在Digital Edge(数字边沿)、Analog Edge(模拟边沿)或者Analog Window(模拟信号进入或离开窗口)的时候。
下面介绍几个触发VI的常用实例。
(1)Start Digital Edge实例
在数字信号上升沿或下降沿触发任务的采集或生成操作,
source输入端口:指定触发源数字信号的端口名。
edge输入端口:指定是在数字信号的上升还是下降沿触发。
(2)Start Analog Edge实例
在指定的模拟信号边沿触发任务的采集或生成操作
source输入端口:指定触发源模拟信号的端口或虚拟通道名。对于E系列设备,触发信号端口只能是PFI0,触发信号通道必须是通道列表中第一个通道。
slope输入端口:指定是在信号的上升还是下降过程触发。
level输入端口:一个用于触发的设定值,当触发信号按照slope指定的方式达到该设定值时,启动任务操作。
(3)Reference Digital Edge实例
当设备检测到数字信号触发边沿时,停止触发前数据采集,并开始触发后数据采集,其图标和端口如图
(4)读取VI
读取VI为DAQmx Read. vi,该VI从任务或指定的虚拟通道读取数据样本,实际上也是从缓存中读取数据。它的各个实例指定了返回数据的格式、每次读取单个还是多个样本、从一个还是多个通道读取。
在应用中,用户应该根据实际测量情况,选择恰当的实例。通过实例名称,用户可以很容易判知返回数据的形式。
以Analog 1D DBL 1Chan NSamp为例,其第一项表示任务操作类型,这里Analog表示模拟操作;第二项表示返回数据结构形式,是单个数据还是数组,若该项不存在,则表示单个数据,这里1D表示是一维数组;第三项表示数据类型,这里DBL表示双精度浮点数;第四项表示从单个还是指定数目的通道读取数据样本,这里1Chan表示从单个通道读取样本;最后一项表示每次读取单个还是指定数目的样本,这里NSamp表示每次读取指定数目样本。
number of samples per channel输入端口:指定读取的数据样本数。若该端口没有赋值或设置为-1时,NI-DAQmx会依据该任务是连续采样还是有限采样而决定每次读取的样本数。当连续采样时,该VI会读取当前缓存中所有可读的样本;当有限采样时,该VI会等待任务获取了所有被请求的样本,然后将这些样本从缓存中全部读出。
(5)启动任务VI
启动任务VI为DAQmx Start Task. vi,如图4-70所示,该VI显式地将一个任务转换至运行状态,在运行状态,这个任务将完成特定的采集或生成。如果程序中没有使用该VI,当“读取”或“写入”VI执行时,任务可以隐式地转换至运行状态,或者自动开始。