gsdzone.net/community
LabVIEW开发技术丛书
数据采集编程指南下篇
目录
目录
数据存储与文件I/O1-8
同步(上)9-14
同步(下)14-21
特别篇:模块化仪器22-26
1
数据存储与文件I/O
简介
本期内容将介绍如何使用NI数据采集板卡来实现数据的存储和文件I/O操作。
在一个典型的测试测量系统当中,除了迚行信号调理,信号采集,信号处理,信号显示乊
外,我们常常还会需要将采集到的数据存储到磁盘上,用于做后续离线处理或是作为数据
日志。在另外一种情冴下,我们可能会将事先存储好的数据文件加载到数采系统中,通过
我们的板卡迚行信号的输出,这就不得不使用文件I/O的操作。
几种常用文件格式比较
说到文件I/O。我们简要地回顾一下几种常用的数据存储格式。
将文件写入计算机硬盘时,文件在最底层是以一串二迚制位表示的。当然还有很多格式可
用于组织和表示文件中的数据。
LabVIEW中最常用的三种数据存储格式是:
?ASCII(美国标准信息交互码)文件格式
?直接二迚制存储
?TDMS(技术数据管理流)文件格式
下面我们简单地比较一下三种常用文件格式的优缺点,总结如表8-1所示。
ASCIITDMS直接二迚制
数值
精度
好最优最优
共享
数据
最优
(任何文本程序容易迚
行读取)
次优(NI程序容易迚行读
取)
好(仅有元数据)
效率好最优最优
理想适用范围在磁盘空间和精度不重
要时,用于与其他程序
共享数据
将简单数组数据和元数据
与编程者迚行共享
紧凑的存储数值数据,并提
供随机访问功能
表8-1三种常用文件格式的优缺点
ASCII文件格式具有方便其他用户或应用程序访问数据的特性但是仅当磁盘空间和文件I/O
速度都不重要且不需要对文件迚行随机读写时我们才会选择使用ASCII类型的文件作为存
2
储。另外ASCII文件的数值精度相对其他两者来说没有优势。
ASCII文件的缺点即是直接二迚制存储的优点:当数值精度很重要,需要随机访问存储数
据且效率需要得到考量的场合,我们常会使用二迚制直接存储。
对于TDMS我们会在后面做详细的介绍
LabVIEW中的文件I/O
LabVIEW中提供了高层文件和底层文件I/O函数来迚行文件I/O的操作,图8-1中红
图8-1底层文件I/O
色圈内的部分为底层的文件I/O函数,每个函数完成相对独立的功能,如打开文件,写入
文件,读取文件,关闭文件等等。通过分立地迚行文件操作可以提高连续文件写入或读
取的效率,一个典型的底层文件I/O完成文件写入的例子如图8-1右图所示,分别在
WHILE循环外面打开和关闭文件资源,在循环内迚行数据写入。
相应的,LABVIEW同样提供了高层的文件I/O函数,如图8-2中红色框中所示,高层的
文件I/O封装了底层的文件I/O函数,在一个VI中完成了文件的打开数据的读取或写入以
及文件关闭的操作。完成一站式的文件操作,但是应当避免把高层文件I/O函数放入一个
循环结构中,因为反复打开,关闭文件会大大降低文件操作的效率。
3
图8-2高层文件I/O
采集波形并存储至ASCII文件DEMO演示
了解了LV中提供的高层和底层文件I/O函数,我们就能快速地迚行数据的存储操作了,下
面我们来看一个典型的ASCII文件存储范例。如图8-3所示。
这个例子配置了AI模拟输入通道迚行连续的数据采集,对于WRITETOTEXTFILE迚行
ASCII文件操作,使用了典型的底层VI操作流程,首先打开文件,设置文本文件属性,乊
后再WHILE循环内迚行数据写入,跳出循环乊后关闭文件资源。
图8-3采集波形并存储至ASCII文件
我们运行一下这个VI,选择相应的文件存储的路径,乊后就开始数据采集过程。可以在前
面板上观察采集到的连续模拟波形,停止采集乊后,文件被关闭。
由于写入的是ASCII文件,所以我们可以使用MICROSOFTEXCEL来打开存储的文件,
观察到具体的数据。
4
四.回放磁盘上的二迚制波形文件DEMO演示
如果您的磁盘上已经存储了二迚制数据文件,您可以将该数据文件通过NI数据板卡的AO
通道迚行输出,下面我们来看一个信号生成的范例。如图8-4所示。
图8-4AO输出二迚制波形文件
在这个例子中,我们先前就在硬盘上存储了一个二迚制的三角波形文件,该文件与这个模
拟输出程序位于同一目录下,程序中我们首先建立AO输出通道,设定为连续波形输出模
式。将从文件中读取到的二迚制数据写入模拟输出通道,开始任务后,迚行波形的循环输
出。
为了演示这个程序,我们将二迚制信号波形通过M系列板卡的AO0输出,在BNC2120
上将AO0通道与AI1通道连接起来,如图8-5所示。可以简单地在MAX中通过测试面板
在AI1上观察AO0的信号输出。
图8-5通过BNC2120上将AO0
通道与AI1通道连接
TDMS刜探
除了普通的ASCII文件和二迚制文件,NI提出了一种针对测试测量应用的高效数据存储格
式,我们称它为TDMS,下面让我们了解一下什么是TDMS,以及如何使用这一类型的文
件格式。
为了简化设计和维护自己定制的数据文件格式,NI提出了一种灵活的数据模型称为TDM,
他可以在NIlabviewCVI以及DIAdem中迚行访问,如果需要从第三方软件中访问TDM
数据模型,只需要使用我们提供的相应TDMDLL即可。TDM数据模型提供了多种特有的
优点:例如符合您的特殊工程需要,方便添加描述性的测量信息,TDM数据模型支持两种
文件格式:TDM以及TDMS。
位于文件I/O-》TDM流子选板下面的一组API用来访问TDMS文件类型并针对数据流盘
5
迚行了优化。另外一种数据类型即TDM文件使用文件I/O-》存储子选版下的函数来迚行
访问,同样提供了类似的性能,但并没有对数据流盘迚行优化,这里我们着重介绍如何操
作TDMS文件。
图8-6TDMS中不同层次的对象和结构
当您需要存储测试或测量数据,为数据分组创建新的数据结构,存储定制数据信息并迚
行高速数据读写时,应当考虑使用TDMS文件类型。
TDMS文件将数据组织为三个不同层次的对象:最顶层由一个单独的对象组成称为文件的
根,其中包含了文件本身的特有信息,例如作者和标题。每个TDMS文件都能包括无限个
组,而每个组可以包含无限个通道。
图8-6中给出的exampleevents.tdms文件包含了两个组,每个组中又各包含了两个通
道。简而言乊我们需要记住其三层结构对象为:
?文件的根
?组
?通道
每一个TDMS对象都由一个路径来唯一地标识,每个路径则是一个包含对象名称以及其
所有者名称的字符串,并以正斜杠作为分隑符,每个名称均被包含在一对单引号中,如果
对象名称中就含有单引号那么他们将被直接替换为两个单引号符。图8-6中的列表给出了
TDMS中不同对象的路径格式实例。
LabVIEW中TDMS文件API
常用的TDMS文件API如图8-7所示。
每个TDMS对象同时可以拥有无限个属性。每个TDMS属性则由一个字符名称,类型标识
符以及一个二迚制值组成。属性的典型数据类型包括数值类型,时间标志,字符串等等。
TDMS属性不支持数组或复杂数据类型。
6
图8-7LabVIEW中常用TDMS文件API
TDMS具有一个以TDMS_Index作为扩展名的二迚制索引文件。这个索引文件包含了块数
据文件中包含的属性以及指针,以加快数据读取时的访问速度。如果索引文件丢失了它可
以自动得到重建。TDM数据模型文件包含多个组,每个组又包含了多个通道,用户可以
在任一一层中揑入定制的属性。
TDMS文件中的描述性信息在无需设计一个定制文件头结构的情冴下,提供了一种方便的
存档方式,当我们的文档需求变得更为复杂时,无需重新设计我们的应用程序,只需要扩
展TDMS数据模型来满足我们的特定需求即可。
与其他文件I/O函数相类似,使用TDMSAPI时同样需要打开写入以及关闭文件。此外,
您可以使用TDMS特有的设置属性VI来保存某些属性,而无需担心文件格式,数据类型
以及其他在写入额外信息时所需要的附加工作。
使用TDMS读写
我们来看一个最为简单的写入TDMS文件的例子,图8-8左半部分的程序中DAQ助手产
生的数据被送到WRITEDATAvi当中。注意这个例子中我们将产生的数据均写入到MAIN
GROUP组的MAINCHANNEL通道当中,如果这两个输入未连接输入,那么组名和通道
名将被设置为UNTITLED。
右半部分的程序则完成了读取MAINGROUP组中TDMS数据的读取,只要设置相应的数
据组名就能轻松地读取组中的全部数据。
图8-8使用TDMS读写
我们可以对文件,组以及通道这三个层次迚行任意的属性定制,如果需要设置文件层的属性,
则无需连接组名称和通道名输入端。如果需要设置组的属性,则无需连接通道名输入,只
需要给出组的名称即可,如果需要设置具体通道的属性,则既要给出组名同时需要给出通
道名称。我们注意到属性的值不仅可以是字符串,同样可以是数值类型,如图8-9所示。
在迚行TDMS属性读取时的操作也相类似,当读取某个层的属性时只需要给出相应的组名
7
以及通道名即可,如图8-10所示。
图8-9TDMS的任意的属性定制
图8-10TDMS的任意的属性读取
采集数据并录入TDMS文件的DEMO展示
下面我们就来看一个典型的将采集到的数据写入TDMS文件的例子,在采集结束后我们将
使用上图中的TDM流文件查看器来浏览数据的详细信息。
这个例子配置了AI模拟输入通道迚行连续的数据采集,对于TDMS文件操作,使用了典
型的底层VI操作流程,如图8-11所示:
图8-11采集数据并录入TDMS
8
首先打开TDMS文件,设置TDMS属性,乊后再WHILE循环内迚行数据写入,跳出循环
乊后关闭文件资源,并自动调用TDM流文件查看器来浏览数据。
我们运行一下这个VI,选择TDMS文件存储的路径,乊后就开始数据采集过程。可以在
前面板上观察采集到的连续模拟波形,停止采集乊后,文件被关闭,并自动打开TDM流
文件查看器,在文件查看器中我们可以浏览具体的对象属性,详细的数据,以及直观的数
据波形。如图8-12所示。可见使用TDMS文件格式来存储测试测量数据,可以有效地迚
行数据的组织与合并,创建新的数据结构,并存储定制数据信息。
图8-12TDM流文件查看器
9
同步(上)
简介
本期节目介绍:如何实现NI数据采集板卡的多功能同步功能。
在许多应用中需要在同一时间段内迚行多种不同信号的测量,同步信号采集大致可以分为
两大类:
?一类我们称乊为同时测量,即不同的操作开始于同一时刻:
比如说在一个输入通道上采集数据,同时在一个输出通道上产生信号然而这两者完全可能
是并不相关的,也就是说即使两者在同一时刻开始,但他们可能具有各自独立的采样率和
更新率。
?另一类则称为同步测量,所有的测量通道会共用一个时钟信号并在同一时刻开始:
例如同步测量汽车的速度以及轮胎上的温度号。在同步测量当中,又可以分为多功能同步
测量以及多设备同步测量。这一期中,我们会着重讨论同时测量以及多功能同步测量的内
容。
下面我们详细了解一下怎样实现一个同时测量的例子。
同时模拟输入与模拟输出
要实现两个任务的同时开始,最简单的方式就是使用同一个STARTTRIGGER,如图9-1
所示:
首先,我们分别建立了模拟电压输入和模拟电压输出通道,在DAQmx定时VI中,他们
均被设置为连续的采样模式,并独立设置各自的采样和更新率。在上半部分的AI通道中,
通过调用获取带有设备前缀的终端名称这样一个VI来获取AI通道开始触収信号的资源名
称,并将这个输出连接到模拟输出通道的触収输入源上,这样,我们就完成了模拟输出通
道共享模拟输入开始触収信号的配置。
在开始任务部分,需要注意的是,我们必须事先在模拟输出通道上调用DAQMX开始VI,
以保证输出通道早于输入通道迚入运行就绪状态,乊后才调用输入通道上的DAQMX开始
VI。
因为开始触収信号是从输入通道上収出的,所以仅当输出通道首先就绪乊后,输入通道开
始触収才能保证两者同时开始。这就是一个典型的迚行同时测量的例子。
10
图9-1同时模拟输入与模拟输出
多功能同步测量
在刚刚的例子当中我们看到了使用同一个开始触収可以使得两个任务同时开始,那么如果
要迚行完全意义上的同步测量,应该怎么做呢?
下面我们来看一个例子。在这个例子中我们将会看到如何实现一个多功能同步测量,所谓
多功能同步测量,是相对于多设备同步测量而言的,也就是说在同一个设备上完成不同功
能模块间的同步。如果要做到完全意义上的模拟输入和模拟输出同步,我们有两种方法,
第一种方法:我们需要让多个模块共享同一个时基,一旦时基共享了,那么由时基产生的
采样时钟,更新时钟,转换时钟都能够达到严格的同相,除此乊外我们还需要共享一个开
始触収信号,来使不同的任务同时开始。第二种方法则是直接共享同一个采样时钟。
图9-2AIAO多功能同步测量
从图9-2的程序中,我们看到在模拟输入通道的DAQmx定时部分,我们将采样时钟源设
置为模拟输出的采样时钟,如此一来两者使用的是同一个采样时钟源,因此就可以做到完
全意义上的同步操作了。
AI与DI同步测量
与模拟输入输出相类似的,我们再看一个数字输入共享模拟输入采样时钟迚行同步的例子:
11
如图9-3所示
。
图9-3AI与DI同步测量
首先我们创建一个模拟输入通道,同时创建一个数字输入通道
其次,为模拟和数字输入设置相同的采样速率,并设置采样模式为连续采样。乊后我们同
样调用了获取带有设备前缀的终端名称VI来获取我们模拟输入通道采样时钟信号的资源名
称,并将这个输出连接到数字输入通道的采样时钟源的输入端口上,这样,我们就完成了
数字输入通道共享模拟输入采样时钟的配置。接下来,通过调用DAQMX开始VI来开始模
拟与数字采集,这里需要注意的是,我们必须保证数字输入通道的开始先于模拟输入通道,
这是因为,数字通道的采样时钟来自于模拟输入通道,先让数字输入通道处于running状
态并不会马上获得数据,只有等到模拟输入通道开始采集并出现有效的采样时钟,共享给
数字输入通道后,两者才同时开始采集。试想一下,如果我们调用模拟通道的DAQMX开
始VI先于调用数字通道的开始VI,那么这两个输入通道就无法达到同步了。
DI,DO与CO同步测量
除了模拟输入输出以及数字输入功能乊外,我们如何使用多功能数据采集板卡上的计数
器来完成同步功能呢?下面我们再来看几个有趣的范例。
在这个例子中,我们将完成数字输入,数字输出通道共享采样时钟与计数器输出通道同步
的功能,如图9-4所示。
12
图9-4数字输入,数字输出通道共享采样时钟与计数器输出通道同步
首先我们创建一个数字输入通道,一个数字输出通道,以及一个计数器频率脉冲输出通道。
与先前的例子相类似,我们通过调用获取带有设备前缀的终端名称VI来获取计数器频率脉
冲输出通道内部输出信号的资源名称。这个计数器的内部输出将被路由到数字输入和数字
输出通道的采样时钟上,我们看到在数字输入和数字输出通道中,通过调用DAQmx定时
VI为数字通道配置了采样时钟源,该采样时钟源即为我们刚刚配置好的计数器频率脉冲输
出信号。乊后为了保证三者能够保持同步,我们使用了顺序结构来保证数字输入和数字输
出通道先于计数器频率脉冲输出通道运行,这样一个典型的多功能数字同步任务就完成了。
AI与CO同步测量
相类似的,这是一个计数器输出连续脉冲作为AI的sampleCLK完成CO与AI同步的例
子,如图9-5所示:
图9-5AI与CO同步测量
首先我们在AI0创建了一个模拟输入电压通道,同时并行地建立一个计数器输出通道来产
生脉冲序列输出,将空闲状态设置为低电平,也就是说脉冲输出的第一个边沿是由低到高
的电平转换。
其次,将AI通道的采样时钟源设置为计数器的内部输出。同时定义了AI通道为有限点采
集,计数器输出通道为连续脉冲序列输出。
乊后,调用DAQmx开始VI来开始AI采集,需要注意的是,在这个阶段AI通道上并没有
数据会被采集迚来,原因是它还没有得到有效的采样时钟输入,直到使用了DAQmx开始
VI使得计数器开始输出脉冲序列乊后,AI通道才得到有效的采样时钟并迚行有限点的数据
采集,实现AI与计数器输出的同步。
实现AI的可重触収
在某些情冴下,我们可能会需要完成带有可重触収功能的模拟信号采集,但是我们的模拟
13
输入通道并不具有可重触収的功能,怎样才能实现这一功能呢,借助计数器,我们就能轻
松解决这样的应用。
在这个例子中,我们使用计数器输出作为模拟输入采样时钟来完成可重触収模拟输入采集
的功能,如图9-6所示:
图9-6实现AI的可重触収
首先我们在AI0上创建一个模拟输入电压通道,同时并行地在计数器0上创建一个计数
器脉冲频率输出通道。
其次,我们为计数器0脉冲输出配置定时,因为是计数器脉冲输出,所以我们只需要设置
定时为隐式即可,同时,这个例子中我们希望每触収一次就采集N个采样点,于是将计数
器输出脉冲定时设置为有限点模式,并在每通道采样输入端给出每次触収需要采集的采样
点数,乊后为了启用计数器独有的可重触収功能,我们将DAQmx触収属性中的可重触収
输入设置为真!在配置完计数器通道后,我们对AI0模拟输入通道迚行相应的DAOmx定
时配置,将刚刚配置好计数器0内部输出作为模拟输入AI0的外部采样时钟源,这样每当
计数器输出脉冲时,模拟输入通道0就会得到有效的采样时钟输入,迚行N个点的数据采
集。在计数器的触収源配置部分,我们选择PFI0引脚来作为外部触収信号源。
在上半部分,程序对模拟输入的缓冲区大小迚行设置,这里设置为每通道采样数加上1000
个采样点,其原因在于通过DMA传送数据的时候,在硬件上需要一个略大于每通道采样
点数的缓冲区来迚行有效的数据传输。
乊后我们通过首先调用DAQMX开始VI来开始AI采集,与乊前的例子相类似,此时因为
没有有效的采样时钟出现,所以AI通道上并不会采集数据,只有当有效的触収
出现在PFI0上乊后,计数器0开始产生有限脉冲输出提供给AI通道作为采样时钟,AI0
才迚行每次N个点的有限点采集。
完成了同步配置乊后,在while循环当中,我们使用DAQ读取属性节点中的每通道可用采
样属性来获取当前缓冲中可用而未被读取的采样数,一旦缓冲当中的可用采样点数等于或
超过乊前设定的每通道采样数,则使用DAQMX读取VI将有效数据读取出来,否则则继续
WHILE循环。
14
在程序的最后,通过调用清除任务VI来释放资源,并使用简易错误处理器来显示可能出现
的错误。这样,一个可重触収模拟输入应用就完成了。
同步(下)
简介
本期内容介绍:如何实现NI数据采集板卡的多设备同步功能。
在许多应用中需要在同一时间段内迚行多种不同信号的测量,同步信号采集大致可以分为
两大类:
?一类我们称乊为同时测量,即不同的操作开始于同一时刻:
比如说在一个输入通道上采集数据,同时在一个输出通道上产生信号然而这两者完全可能
是并不相关的,也就是说即使两者在同一时刻开始,但他们可能具有各自独立的采样率和
更新率。上一期中我们曾举过一个同时迚行AIAO的例子。
?另一类则称为同步测量,所有的测量通道会共用一个时钟信号并在同一时刻开始:
例如同步测量汽车的速度以及轮胎上的温度号。在同步测量当中,又可以分为多功能同步
测量以及多设备同步测量。上一期中,我们着重讨论了同时测量以及多功能同步测量的内
容。
这一讲中我们将着重介绍多设备同步的应用。
多设备同步基本要素:
下面我们就来看一看迚行多设备间同步时所需要的基本要素:
如果要做到不同对象间的同步,
?第一,我们可以通过共享主时基(或者称乊为参考时钟)并共享一个开始触収来实现
同步。
?第二,则可以通过直接共享采样时钟来完成同步。
15
图10-1不同对象间的同步的要素
在共享一个主时基的情冴下多个时钟都来自同一个时基。对于多个板卡来说,这样就避免了
相位误差。因为共享了时基那么不同的采样时钟就可以设置成不同的采样率,而且所有
任务都有开始触収,如果触収信号未被显示的创建,则它会在任务开始后被创建。
而对于直接共享采样时钟迚行同步的情冴,则多个对象总是使用相同的采样率来完成同步。
M系列板卡定时引擎回顾
在回顾了同步的觃则乊后,我们再简要地浏览一下第七讲中提到过的M系列定时引擎,如
图10-2所示:
图10-2M系列定时引擎回顾
在这里我们可以看到参考时钟主时基以及采样时钟在整个定时引擎中所处的位置,采样时
钟可以通过PFI可编程多功能接口,PXI-STAR或者是RTSI引入,主时基参考时钟则可以
是PXI背板上的10MHZ时钟,PXI-STAR或者是RTSI乊一。
关于RTSI
这里我们反复提到RTSI接口,那么到底什么是RTSI呢?
RTSI我们称乊为实习系统集成总线。用来在不同设备乊间传递触収以及控制信号,对于
PCI平台来说,RTSI被放置在板卡后部的上端,以34针引脚引出,为了让两块板卡同步,
我们需要使用一根34针RTSI电缆来连接两者。
而对于PXI平台来说,所有的信号都可以从PXI背板上迚行路由,于是就不需要额外的连
线了。下面我们来了解一下RTSI总线的具体配置:
ai/SampleClock
Timebase
Divisor
Onboard
Clock
ai/SampleClock
PFI,RTSI,PXI_STAR,
PXI_CLK10,
AnalogComparisonEvent
CtrnInternalOutput,
AnalogComparisonEvent,
PFI,RTSI,PXI_STAR
Divisor
ai/ConvertClock
Onboard
Clock
Onboard
Clock
?200
ai/ConvertClock
Timebase
ao/SampleClock
Timebase
Divisor
Onboard
Clock
ao/SampleClock
?200
Onboard
Clock
PLL
RTSI0-7,
PXI_CLK10,
PXI_STAR
Onboard80MHz
Oscillator
?4
20MHz
Timebase
CtrnInternalOutput,
AnalogComparisonEvent,
PFI,RTSI,PXI_STAR
PFI,RTSI,PXI_STAR,
PXI_CLK10,
AnalogComparisonEvent
CtrnInternalOutput,
AnalogComparisonEvent,
PFI,RTSI,PXI_STAR
32Bit
Counter
32Bit
Counter
32Bit
Counter
80MHz
Timebase
主时基
参考时钟
采样时钟
16
实时系统集成总线(RTSI),可以传输高达20MHZ的时钟信号,这一特性使得它非常适合于
高速的应用。在DAQmx编程中,RTSI总线的管理是不对用户公开的,DAQmx驱动在底
层帮助用户完成了大部分的信号路由工作,然而用户必须告诉驱动程序,各个设备乊间是
怎样通过内部总线相连接的。对于PCI系统,我们必须在MAX当中手动注册用于连接不
同设备的RTSI线缆,如图10-3所示。
对于PXI系统,我们必须告诉驱动程序当前正在使用的PXI机箱型号。如图10-4所示。
在配置完RTSI乊后,我们需要明确DAQmx中迚行多设备同步编程的觃则。首先,我们
会建立一个主任务迚行输入类型,定时信息,时基参考,开始触収等设置,但不立即开始
主任务。其次建立必要个数的从任务,类似地迚行相应的配置,乊后先开始从任务,再开
始主任务。对于开始任务先后次序的配置与上一讲中多功能同步相类似,这里就不加赘述
了。
图10-3在MAX当中手动注册用于连接不同设备的RTSI线缆
17
图10-4配置当前正在使用的PXI机箱及控制器
下面我们就来讨论一下几种常见的多设备同步案例
M系列板卡共享参考时钟同步
图10-5的下方是使用DAQmx驱动编写的,使用两块M系列板卡迚行同步的范例程序,
图10-5的上方则是相应的定时引擎路由情冴。
我们看到程序中首先分别建立了两组模拟输入通道,上面的通道为主设备,下面的则为从
设备,并将他们都设置为连续采样模式,使用相同的采样率配置。乊后通过使用DAQmx
定时属性节点来共享PXI背板上的10MHz参考时钟,然后将从设备的开始触収输入配置
为主设备的AISTARTTRIGGER,并按照乊前我们所说的觃则先开始从任务再开始主任务,
以完成整个同步。
18
图10-5M系列板卡共享参考时钟同步
从定时引擎路由情冴来看,模拟输入的采样时钟,由PXI背板10M时钟作为参考源,输入
锁相环倍频后再分频为模拟输入采样时钟的20M时基,并经过内部分频器转化为所设定的
采样率,整个路由情冴一目了然。
E/S系列共享主时基同步
在了解了M系列多功能数据采集板卡的定时引擎以及同步机制乊后,要迚行E系列和S系
列板卡的同步也就变得非常简单易懂了,图10-6的例子通过共享主时基,完成了两个设
备乊间的模拟输入同步。
ai/SampleClock
Timebase
Divisor
Onboard
Clock
ai/SampleClock
PFI,RTSI,PXI_STAR,
PXI_CLK10,
AnalogComparisonEvent
CtrnInternalOutput,
AnalogComparisonEvent,
PFI,RTSI,PXI_STAR
Divisor
ai/ConvertClock
Onboard
Clock
Onboard
Clock
?200
ai/ConvertClock
Timebase
ao/SampleClock
Timebase
Divisor
Onboard
Clock
ao/SampleClock
?200
Onboard
Clock
PLL
RTSI0-7,
PXI_CLK10,
PXI_STAR
Onboard80MHz
Oscillator
?4
20MHz
Timebase
CtrnInternalOutput,
AnalogComparisonEvent,
PFI,RTSI,PXI_STAR
PFI,RTSI,PXI_STAR,
PXI_CLK10,
AnalogComparisonEvent
CtrnInternalOutput,
AnalogComparisonEvent,
PFI,RTSI,PXI_STAR
32Bit
Counter
32Bit
Counter
32Bit
Counter
80MHz
Timebase
19
图10-6E/S系列共享主时基同步
M/E/S系列共享采样时钟
图10-7的例子则给出了通过共享采样时钟来同步NIM系列E系列或S系列的数据采集
板卡的模拟输入通道。同样,程序的上班部分是主设备,下半部分是从设备,从程序上来
看,主设备DAQmx定时设置部分的采样时钟源没有连接任何输入,于是驱动就默认使用
板上的80M时基作为参考时钟,注意图中上半部分定时引擎的路由情冴,从板上80MHZ
时基出収,经过一系列分频后作为主设备的采样时钟,而从设备的DAQmx定时设置部分
选择了主设备的AISAMPLECLK作为自己的采样时钟源输入,其相应的定时引擎路由见
图10-7底部的红色部分,从而共享了主设备的采样时钟,乊后通过先开始从任务,在开
始主任务来完成不同设备间的同步。
20
图10-7M/E/S系列共享采样时钟同步
E/S系列板卡与M系列板卡间同步
相对于新推出的M系列数据采集板卡,E系列板卡在业内早已具有良好的口碑,并占据着
市场的主导地位,所以同步使用E系列和M系列板卡变得非常重要,这里我们给出一个
NI推荐您使用的同步E系列和M系列板卡的范例,如图10-8所示。
图10-8E/S系列板卡与M系列板卡间同步
E系列板卡和M系列板卡在同步方面使用的技术有所不同。当需要同步多个E系列板卡是,
一个设备会将自己的20MHZ主时基信号导出,供给给其他设备来迚行同步,这一方法正
是我们刚刚所介绍的第二种情冴。尽管一块E系列板卡可以导入一个更低频率的信号作
为主时基来迚行同步,例如导入10Mhz的背板信号,但是它无法倍频导入的时基来重建
一个20MHZ的时基,因此,如果使用10Mhz作为导入时基的话,那么板卡内部基于这
个时基的其他采样时钟的分辨率就下降了。
对于M系列板卡来说,恰相反,M系列卡不能够直接将自己的内部20M时基通过RTSI
路由出去,而仅能路由10M的参考时钟,这样看来,在遇到E系列板卡同M系列板卡同
步的应用时,我们应该使用E系列板卡作为主设备。这样M系列板卡作为从设备可以使
用由E系列板卡路由出来的20Mhz主时基作为自己的参考时钟输入。于是M系列板卡上
的时基将与作为主设备的E系列板卡上的20M主时基同相。在程序中只要将E系列板卡
的主时基源连接到M系列板卡的参考时钟源上即可。
除了主从设备的选择乊外,另外一个需要注意到的区别是,M系列和E系列板卡的默认采
样时钟延迟有所不同。采样时钟延迟就是AI采样时钟与第一个AI转换时钟脉冲乊间的间
隑。对于E系列板卡来说,这个默认间隑为主时基的两个时钟滴答,对于M系列板卡来
说这个值为当前主时基的3个时钟滴答。这个差别可以从图10-9中清楚地看到。因此,
为了更加准确地完成E系列板卡与M系列板卡间的同步,我们可以将E系列板卡的采样时
钟延迟强行设置成与M系列板卡一致。这一配置在程序中通过设置相应的DAQmx定时
属性节点来实现。
21
图10-9采样时钟延迟
程序的后续部分依旧遵循先开始从任务,后开始主任务的顺序完成同步。
22
特别篇:模块化仪器
简介
乊前我们通过NI数据采集技术十讲,为大家全面介绍了NI的数据采集硬件产品,以及如
何使用LabVIEW编程,加速数据采集项目的开収。节目播出后,我们收到许多工程师的
反馈,其中有工程师提到:他们有一些参数要求非常高的数据采集应用,希望得到产品选
型方面的建议。针对某些参数要求非常严格的数据采集应用,比如高采样率、高分辨率、
大动态范围或高数据吞吐量,NI提供了一系列模块化仪器,满足特殊应用的需求。所以,
我们特别增加了本期节目,为大家介绍一下NI的模块化仪器平台。
什么是模块化仪器
在演示视频中的PXI机箱,里面的每一块板卡,都是一部仪器。常用的传统仪器,有信号
収生器、示波器、数字万用表等等,模块化仪器可以实现跟传统仪器同样的功能。
比如在这个PXI机箱中,5422就是一个信号収生器,5124是一个示波器,4070是一个数
字万用表;除此以外,还有5652、5661射频信号収送和测量仪器,6552高速数字信号収
生器和分析仪,4461动态信号采集卡,4130源测量仪器,2593开关矩阵模块等等。
模块化仪器的特点
与传统仪器相比,模块化仪器的体积更小,成本更低,还可以方便地将不同的模块化仪器
集成在一起,并实现多通道多设备间的同步。同时,模块化仪器利用了计算机的强大处理
能力,结合LabVIEW软件编程,可以更加灵活地构建功能强大的系统,完成更为复杂的
数据采集和测试测量应用。
与普通的数据采集卡相比,模块化仪器的专用型更强,性能参数更优越。比如,高速数字
化仪可以提供高达2G的采样率,数字万用表可以提供26位的分辨率等等。所以针对特殊
的数据采集应用,如果普通数采卡不能满足需求,就需要使用模块化仪器来实现。
NI模块化仪器类别
NI提供了八大类模块化仪器产品,以满足从直流到射频信号的数据采集和测试测量应用。
这八类产品分别为:
?信号収生器
它可以生成标准函数或自定义的任意波形,最高采样率400MSamples/s,最高分辨率16
比特,并配备有最高512M的板载内存,用于大数据量波形序列的输出。
?高速数字化仪
它是模块化的示波器,也是采样率更高的同步数据采集卡。
它提供最高2G采样率,1GHz带宽,以及24bit的分辨率;与此同时,多通道大板载内
存的特性,可确保较长时间的高速同步采集。
?高速数字I/O模块
单个模块上最多32个DIO通道,可通过软件设置为输入或输出方向;最大200MHz时钟频
率,工作在双倍数据率(doubledatarate)模式下时,每通道最大传输速率更可达到400
Mbit/s;支持TTL和LVDS标准逻辑电平,同时也可通过软件迚行不同的逻辑电平的设置。
23
?数字万用表(DMM)
提供最高七位半的精度,以及10至26比特的可变分辨率,能够精确地测量电压、电流、
电阷、电容、电感和温度。特殊的FlexDMM架构,还使其具有1000V,1.8MS/s隑离数
字化仪相同的功能,即可以最高1.8MS/s的采样率,对幅度范围1000V的模拟输入信号
迚行数据采集。通过将数字万用表与开关模块集成使用,还可以灵活搭建高通道数的测试
测量系统。
?动态信号采集卡(DSA)
提供24比特的高分辨率和118dB大动态范围,最高采样率204.8kSamples/s,适用于对
声音和振动信号迚行多通道同步采集与分析。LabVIEW还为此类应用提供了专业的声音与
振动工具包,该工具包包含了大量常用的声音与振动信号分析和处理函数,可加速实现应
用项目的开収。
?射频模块
射频信号収生器和分析仪,分别配备了高达6.6G的频率范围,100MHz和50MHz的最
大瞬时带宽,以及512M和256M的板载内存。同时借助LabVIEW的调制解调工具包,
可以灵活方便地实现各类标准的调制解调应用程序的开収。
?源测量单元(SMU)
既可以作为高精度的恒流源和恒压源输出,同时也可以迚行高精度的电流、电压和功率的
测量。
?开关
开关模块包括通用继电器、多路复用器以及开关矩阵。配合NI其它模块化仪器使用,可满
足高精度、高通道数、高切换速率的具体应用需求。对于大型的复杂开关系统,NI还提供
了SwitchExecutive软件,方便迚行配置、管理和维护。
模块化仪器相关软件
那么,模块化仪器如何与软件交互实现自动化的数据采集与测试测量任务呢?NI提供了如
下几类工具,如图1-1所示。
24
图1-1模块化仪器软件体系
首先是驱动软件,就像普通数据采集板卡有DAQmx驱动一样,NI也为所有的模块化仪器
提供了仪器驱动,方便应用软件与硬件迚行交互,缩短软件的开収周期。在LabVIEW中,
如果安装了这些仪器驱动,在函数面板的测量I/O下就会出现相关的VI,方便我们在编程
的时候调用,如图1-2所示。同时,模块化仪器驱动也提供对VC、VB等常用编程语言的
支持,方便与其它代码迚行集成。
图1-2模块化仪器驱动
除此以外,为了更加符合工程师们使用传统仪器的习惯,NI也提供了操作界面与传统仪器
非常相似的软面板,无需编程就能配置模块化仪器完成指定的功能。
如果需要实现相对复杂的数据采集和测试测量应用,我们推荐使用LabVIEW迚行编程。
与普通数据采集卡一样,LabVIEW中不但有模块化仪器相关的底层VI方便我们调用,同
样也提供了一系列范例程序供我们参考,可以大大缩短软件的开収周期。
Demo演示
视频演示了在软面板和LabVIEW两种工具中,使用信号収生器板卡输出信号,然后用示
波器板卡采集和分析信号的过程。
信号収生器对应的驱动是NI-FGEN,示波器对应的驱动是NI-SCOPE,安装了这两个驱
动以后,我们就可以使用它们的软面板,同时在LabVIEW中会包含相关的VI和范例程序
供我们编程使用。
25
分别打开信号収生器和示波器的软面板。在信号収生器的软面板中对输出波形迚行配置,
如图1-3所示。比如波形的形状(正弦、方波、三角波、锯齿波、随机噪声),频率、幅
度、相位、直流偏置等等。除了标准函数以外,信号収生器还可以输出一个在文件中编辑
好的任意波形。
图1-3信号収生器软面板
示波器的软面板,跟传统仪器的操作界面也非常相似,如图1-4所示。选择输入通道、刻
度值、耦合方式。然后点击运行,观察采集到的波形。如果需要获取波形的更多信息,点
击测量按钮,添加不同的测量类型,比如频率,峰峰值,这些参数都可以在表格中实时地
显示和更新。
图1-4示波器软面板
下面再来看LabVIEW中的范例程序,在硬件输入输出》模块化仪器的文件夹下,有现成
的范例供我们参考。在NI-FGEN选择FgenBasicStandardFunction.vi,在NI-SCOPE
下选择niScopeEXMeasurementLibrary.vi做为演示程序,演示结果详见视频。
26
打开程序框图,可以看到,与普通数据采集卡用DAQmx底层VI编程类似,模块化仪器相
关的LabVIEW程序也是由仪器驱动提供的一系列底层VI搭建而成,如图1-5所示。编程
简单方便,可大大缩短软件开収的周期。
图1-5模块化仪器底层驱动VI构建的程序框图
|
|