位置:51电子网 » 技术资料 » 仪器仪表

基于USB 2.0的高速数据采集卡在虚拟仪器中的应用

发布时间:2008/6/2 0:00:00 访问次数:477

  摘 要:本文详细介绍了应用于虚拟仪器的、基于usb 2.0的高速数据采集卡的硬件组成和软件设计。克服了传统数据采集卡的局限,使得虚拟仪器的使用越来越快捷方便。

  关键词:虚拟仪器;usb2.0;高速数据采集

引言

  虚拟仪器,就是在通用计算机平台上,用户根据自己的需求定义和设计仪器的测试功能,与传统仪器相比,虚拟仪器在智能化程度、处理能力、性能价格比、可操作性等方面均具有明显的技术优势。

  本文将着重介绍一种新型优良的下位机—基于usb2.0的高速数据采集卡在虚拟仪器中的应用。

  本文重点分析的下位机即智能a/d,是虚拟仪器硬件设备中的关键环节。下位机通过特定接口接受来自上位机的指令并向上位机提供自身所处的状态:在收到采集指令后,对传感器发送的模拟电信号进行a/d采样以转化为数字信号,然后将数字信号通过usb接口传给上位机。

  本系统的下位机支持2个通道的传感器信号进行a/d转换,其最高采样效率为120mhz,采样转换精度为8位,系统采用了一个内含先进先出(fifo)内存的usb2.0控制芯片,该内存用于存放a/d转换后的数据,使用fifo可以有效地缓冲采集数据,减少频繁的指令传送,使上位机有更多的时间进行其他处理,并且不容易丢失数据。该下位机可以编程控制采集频率和采样增益,具有较大的灵活性。

基于usb2.0的高速

数据采集卡

硬件系统

  虚拟仪器硬件的核心部分是usb设备接口模块,其功能是由硬件和软件共同来完成的。usb接口示意图如图2所示。下面介绍一下主要功能模块器件的选择和功用。

adc的选择

  本设计中选用了ad9059。该器件是8位单片双通道adc,具有高速、高性能、低功耗及易使用等特性,60msps的编码速率和120mhz的最大功率模拟带宽使其在多路数据采样系统中表现出优秀的动态性能。大部分情况下,ad9059仅需要一个单极性的5v电源和一个编码时钟即能正常工作。编码时钟提供与ttl/cmos兼容的逻辑数据输出,并控制两个a/d转换通道同时对数据进行采样。如长时间不需要采集数据,可启动休眠模式使总功耗小于12mw。adc的时钟及控制信号等由cpld提供。

cpld的选择

  在高速数据采集卡中,时序复杂而且精细,可能会因为一个门的时延,而导致整个硬件电路的失败。所以在本设计中采用了cpld来实现电路的数字控制功能。

  cpld主要任务是负责在ez-usb fx2(即cy7c68013)处于slave fifo模式时实现读/写控制信号、时钟、输出使能、端点的选择以及对放大器和adc的控制等功能。?

  基于cpld容易开发升级的优点,在本设计中,所有的数字电路部分,全部是在cpld内实现的,本设计采用了lattice公司的isp1032芯片,所用的eda软件是lattice公司的ispexpert系统,编程语言为abel语言。

  经过在实践中检验,在高速数据采集卡中,用isp1032来实现数字逻辑电路功能,可以使高速数据采集卡工作稳定,各方面性能良好。

信号调理模块

  在高速数据采集系统中, 现场输入信号是高频的模拟信号,信号变化的范围都比较大,如果采用单一的增益放大,那么放大以后的信号幅值有可能超过a/d转换的量程,所以必须根据信号的变化相应地调整放大器的增益。在自动化程度较高的系统中,希望能够在程序中用软件控制放大器的增益,经过考虑本文选择具有增益可编程功能的芯片—ad8321。该芯片具有频带宽、噪声低、增益可编程且易于与单片机进行串行通信等优点,十分适合在数据采集系统做前置放大。程控放大模块的的控制字可在labview设定,再经过usb接口由ez-usb fx2传给ad8321。

usb控制器

  数据采集接口卡是硬件部分的核心,选择合适的能适用于usb协议的芯片是关键。ez-usb fx2(即cy7c68013)是世界上首批usb2.0集成微控制器。其内部集成了usb2.0的收发器、串行接口引擎(sie)、增强的8051微控制器和一个可编程的串行接口。

  在外设未通过usb接口接到pc机之前,外设上的固件存储在pc上;一旦外设连接到pc机上,pc先确认外设身份(即读设备描述符),然后将该外设的固件下载到芯片的ram中,这样在开发过程中当固件需要修改时,可以在pc机上修改好后,下载到芯片中。

固件开发

  设备固件是设备运行的核心,它控制整个硬件系统的运行,并负责处理pc机发来的各种usb请求,以完成它们之间的数据传输。其主要功能包括控制放大模块,实现通道选择;控制a/d模块的数据采集;通过fx2实时上传采集数据给pc;控制fx2芯片接收并处理usb设备驱动程序的请求(如设置usb接口状态等多种usb协议标准请求)等。

  由于固件的开发流程比较复杂,故本设计中采用c语言进行开发,这样比较容易实现模块化和分层结构化的程序设计。

  ez-usb fx2固件库为用户提供了底层keil c函数库。ez-usb fx2软件开发包提供了该库的目标文件,同时还提供了该函

  摘 要:本文详细介绍了应用于虚拟仪器的、基于usb 2.0的高速数据采集卡的硬件组成和软件设计。克服了传统数据采集卡的局限,使得虚拟仪器的使用越来越快捷方便。

  关键词:虚拟仪器;usb2.0;高速数据采集

引言

  虚拟仪器,就是在通用计算机平台上,用户根据自己的需求定义和设计仪器的测试功能,与传统仪器相比,虚拟仪器在智能化程度、处理能力、性能价格比、可操作性等方面均具有明显的技术优势。

  本文将着重介绍一种新型优良的下位机—基于usb2.0的高速数据采集卡在虚拟仪器中的应用。

  本文重点分析的下位机即智能a/d,是虚拟仪器硬件设备中的关键环节。下位机通过特定接口接受来自上位机的指令并向上位机提供自身所处的状态:在收到采集指令后,对传感器发送的模拟电信号进行a/d采样以转化为数字信号,然后将数字信号通过usb接口传给上位机。

  本系统的下位机支持2个通道的传感器信号进行a/d转换,其最高采样效率为120mhz,采样转换精度为8位,系统采用了一个内含先进先出(fifo)内存的usb2.0控制芯片,该内存用于存放a/d转换后的数据,使用fifo可以有效地缓冲采集数据,减少频繁的指令传送,使上位机有更多的时间进行其他处理,并且不容易丢失数据。该下位机可以编程控制采集频率和采样增益,具有较大的灵活性。

基于usb2.0的高速

数据采集卡

硬件系统

  虚拟仪器硬件的核心部分是usb设备接口模块,其功能是由硬件和软件共同来完成的。usb接口示意图如图2所示。下面介绍一下主要功能模块器件的选择和功用。

adc的选择

  本设计中选用了ad9059。该器件是8位单片双通道adc,具有高速、高性能、低功耗及易使用等特性,60msps的编码速率和120mhz的最大功率模拟带宽使其在多路数据采样系统中表现出优秀的动态性能。大部分情况下,ad9059仅需要一个单极性的5v电源和一个编码时钟即能正常工作。编码时钟提供与ttl/cmos兼容的逻辑数据输出,并控制两个a/d转换通道同时对数据进行采样。如长时间不需要采集数据,可启动休眠模式使总功耗小于12mw。adc的时钟及控制信号等由cpld提供。

cpld的选择

  在高速数据采集卡中,时序复杂而且精细,可能会因为一个门的时延,而导致整个硬件电路的失败。所以在本设计中采用了cpld来实现电路的数字控制功能。

  cpld主要任务是负责在ez-usb fx2(即cy7c68013)处于slave fifo模式时实现读/写控制信号、时钟、输出使能、端点的选择以及对放大器和adc的控制等功能。?

  基于cpld容易开发升级的优点,在本设计中,所有的数字电路部分,全部是在cpld内实现的,本设计采用了lattice公司的isp1032芯片,所用的eda软件是lattice公司的ispexpert系统,编程语言为abel语言。

  经过在实践中检验,在高速数据采集卡中,用isp1032来实现数字逻辑电路功能,可以使高速数据采集卡工作稳定,各方面性能良好。

信号调理模块

  在高速数据采集系统中, 现场输入信号是高频的模拟信号,信号变化的范围都比较大,如果采用单一的增益放大,那么放大以后的信号幅值有可能超过a/d转换的量程,所以必须根据信号的变化相应地调整放大器的增益。在自动化程度较高的系统中,希望能够在程序中用软件控制放大器的增益,经过考虑本文选择具有增益可编程功能的芯片—ad8321。该芯片具有频带宽、噪声低、增益可编程且易于与单片机进行串行通信等优点,十分适合在数据采集系统做前置放大。程控放大模块的的控制字可在labview设定,再经过usb接口由ez-usb fx2传给ad8321。

usb控制器

  数据采集接口卡是硬件部分的核心,选择合适的能适用于usb协议的芯片是关键。ez-usb fx2(即cy7c68013)是世界上首批usb2.0集成微控制器。其内部集成了usb2.0的收发器、串行接口引擎(sie)、增强的8051微控制器和一个可编程的串行接口。

  在外设未通过usb接口接到pc机之前,外设上的固件存储在pc上;一旦外设连接到pc机上,pc先确认外设身份(即读设备描述符),然后将该外设的固件下载到芯片的ram中,这样在开发过程中当固件需要修改时,可以在pc机上修改好后,下载到芯片中。

固件开发

  设备固件是设备运行的核心,它控制整个硬件系统的运行,并负责处理pc机发来的各种usb请求,以完成它们之间的数据传输。其主要功能包括控制放大模块,实现通道选择;控制a/d模块的数据采集;通过fx2实时上传采集数据给pc;控制fx2芯片接收并处理usb设备驱动程序的请求(如设置usb接口状态等多种usb协议标准请求)等。

  由于固件的开发流程比较复杂,故本设计中采用c语言进行开发,这样比较容易实现模块化和分层结构化的程序设计。

  ez-usb fx2固件库为用户提供了底层keil c函数库。ez-usb fx2软件开发包提供了该库的目标文件,同时还提供了该函

相关IC型号

热门点击

 

推荐技术资料

驱动板的原理分析
    先来看看原理图。图8所示为底板及其驱动示意图,FM08... [详细]
版权所有:51dzw.COM
深圳服务热线:13751165337  13692101218
粤ICP备09112631号-6(miitbeian.gov.cn)
公网安备44030402000607
深圳市碧威特网络技术有限公司
付款方式


 复制成功!