![数据采集与仪器驱动课件_第1页](http://file4.renrendoc.com/view/a6384804cdd1c3a8d66d976dd962c686/a6384804cdd1c3a8d66d976dd962c6861.gif)
![数据采集与仪器驱动课件_第2页](http://file4.renrendoc.com/view/a6384804cdd1c3a8d66d976dd962c686/a6384804cdd1c3a8d66d976dd962c6862.gif)
![数据采集与仪器驱动课件_第3页](http://file4.renrendoc.com/view/a6384804cdd1c3a8d66d976dd962c686/a6384804cdd1c3a8d66d976dd962c6863.gif)
![数据采集与仪器驱动课件_第4页](http://file4.renrendoc.com/view/a6384804cdd1c3a8d66d976dd962c686/a6384804cdd1c3a8d66d976dd962c6864.gif)
![数据采集与仪器驱动课件_第5页](http://file4.renrendoc.com/view/a6384804cdd1c3a8d66d976dd962c686/a6384804cdd1c3a8d66d976dd962c6865.gif)
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数据采集与仪器驱动数据采集与仪器驱动1数据采集与仪器驱动数据采集与仪器驱动2第五章数据采集与仪器驱动5.1数据采集与控制系统构成5.2数据采集VI的组织结构5.3基于NI的DAQ系统的实现5.4非NI的DAQ系统的实现本章小结
12/13/2022第五章数据采集与仪器驱动5.1数据采集与控制系统构成35.1数据采集、控制系统的构成
采用基于PC的数据采集(dataacquisition,DAQ)、控制系统来完成实验室研究和工业控制中的测控任务的方案配置是:
工控机+数据采集/控制卡+VB/VC/LabView编程,即:数据采集/控制卡:完成一般测试仪器的数据采集和控制功能,工控机系统:完成一般测试仪器的数据分析、计算、显示、输出等功能。12/13/20225.1数据采集、控制系统的构成采用基于PC的数据采集4数据采集控制系统的组成12/13/2022数据采集控制系统的组成12/10/20225模拟信号的数字化处理数据采集的核心过程就是将连续的模拟信号转换成离散的数字信号采样点太多,会占用大量内存单元;采样点太少,会使模拟信号的某些信息被丢失,出现失真现象12/13/2022模拟信号的数字化处理数据采集的核心过程就是将连续的模拟信号转6数据采集卡
数据采集卡的组成:①多路开关:将各路信号轮流切换到放大器的输入端,实现多参数多路信号的分时采集。②放大器:将前一级多路开关切换进入待采集信号放大(或衰减)至采样环节的量程范围内。通常实际系统中放大器为增益可调的放大器,设计者可根据输入信号不同的幅值选择不同的增益倍数。
③采样/保持器:取出待测信号在某一瞬时的值(即实现信号的时间离散化),并在A/D转换过程中保持信号不变。如被测信号变化很缓慢可不用采样/保持器。12/13/2022数据采集卡
数据采集卡的组成:12/10/20227④A/D转换器:输入的模拟量转化为数字量输出,并完成信号幅值的量化。随着电子技术的发展,目前通常将采样/保持器同A/D转换器集成在一块芯片上。以上四个部分都处在PC计算机的前向通道,完成对信号数据的采集、放大及模/数转换任务。12/13/2022④A/D转换器:输入的模拟量转化为数字量输出,并完成信号幅8需要注意的两个问题1、是否使用Buffer?2、是否使用外触发启动、停止或同步操作?缓冲(Buffers):缓冲指的是PC内存的一个区域(不是数据采集卡上的FIFO缓冲),它用来临时存放数据。使用BufferI/O的情况:需要采集或产生许多样本,其速率超过了实际显示、存储到硬件,或实时分析的速度。需要连续采集或产生AC数据(>10样本/秒),并且要同时分析或显示某些数据。采样周期必须准确、均匀地通过数据样本。12/13/2022需要注意的两个问题1、是否使用Buffer?12/10/209registeraddress:U32型。首地址后面的内存空间供采集卡内部寄存器分配使用。outp(*basea,channel); /*向板基地址写入所选模拟信号通道号并启动A/D转换*/当IO=1时,表示A/D转换完毕。vi和PID%toEGU.对于HY–1232采集卡分查询方式和中断方式两种。hwnd:类型=数值,数据类型=无符号32拉整型,传递=值returnnoErr;c选项,则进行add.(5)调用CIN的功能菜单将生成的可执行文件载入CIN图标。float64value;/*定义变量,存放单点的A/D转换结果对应的模拟量*/以NI公司的PCI-6071E多功能采集卡为例,介绍采集卡的一般参数:模拟信号:直流、时域、频域信号。/*软件查询式采集程序*/vi:可以对PID控制器前端由系统反馈来的输入信号做动态补偿。不使用BufferI/O的情况:数据组小,如每秒只从两个通道之一采集一个数据点。需要缩减存储器的开支。触发(Triggering):触发涉及初始化、终止或同步采集事件的任何方法。软件触发:可以直接用软件,例如使用布尔面板控制去启动/停止数据采集。硬件触发:让板卡上的电路管理触发器,控制采集事件的时间分配,有很高的精确度。12/13/2022registeraddress:U32型。不使用Buffe10下列情况使用软件触发:
用户需要对所有采集操作有明确的控制。事件定时不需要非常准确。下列情况使用硬件触发:采集事件定时需要非常准确。用户需要削减软件开支。采集事件需要与外部装置同步。12/13/2022下列情况使用软件触发:
用户需要对所有采集操作有明确的控制。11输入信号类型
不同信号的测量对采集系统的要求是不同的。输入信号的种类:信号所运载信息很广泛的,比如:状态(state)、速率(rate)、电平(level)、形状(shape)、频率成分(frequencycontent)。根据信号运载信息方式的不同,可以将信号分为模拟或数字信号。数字(二进制)信号:开关信号、脉冲信号。模拟信号:直流、时域、频域信号。12/13/2022输入信号类型
不同信号的测量对采集系统的要求是不同的。1212/13/202212/10/2022131、数字信号开关信:信号运载的信息与信号的瞬间状态有关。脉冲信号:信号包括一系列的状态转换,信息就包含在状态转化发生的数目、转换速率、脉冲宽度。2、模拟信号模拟直流信号:静止的或变化非常缓慢的模拟信号。直流信号最重要的信息是幅度.常见的直流信号有温度、流速、压力、应变等采集系统在采集模拟直流信号时,需要有足够的精度以正确测量信号电平,由于直流信号变化缓慢,用软件计时就够了,不需要使用硬件计时。12/13/20221、数字信号12/10/202214模拟时域信号
模拟时域信号的运载信息:电平随时间的变化(波形形状的特性,如斜度、峰值等),比如心脏跳动信号、视频信号。测量时域信号的采集系统包括:一个A/D转换器:A/D的分辨率要足够高,保证采集数据的精度,带宽要足够高,用于高速率采样;一个采样时钟电路:精确的采样时钟,用于以精确的时间间隔采样;一个触发器:触发器使测量在恰当的时间开始。12/13/2022模拟时域信号模拟时域信号的运载信息:电平随时间的变化(波15模拟频域信号
模拟频域信号与时域信号类似,然而,从频域信号中提取的信息是基于信号的频域内容,而不是波形随时间变化的特性。比如声音信号、地球物理信号、传输信号等。用于测量一个频域信号的系统必须有一个A/D、一个简单时钟和一个用于精确捕捉波形的触发器。系统必须有必要的分析功能,用于从信号中提取频域信息。为了实现这样的数字信号处理,可以使用应用软件或特殊的DSP硬件来迅速而有效地分析信号。12/13/2022模拟频域信号模拟频域信号与时域信号类似,然而,从频域信号16信号连接方式
1、输入信号的参考点:接地信号、浮动信号接地信号:输入信号的一端直接接地,它的参考点是系统地(如建筑物的地或大地);最常见的接地信号是通过电源插座接入的设备。浮动信号:输入信号是不连接到建筑物地等绝对参考点的电压信号,浮动信号源常见的有:电池及其供电设备、热电偶、变压器等设备。12/13/2022信号连接方式
1、输入信号的参考点:接地信号、浮动信号12/17/*ENTERYOURCODEHERE*/填入C语言源代码typedefstruct{在主菜单Build下选择Compileadd.通常选0x280,即280H(640)。l
Outputs:输入命令行如下:最后形成工程文件add.安装LabVIEWPIDControlTookit,即可在FunctionsPalette上选择ControlDesign&Simulation,该工具包由10个VI组成。vi:一个五阶的低通滤波器,放在PID控制器的processvariable前端,可以滤去小于采样率十分之一的输入值。随着电子技术的发展,目前通常将采样/保持器同A/D转换器集成在一块芯片上。CLF(CallLibraryFunctionNode)
调用库函数节点vi图标及其端口参数设置(7)设置信号输入通道。在硬件设备上,多路(Line)数字I/O组成一组后被称为端口(Port)。typedefTD1**TD1Hdl;采用Lab–PC–1200型卡,信号由第0通道输入。2、差分测量系统输入信号的正负极分别接入两个通道,所有输入信号各自有自己的参考点。12/13/2022/*ENTERYOURCODEHERE*/183、参考地单端测量系统(RSE)用于测试浮动输入信号。被测信号一端接模拟输入通道,另一端(信号参考点)与系统地AIGND连接。12/13/20223、参考地单端测量系统(RSE)用于测试浮动输入信号。被测信194、无参考地单端测量系统(NRSE)
它的一端接模拟输入通道,另一端接一个公用参考端AISENSE,这个参考端电压不一定于测量系统地AIGND相等。12/13/20224、无参考地单端测量系统(NRSE)它的一端接模拟输入通20数据采集卡的基本性能指标
数据采集卡的主要性能指标:1、模拟信号输入部分
①
模拟输入通道数。该参数表明数据采集卡所能够采集的最多的信号路数。
②
信号的输入方式。一般待采集信号的输入方式有:l
单端输入:即信号的其中一个端子接地。l
差动输入:即信号两端均浮地。l
单极性:信号幅值范围为[0,A],A为信号最大幅值。l
双极性:信号幅值范围为[–A,A]。12/13/2022数据采集卡的基本性能指标
数据采集卡的主要性能指标:12/121③
模拟信号的输入范围(量程):
一般根据信号输入特性的不同(单极性输入还是双极性输入)有不同的输入范围。如对单极性输入,典型值为0~10V,对双极性输入,典型值为–5V~5V。④
放大器增益:⑤
模拟输入阻抗:采集卡固有参数,一般不由用户设置。12/13/2022③模拟信号的输入范围(量程):12/10/202222混叠干扰图中采样频率500Hz,5个正弦波的频率分别为100Hz,200Hz,300Hz,375Hz和400Hz。因为100Hz,200Hz的信号频率小于fs/2,可以由离散信号还原出原始的正弦波连续信号。而300Hz,375Hz和400Hz的信号频率都大于fs/2,故离散信号重构原信号时形成了频率不同于原信号频率的信号,即混叠干扰
采样速率:式中N为多通道数据采集系统的通道数。12/13/2022混叠干扰图中采样频率500Hz,5个正弦波的频率分别为10023位数b:
A/D转换器输出二进制数的位数。当输入电压由U=0增至满量程值U=UH时,一个八位(b=8)A/D的数字输出由八个“0”变为八个“1”,共计变化2b个状态,故A/D转换器产生一个最低有效位数字量的输出改变量,相应的输入量Umin=1LSB=q(量化值)可由下式计算:分辨率:指数据采集卡可分辨的输入信号最小变化量。
2022/12/13位数b:A/D转换器输出二进制数的位数。当输入电压由U采集卡基本参数以NI公司的PCI-6071E多功能采集卡为例,介绍采集卡的一般参数:模拟输入:64路单端/32路双端,输入范围:±10V分辨率:12位采样频率:最高1.25M模拟输出:2路,12位,1M,输出范围:±10V数字I/O:8路计数器:2路,24位,基准时钟20MHz或100KHz12/13/2022采集卡基本参数以NI公司的PCI-6071E多功能采集卡为例25数据采集卡的参数设置
要使数据采集卡正确地实现数据采集的功能,必须根据实际测量的需要对一些参数进行正确设置。待设置的参数主要有数据采集卡的设备号、地址码,此外,还有如下设置。1、模拟信号输入部分①设置信号的输入方式。单端输入还是双端输入,单极性信号还是双极性信号等。②选择增益。根据输入信号幅值范围和分辨率的要求进行增益选择。③选择量程。根据输入信号是单极性还是双极性,相应选择合适的量程。12/13/2022数据采集卡的参数设置
要使数据采集卡正确地实现数据采集的功能262、A/D转换部分①设定信号输入通道号。②设定采样点数。③设定采样速率。④采样结果的输出方式。采样结果可放在一个数组中,也可放在某一缓冲区中。⑤采样触发方式。一般分外触发、定时触发、软件触发等3、D/A转换部分①模拟信号的输出通道号。②模拟信号的输出幅值。此参数应设置在标称满量程范围内。③刷新速率。该参数决定所产生的模拟信号波形的“光滑度”。最快刷新速率的倒数即为响应时间。12/13/20222、A/D转换部分①设定信号输入通道号。12/10/20227(2)单击对话框“函数”页面中“库名或路径”框右侧的打开文件按钮,选挥“C:\WINDOWS\system32\user32d11”文件,LabVIEW会自动搜出该DLL中所包含的所有函数,只需在“函数名”下拉列表今选择即可。需要连续采集或产生AC数据(>10样本/秒),并且要同时分析或显示某些数据。#include<conio.dimSize[0]=m,value=(float64)(dbyte-2047)*10/4096; /*将二进制结果转换为对应的模拟量值,送入value变量*/根据输入信号幅值范围和分辨率的要求进行增益选择。该信号的采集演示仪可以采集和显示一路信号,参数为:vi即可搭建一个简单的PID控制器,在该vi的输入端给入PID的3个参数值(PIDgains),系统反馈值(processvariable),实际期望值(setpoint)以及微分时间(dt),便能得到需要的输出值(output)。HY–1232数据采集卡板基地址的可选范围为:200H~3FFH(512~1023)。当IO=1时,表示A/D转换完毕。在LabVIEW中对数字I/O的操作非常简单,可以对整个端口进行操作,也可以对端口中的一路或多路同时进行操作。①设置信号的输入方式。在主菜单Build下选择Compileadd.触发(Triggering):触发涉及初始化、终止或同步采集事件的任何方法。在主菜单Build下选择Compileadd.5.2DataAcquisitionVI的组织结构
在LabVIEW平台,用软件驱动I/O接口数据采集卡,实现数据采集分以下两种情况:
LabVIEW支持的数据采集卡:如NI公司自行生产的各类数据采集卡,可利用LabVIEW自带的驱动函数驱动。设计者只需正确设置输入参数就可实现数据采集的任务,而不需编写代码程序。LabVIEW不支持的数据采集卡:可利用LabVIEW的代码嵌入功能(CIN模块)等来实现采集卡的软件驱动。12/13/2022(2)单击对话框“函数”页面中“库名或路径”框右侧的打开文件28
LabVIEW数据采集模块的分类
LabVIEW的功能模板(FunctionsPalette)提供了DataAcquisition驱动数据采集卡DAQ子模板,该子模板提供了六个子模块,如图所示。12/13/2022LabVIEW数据采集模块的分类
LabVIEW的29DataAcquisition子模板上的图标及名称12/13/2022DataAcquisition子模板上的图标及名称12/130A/D部分易用函数中级函数高级函数实用函数12/13/2022A/D部分易用函数中级函数高级函数实用函数12/10/20231(1)易用函数
1.波形输入AIAcquireWaveform.vi图标及端口参数(单通道单点采样)12/13/2022(1)易用函数
1.波形输入AIAcquireWavef322多波形图标及其输入、输出端口参数
12/13/20222多波形图标及其输入、输出端口参数
12/10/202233(2)中级函数
1.AIConfig.vi图标及其输入、输出端口参数
12/13/2022(2)中级函数
1.AIConfig.vi图标及其输入、输342.AIStart.vi图标及其输入、输出端口参数
12/13/20222.AIStart.vi图标及其输入、输出端口参数
12/353.AIRead.vi图标及其输入、输出端口参数
12/13/20223.AIRead.vi图标及其输入、输出端口参数
12/364.AIClear.vi图标及其输入、输出端口参数
12/13/20224.AIClear.vi图标及其输入、输出端口参数
12/37LabVIEW中的模拟输入12/13/2022LabVIEW中的模拟输入12/10/202238连续模拟输入12/13/2022连续模拟输入12/10/202239basea=0x280;/*板基地址设为640*/也可以采用其默认路径D:\MicrosoftVisualStudio\MyProjects\。2、是否使用外触发启动、停止或同步操作?typedefTD1**TD1Hdl;value=(float64)(dbyte-2047)*10/4096; /*将二进制结果转换为对应的模拟量值,送入value变量*/for(i=0;i<*samples;i++) /*重复采样,采样点数由samples确定*/1)前面板设计2、数据采集和后续工作并行执行的模型计数器:2路,24位,基准时钟20MHz或100KHz如实现c=a+b运算时,c是CIN的运行结果,它只能是输出值,没有对应的输入值,这时应当将其对应的输入口置为无效。假设LabVIEW安装路径为d:\LabVIEW,则在Additionalincludedirectories处添加路径d:\LabVIEW\cintools\。最后形成工程文件add.1.功能描述当新数据被采集来,上次的数据可能还没处理完呢。模拟时域信号的运载信息:电平随时间的变化(波形形状的特性,如斜度、峰值等),比如心脏跳动信号、视频信号。连续模拟输入需要注意,程序读取数据的速度要不慢于设备往缓冲区中存放数据的速度,这样才能保证连续运行时,缓冲区中的数据不会溢出。可以通过调节以下3个参数来达到上述要求:buffersize(缓存的大小)scanrate(采样速率)numberofscanstoreadatatime(每次读取的样本数)连续采集的程序模型为:12/13/2022basea=0x280;40连续模拟输入程序实例12/13/2022连续模拟输入程序实例12/10/202241LabVIEW中的模拟输出12/13/2022LabVIEW中的模拟输出12/10/202242连续模拟输出有两种形式的连续模拟输出:第一种就是在模拟输出之前,将数字信号写入缓冲区中,然后设备连续不断地将缓冲区中的数据通过DAC重复输出。这种连续模出执行效率很高,但是需要写入的数字信号必须是整周期的,不然输出模拟信号将会不连续,在使用上不够灵活。12/13/2022连续模拟输出有两种形式的连续模拟输出:12/10/202243第二种方式:
在设备将缓冲区中数据输出的同时,不断地将数字信号写入缓冲区中,这种方式在编程上比较复杂,但是灵活性比较高,只要保证这一次写入缓冲区的数字信号和上次是连续的就行,不需要每次写入的信号是整周期的。12/13/2022第二种方式:12/10/202244LabVIEW中的数字I/O一般情况下,数字I/O按照TTL逻辑电平设计,其逻辑低电平在0到0.7V之间,高电平在3.4到5.0V之间;在硬件设备上,多路(Line)数字I/O组成一组后被称为端口(Port)。一个端口由多少个数字通路组成是依据其设备而定的,在多数情况下8个数字通路组成一个端口;在LabVIEW中对数字I/O的操作非常简单,可以对整个端口进行操作,也可以对端口中的一路或多路同时进行操作。12/13/2022LabVIEW中的数字I/O一般情况下,数字I/O按照TTL455.3基于的NIDAQ系统的实现
I/O接口设备Lab–PC–1200型数据采集卡的软件驱动
连续信号的采集与显示演示仪。
1.功能描述该信号的采集演示仪可以采集和显示一路信号,参数为:频率范围:0~10kHz。幅值范围:0.1~6V。采用Lab–PC–1200型卡,信号由第0通道输入。12/13/20225.3基于的NIDAQ系统的实现I/O接口设备Lab462.设计步骤在编写VI之前,需在Measurement&Automation驱动软件下,进行相关参数的设置。设置完毕后,进入LabVIEW进行前面板和流程图的设计。
1)参数设置AI设置项:因为输入信号幅值在0.1~6V,故选模拟信号输入方式为有参考地单端输入;量程为0~10V。12/13/20222.设计步骤12/10/202247(a)前面板连续信号的采集与显示演示仪12/13/2022(a)前面板连续信号的采集与显示演示仪12/10/202248连续信号的采集与显示演示仪(b)流程图12/13/2022连续信号的采集与显示演示仪(b)流程图12/10/202249几种简单的测试程序流程模型程序逻辑简单,容易设计和理解1、顺序测试程序的模型几种简单的测试程序流程模型程序逻辑简单,容易设计和理解1、502、数据采集和后续工作并行执行的模型数据采集的速度一般来说高于处理和存储的速度。当新数据被采集来,上次的数据可能还没处理完呢。所以可以先把每次采集到的来不及处理的数据放在缓存里。2、数据采集和后续工作并行执行的模型数据采集的速度一般来说513、并行执行每一任务的模型所有的任务同时运行:采集新的数据、处理上一次采到的数据,显示保存上一次处理好的数据。在这个模型下,要注意第一次循环运行时处理的数据,和循环头两次运行显示存储的数据是无效的,实际循环终止条件式也要考虑到,采集的数据再两次循环后才被保存下来。3、并行执行每一任务的模型所有的任务同时运行:采集新的数据525.4使用NIDAQ设备和LabVIEW构造PID控制系统
PID是根据系统误差利用比例/微分/积分计算出控制量进行控制。
1.PID控制系统结构图
12/13/20225.4使用NIDAQ设备和LabVIEW构造PID控制系统53
2.PID控制算法P比例控制器:输出仅与误差成正比,即u(t)=Kpε(t),对误差的反应很快,但总是存在一个稳态误差。提高Kp值使稳态误差减小,还能够增加系统的快速性;但使系统的稳定程度变差。
I积分控制器:输出与误差信号的积分成正比,只要误差还存在,就会不断输出,直到等于零,以达到消除稳态误差的目的。但积分必将影响系统的快速动态性能,对于一些系统会出现超调过大的现象。D微分控制器:输出与误差信号的变化率成正比,能预见误差的变化趋势,产生超前的控制作用。它仅对动态过程作用,通常不单独使用。而且微分控制对噪声干扰有放大作用,过强地调节微分项对系统抗干扰能力不利。
12/13/20222.PID控制算法12/10/2022543.LabVIEW中使用的PID控制工具包
安装LabVIEWPIDControlTookit,即可在FunctionsPalette上选择ControlDesign&Simulation,该工具包由10个VI组成。12/13/20223.LabVIEW中使用的PID控制工具包安装La55PID.vi
利用PID.vi即可搭建一个简单的PID控制器,在该vi的输入端给入PID的3个参数值(PIDgains),系统反馈值(processvariable),实际期望值(setpoint)以及微分时间(dt),便能得到需要的输出值(output)。该vi还能控制输出值的范围。12/13/2022PID.vi利用PID.vi即可搭建一个简单的PID56PIDAdvanced.vi:为专家PID设计的vi,增加了一些高级的功能,如可以设定期望值的范围(setpointrange),手动控制(manualcontrol),线性化(linearity)等功能。PIDAutotuning.vi:为需要自整定的PID系统设计的,在给出一些基本要求后,具有自整定的功能PIDLead/Lag.vi:可以对PID控制器前端由系统反馈来的输入信号做动态补偿。PIDSetpointProfile.vi:可以在期望值间断性变化时使其变得平滑。12/13/2022PIDAdvanced.vi:为专家PID设计的vi,增加57PIDControlInputFilter.vi:一个五阶的低通滤波器,放在PID控制器的processvariable前端,可以滤去小于采样率十分之一的输入值。PIDGainSchedule.vi:写入几组增益参数,并给出条件,执行时当输入信号达到条件,便使用对应的一组参数给入到PID控制器的PIDGains上。PIDOutputLimiter.vi:对PID控制器输出信号的变化速率进行控制,以保证外部接受控制信号部件的安全。PIDEGUto%.vi和PID%toEGU.vi:对实际数值和其在设定工程单元范围内占的百分比进行转换。12/13/2022PIDControlInputFilter.vi:一个5812/13/202212/10/2022595.5非NI公司的DAQ系统的实现1、直接调用LabVIEW驱动操作图标
2、直接调用LabVIEW的端口操作图标;
3、调用动态连接库;
4、利用CIN图标调用C语言驱动程序;12/13/20225.5非NI公司的DAQ系统的实现1、直接调用LabVIE60直接调用LabVIEW驱动操作图标(研华)
12/13/2022直接调用LabVIEW驱动操作图标(研华)
12/10/26112/13/202212/10/202262直接调用LabVIEW的端口InPort/OutPort.Vi
LabVIEW中有两个可直接访问底层设备的图标,即InPort.vi和OutPort.vi。分别完成从设备的物理地址直接读取和输出数据的功能。12/13/2022直接调用LabVIEW的端口InPort/OutPor63InPort.vi、OutPort.vi图标端口参数设置
1.InPort.vi图标及其端口参数设置12/13/2022InPort.vi、OutPort.vi图标端口参数设置64该函数完成从指定地址读取一个字节或一个字的操作,其输入、输出口参数及其含义为:输入端口:
registeraddress:U32型。数据读入端口的物理地址。readabyteoraword:Boolean型。当该值为True时,读取一个字;当该值为False时,读取一个字节。默认值为False。输出端口:value:U16型。该值是从指定端口读取的字(或字节)。12/13/2022该函数完成从指定地址读取一个字节或一个字的操作,其输入、输出65OutPort.vi图标及其端口参数设置
该函数完成向指定地址写入一个字或字节的操作。其输入端口参数及其含义为:12/13/2022OutPort.vi图标及其端口参数设置
该函数完成向指定66
CLF(CallLibraryFunctionNode)
调用库函数节点
Labview可以与多种类的编程语言进行混合开发,通过Labview中两类外部接口节点调用外部代码.调用库函数节点:调用外部动态链接库DLL文件中的函数;代码接口节点:调用外部c语言代码,CLF节点最为常用,配合其他C语言编译器基本上可以取代CIN节点12/13/2022CLF(CallLibraryFunctionNo67动态链接库DLL可以理解为一种存储函数、变量或类的仓库,供调用者使用。它具有这样的特点:动态链接库不用被包含在调用程序体内,而是在执行时根据需要动态地加载或卸载,这样不仅可以减少调用程序文件的体积,还可以增强调用的灵活性,并节省内存占用量。DLL文件的创建与具体编程语言和编译器无关,可以便用VC、VB也可以使用Labview编写DLL文件,只要遵守统一的DLL接口和调用规范,就可正常使用。动态链接库DLL的特点12/13/2022动态链接库DLL可以理解为一种存储函数、变量或类的仓库,供调68使用CLF节点调用windowsAPI函数实例
设计步骤:(1)新建一个空.vi并保存为“CLPAPI函数.vi”,向框图内拖入一个CLF节点,在其右键菜单中选择“配置.”项,弹出配置对话框;12/13/2022使用CLF节点调用windowsAPI函数实例
设计步骤:69(2)单击对话框“函数”页面中“库名或路径”框右侧的打开文件按钮,选挥“C:\WINDOWS\system32\user32d11”文件,LabVIEW会自动搜出该DLL中所包含的所有函数,只需在“函数名”下拉列表今选择即可。本例中选择名为“MessageBoxA,的函数,用于弹出一个标标准的Windows消息框。右侧的“线程”单选框选为“在UI线程中运行’,“调用规范”单选框选为”stdcall(WINAPI)”。12/13/2022(2)单击对话框“函数”页面中“库名或路径”框右侧的打开文70(3)对话框“参数”页面用于配置函数参数,需根据所调用函数的原型来进行配置,由MSDN可知:MessageBoxA函数的原型:
IntMessageBoxA(HWNDhwnd,LpcTSTRlptext,LpcTsTRlpcaption,Uintwtype)其各个参数具体含义为
hwnd:创建消息框的父窗口的句柄,若为NuLL则没有父窗口1pText:消息框牛的字符串.1pcaPtton:消息框标题Mtype:用于指定消息框所显示图标和按钮的控制参数。(12/13/2022(3)对话框“参数”页面用于配置函数参数,需根据所调用函数71使用该页面中的右侧下拉列表和左侧的各个按钮,将返回值和各个参数类型设置为:
Returetype:类型=数值,数据类型=无符号32位整型
hwnd:类型=数值,数据类型=无符号32拉整型,传递=值
1PText:类型=字符串,数据类型=C字符串指针
1pcaption:类型=字符串,数据类型=字符串指针
uType:类型=数值,数据类型=无符号32位整型,传递=值其他选项均使用默认值。(4)对话框“回调”页面用于指定调用方式,在此使用默认配置即可。全部配置好之后单击‘确定”按钮进行确认,可以看到CLF节点增添了一些连接端子表示新添的参数,添加适当的常量或变量连接至各个参数。12/13/2022使用该页面中的右侧下拉列表和左侧的各个按钮,将返回值和各个参72CIN(CodeInterfaceNode)CIN的设计步骤:(1)确定CIN图标的输入、输出参数个数和数据类型。(2)生成C源代码编辑格式文件。(3)在编辑格式文件中的规定位置(/*EnterYourCodeHere*/)填写实现某种测量功能的C源代码,生成最终的C源代码文件。(4)在LabVIEW指定的环境下编译步骤(3)中生成的C源代码文件,并生成可执行文件。(5)调用CIN的功能菜单将生成的可执行文件载入CIN图标。这样就基本形成了一个具备某种功能的CIN图标。12/13/2022CIN(CodeInterfaceNode)CIN的设计73CIN图标的调用及参数设置初始化时的CIN图标如图所示。CIN图标中表格状图案的每一行代表一个参数,左侧为参数的输入值,右侧为CIN运行后该参数的返回值。参数1输入口参数1返回值的输出口有些情况下,有的参数只能作为输出值,而没有对应的输入。如实现c=a+b运算时,c是CIN的运行结果,它只能是输出值,没有对应的输入值,这时应当将其对应的输入口置为无效。方法是,把鼠标放在相应的输入口,用鼠标右击CIN图标,弹出快捷菜单,从中选择OnlyOutput项,则该输入口变暗,表明其无效无效a返回值b返回值CIN输出b输入值a输入值12/13/2022CIN图标的调用及参数设置初始化时的CIN图标如图所示。CI74生成C源代码编辑格式文件(*.C文件)代码框架
CIN图标的快捷菜单中选择Create.CFile…项,会弹出一个文件存储对话框,键入文件名
则生成LabVIEW的C语言代码框架;然后用任意一种文本编辑器将它打开。该C文件的代码框架为*CINsourcefile*/注释#include"extcode.h"CINMgErrCINRun(float64*a,float64*b,float64*c);函数声明CINMgErrCINRun(float64*a,float64*b,float64*c) 函数体{
/*ENTERYOURCODEHERE*/填入C语言源代码
returnnoErr; }12/13/2022生成C源代码编辑格式文件(*.C文件)代码框架
CIN图标的75*.C文件源代码的编译
下面介绍在VC++集成环境下编译*.C源代码的具体步骤。(1)新建一个DLL工程文件,命名为Add。打开VC++开发平台,执行File>>New操作。①进行选项:win32DynamicLinkLibrary。②添加工程文件名:Add。③location:填写工程文件的存放路径。也可以采用其默认路径D:\MicrosoftVisualStudio\MyProjects\。最后形成工程文件add.cpp。12/13/2022*.C文件源代码的编译
下面介绍在VC++集成环境下编译*.76(2)向工程文件中添加cin.obj、labview.lib、lvsb.lib、lvsbmain.def四个文件。执行Project>>AddtoProject>>Files…操作,向工程文件添加上述四个文件。这四个文件在LabVIEW安装路径下的cintools文件夹下的win32子文件夹中。(3)向工程文件中添加上面的*.C源代码文件add.c。添加方法同(2)。(4)*.C源代码文件编译前的设置。由菜单项Project>>Setting…打开设置对话框,逐项设置。①
Settingfor选项设置。AllConfiguration。②
C/C++标签页设置。用鼠标左击C/C++标签页按钮,逐项设置。12/13/2022(2)向工程文件中添加cin.obj、labview.li77l
Category:由下拉菜单选择为Preprocessor。Additionalincludedirectories:添加LabVIEW的cintools文件夹的路径。假设LabVIEW安装路径为d:\LabVIEW,则在Additionalincludedirectories处添加路径d:\LabVIEW\cintools\。l
Category:由下拉菜单另选为CodeGeneration。Strictmemberalignment:设置为1Byte。Userun-timelibrary:设置为MultithreadedDLL。12/13/2022l
Category:由下拉菜单选择为Preproces78③CustomBuild标签页设置。用鼠标左击CustomBuild标签页,逐项设置。l
Commands:输入命令行如下:d:\labview\cintools\win32\lvsbutil$(TargetName)–d“$(WkspDir)\$(OurDir)”(假设LabVIEW的安装路径为:d:\labview。)l
Outputs:输入命令行如下:$(OutDir)$(TargetName).lsb12/13/2022③CustomBuild标签页设置。用鼠标左击Custo79(5)添加C源代码程序。可在Workspacewizard窗口中双击add.c,打开源文件添加C源代码。如果已经添加过,则继续下一步。(6)编译*.C源代码文件。在主菜单Build下选择Compileadd.c选项,则进行add.c程序的编译,如有语法等错误,则给出错误提示,按提示修改程序,重新编译。重复这一过程,直至没有错误。(7)生成可执行文件。在主菜单Build下选择BuildAdd.dll选项,即生成可执行文件Add.lsb,同时生成如Add.dll等所需的全部文件12/13/2022(5)添加C源代码程序。12/10/2022801.装载可执行文件到CIN图标回到LabVIEW流程图窗口,窗口中CIN图标的快捷菜单如左图所示。从中选择LoadCodeResource…项,即弹出一个Chooseacoderesourcefile对话框,如右图所示。按照Add.工程文件存入的路径寻找Debug目录下的Add.lsb文件,然后点击“打开”按钮,于是Add.lsb文件就装入CIN图标中。至此,就完成了CIN的全部设计过程,可运行程序。12/13/20221.装载可执行文件到CIN图标12/1081应用举例
用CIN图标实现对HY–1232数据采集卡的驱动–1232数据采集卡简介
HY–1232是一种IBM–PCXT/AT总线兼容的数据采集卡,其主要性能指标如下:
32路单端模拟输入通道;
A/D分辨率为12bit;1路模拟输出通道;D/A分辨率为12bit;D/A输出上电清零;模拟输入电压范围:5V;模拟输出电压范围:5V或0~+5V;软件触发方式;数据传输方式采用软件查询方式和中断方式。12/13/2022应用举例
用CIN图标实现对HY–1232数据采集卡的驱动–82HY–1232数据采集卡工作原理
对于HY–1232数据采集卡,在选通某模拟信号输入通道的同时即启动了该路的A/D转换。当A/D转换完成时,采集卡上的转换完成位寄存器的最高位(D7)被置为“1”。用软件查询方式查询该寄存器的D7位,当查询到该位为“1”时,即表明采样已结束,可将12bit的数据读入计算机内存中。如果采用中断方式,则在A/D转换完成后,采集卡会自动向计算机发出中断请求信号。在中断服务程序内,将12bit数据读入计算机内存。12/13/2022HY–1232数据采集卡工作原理
对于HY–1232数83HY–1232数据采集卡中采用的是12位A/D转换器,转换完毕的12位二进制数中的低八位AD7、AD6…AD1、AD0存放在低八位缓冲寄存器中,其高四位AD11、AD10、AD9、AD8存放在高四位缓冲寄存器中。
HY–1232数据采集卡有32路单端模拟输入通道,由八位输入通道选择寄存器低六位(C4、C3、C2、C1、C0)的二进制状态字选择被测信号的输入通道。例如,选择第4通道输入信号的二进制状态字为00100。表5-1列入了各寄存器的读/写操作功能与占用地址。12/13/2022HY–1232数据采集卡中采用的是12位A/D转换器,转84表5–1HY–1232数据采集卡板基地址分配与寄存器读/写操作功能12/13/2022表5–1HY–1232数据采集卡板基地址分配与寄存器读/85采集卡参数设置
(1)确定采集卡的板基地址。板基地址是CPU分配给采集卡内存空间的首地址。首地址后面的内存空间供采集卡内部寄存器分配使用。
HY–1232数据采集卡板基地址的可选范围为:200H~3FFH(512~1023)。通常选0x280,即280H(640)。
(2)确定信号的输入方式。选择设置信号是单端输入还是双端输入,单极性信号还是双极性信号。HY–1232数据采集卡只有32路单端输入一种方式,故不需要用户来设置。12/13/2022采集卡参数设置12/10/202286(3)设置信号的输入范围。根据输入信号幅值范围和分辨率的要求进行选择。HY–1232数据采集卡信号输入范围不可选,只能为–5V~+5V,且内部的放大器增益固定为1。
(4)确定采样触发方式。一般分外触发、定时触发、软件触发等几种方式。但对于HY–1232采集卡,只有软件触发一种方式,即在往输入通道寄存器写入所选通道号的同时即触发了A/D转换。12/13/2022(3)设置信号的输入范围。根据输入信号幅值范围和分辨率的要87(5)A/D转换结束的判断。对于HY–1232采集卡分查询方式和中断方式两种。
(6)采样速率的设置。对于有些数据采集卡(如Lab–PC–1200卡),用户可在其最大采样速率范围内进行选择设置,以满足实际的需要。但HY–1232数据采集卡的采样速率是固定的,用户不可选。
(7)设置信号输入通道。在0~31可选范围内选择。
(8)设置一次采集点数。12/13/2022(5)A/D转换结束的判断。对于HY–1232采集卡分查询88图2HY–1232数采卡单点数据采集程序流程图采集程序流程图与编程要点1.流程图HY–1232数采卡单点数据采集程序流程图如图2所示。12/13/2022图2HY–1232数采卡单点数据采集程序流程图采集程序流程892.数据采集程序HY–1232数据采集卡采集一个点的C源程序如下:#include<dos.h>#include<conio.h>#include<stdio.h>voidmain(void){intbasea,channel;floatvalue,IO,hi;12/13/20222.数据采集程序12/10/202290basea=0x280;/*板基地址设为640*/printf(“Inputchannelnumber:”); /*设置采集通道号*/scanf(“%d”,&channel);outp(base,channel); /*往输入通道寄存器写入所选通道号,并触发A/D转换*/do/*查询A/D转换完成寄存器的最高位,若为1,则表明A/D换结束,否则继续查询*/while(!(inp(basea+5)&0x80));lo=inp(base+1); /*读入A/D结果的低八位*/hi=inp(base+2)/*读入A/D结果的高四位value=((lo+hi&0xf)*256)-2047)*10.0/4096;/*合并后,再将A/D转换的二进制结果转换成对应的模拟量值*/getch();}12/13/2022basea=0x280;913.编程要点说明
1) outp(x,y)和inp(x)函数
C语言接口函数①
outp(x,y)函数的功能是把函数y送入端口地址为x的寄存器中。
outp(base,channel)是把通道号channel(程序中是由前面板控件设置)送入地址为base的输入通道选择寄存器,并启动该通道的A/D转换。
②inp(x)函数的功能是从端口地址为x的寄存器中读取二进制数据。inp(base+1)从地址为base+1的低八位寄存器读取A/D转换结果。inp(base+2)从地址为base+2的高四位寄存器读取A/D转换结果二进制数的高四位,并清除A/D完成位寄存器和中断请求信号。inp(base+5)从地址为base+5的完成位寄存器读取完成标志位I/O显示值,当IO=0时,表示A/D转换未完成;当IO=1时,表示A/D转换完毕。
12/13/20223.编程要点说明②inp(x)函数的功能是从端口地址923)A/D转换结果的合并及工程运算
hi&oxf是将A/D结果高四位(二进制数)转化为十六进制数,(hi&oxf)*256则将十六进制数转化为十进制数,lo+(hi&0xf)*256将数据合并为一个十进制数。这里,被测信号的输入范围设置为-5V~+5V,HY–1232卡的分辨率为12位,则量化值Q为10.0/4096(V),而十进制数也需减去满量程的一半:4096/2=2048,由于十进制数从0开始,故满量程的一半是2047。因此,用value=((lo+hi&oxf)*256)-2047)*10.0/4096就可以将A/D输出的二进制数转换为与模拟输入电压相对应的电压值。
例如,若hi=1011、lo=11010011,那么hi&oxf=0xb,
(hi&oxf)*256=11*266,lo+(hi&oxf)*256=(27+26+24+21+20+11*256=3027,则采集卡的模拟输入电压为
value=(3027-2047)*10.0/4096=2.3926V12/13/20223)A/D转换结果的合并及工程运算例如,若hi=1933具体设计方法
1.模拟信号采集系统功能描述使用CIN实现非LabVIEW支持的HY–1232数据采集卡的驱动。要求在LabVIEW下利用HY–1232采集卡实现一个模拟信号(200Hz的正弦波)的采集和波形显示。要求采样点数、板基地址和通道号可设。
2.设计提示
1)前面板设计数字控件1:用来设置HY–1232数据采集卡的板基地址。基地址basea的数据类型选为U16(因为HY–1232的基地址最大为3FFH),默认值设为640(即0x280)。数字控件2:用来设置信号的输入通道。通道号channel的数据类型选为U8(因为HY–1232的模拟输入通道为0~31),默认值为0,数据范围为0~31。数字控件3:用来设置采样点数。总采样点数samples的数据类型为32,默认值设为100。12/13/20223具体设计方法2.设计提示12/10/202294模拟信号采集程序前面板12/13/2022模拟信号采集程序前面板12/10/2022952)流程图设计
(1)放置CIN图标,并设置图标的输入、输出参数个数及数据类型。①
调用路径。由Functions>>Advanced>>CodeInterfaceNode路径调入CodeInterfaceNode。②
参数设置。本例中,CIN图标有三个输入参数——basea、channel、samples和一个输出参数Waveform。Waveform是一个double型数组,用于存放采集结果。参数数据类型的选择与前面板一致。12/13/20222)流程图设计12/10/202296CIN图标属性对话框(2) C源代码文件的生成选择如图4所示的CIN图标快捷菜单选项中的Create.cFile选项,生成C源代码格式文件(*.C文件)。12/13/2022CIN图标属性对话框(2) C源代码文件的生成12/1097本例生成的格式文件内容如下:/**CINsourcefile*/ #include"extcode.h"/**typedefs*/typedefstruct{ int32dimSize; float64arg1[1];12/13/2022本例生成的格式文件内容如下:12/10/202298 }TD1;typedefTD1**TD1Hdl;
CINMgErrCINRun(uInt16*basea,uInt8*channel,int32*samples,TD1HdlWaveform);
CINMgErrCINRun(uInt16*basea,uInt8*channel,int32*samples,TD1HdlWaveform){
/*ENTERYOURCODEHERE*/
returnnoErr; }12/13/2022 }TD1;12/10/202299从上面生成的代码可以看到,因为定义的CIN图标输出参数是数组型的,而LabVIEW向CIN传递数组类数据时,用的是句柄handle。传递数组的句柄结构是这样定义的:typedefstruct{ int32dimSize;/*数组尺寸*/ float64arg1[1];/*数组首地址指针*/ }TD1;typedefTD1**TD1Hdl;对于一个有n个元素的一维数组,用dimsize函数表示为dimsize=n。对于一个m×n的二维数组a[m][n],
用dimSize函数表示为dimSize[0]=m,dimSize[1]=n。12/13/2022从上面生成的代码可以看到,因为定义的CIN图标输出参数是数组100(3)填写C源代码将HY–1232的C语言采集程序填入到上面的C源代码框架中。最终完成的C源代码文件(sampdata.c文件)如下:
(注:设计者自行添加的语句为黑斜体,其余为自动生成的语句)/**CINsourcefile*/#include"extcode.h" /*自动生成*/#include"hosttype.h"
/*调用了系统及功能函数,因此添加此头文件*/#include"dos.h" /*调用了C语言中的inp()
、outp()
函数,因此添加此头文件*//*12/13/2022(3)填写C源代码/*12/10/2022101*typedefs*/typedefstruct{int32dimSize;/*数组尺寸*/float64arg1[1];/*数组首地址指针*/}TD1;typedefTD1**TD1Hdl;CINMgErrCINRun(uInt16*basea,uInt8*channel,int32samples,TD1HdlWaveform);/*函数声明*/CINMgErrCINRun(uInt16*basea,uInt8*channel,int32*samples,TD1HdlWaveform)/*函数体*/{/*ENTERYOURCODEHERE*/12/13/2022*typedefs12/10/2022102int16dbyte;/*定义16位字(A/D转换结果)*/float64value;/*定义变量,存放单点的A/D转换结果对应的模拟量*/float64array;/*定义数组,存放所有点的A/D转换结果对应的模拟量*/int32i;/*定义变量,存放循环采样次数*/MgErrerr=noErr;/*动态设定数组Waveform的大小*/
if(err=SetCINArraySize((UHandle)Waveform,3,*samples))gotoout;(*Waveform)—>dimSize=*samples;/*取数组Waveform的参数:dimSize,将其置为samples*/ array=(*Waveform)—>arg1;/*取数组Waveform的参数:arg1e,置给array*/12/13/2022int16dbyte;/*定义16103/*软件查询式采集程序*/for(i=0;i<*samples;i++) /*重复采样,采样点数由samples确定*/{outp(*basea,channel); /*向板基地址写入所选模拟信号通道号并启动A/D转换*/dbyte=0;do /*以查询方式循环采样。采样结果送入dbyte(12位)*/12/13/2022/*软件查询式采集程序*/12/10/2022104while(!(inp(*basea+6)&0x80));dbyte=inp(*basea+1)|((inp(*basea+2)&0xf)<<8);
value=(float64)(dbyte-2047)*10/4096; /*将二进制结果转换为对应的模拟量值,送入value变量*/array=value;/*此次转换结果存入array数组中*/array++;/*修改数组指针*/} out:returnerr; }12/13/2022while(!(inp(*basea+6)&0x80)105数据采集与仪器驱动数据采集与仪器驱动106数据采集与仪器驱动数据采集与仪器驱动107第五章数据采集与仪器驱动5.1数据采集与控制系统构成5.2数据采集VI的组织结构5.3基于NI的DAQ系统的实现5.4非NI的DAQ系统的实现本章小结
12/13/2022第五章数据采集与仪器驱动5.1数据采集与控制系统构成1085.1数据采集、控制系统的构成
采用基于PC的数据采集(dataacquisition,DAQ)、控制系统来完成实验室研究和工业控制中的测控任务的方案配置是:
工控机+数据采集/控制卡+VB/VC/LabView编程,即:数据采集/控制卡:完成一般测试仪器的数据采集和控制功能,工控机系统:完成一般测试仪器的数据分析、计算、显示、输出等功能。12/13/20225.1数据采集、控制系统的构成采用基于PC的数据采集109数据采集控制系统的组成12/13/2022数据采集控制系统的组成12/10/2022110模拟信号的数字化处理数据采集的核心过程就是将连续的模拟信号转换成离散的数字信号采样点太多,会占用大量内存单元;采样点太少,会使模拟信号的某些信息被丢失,出现失真现象12/13/2022模拟信号的数字化处理数据采集的核心过程就是将连续的模拟信号转111数据采集卡
数据采集卡的组成:①多路开关:将各路信号轮流切换到放大器的输入端,实现多参数多路信号的分时采集。②放大器:将前一级多路开关切换进入待采集信号放大(或衰减)至采样环节的量程范围内。通常实际系统中放大器为增益可调的放大器,设计者可根据输入信号不同的幅值选择不同的增益倍数。
③采样/保持器:取出待测信号在某一瞬时的值(即实现信号的时间离散化),并在A/D转换过程中保持信号不变。如被测信号变化很缓慢可不用采样/保持器。12/13/2022数据采集卡
数据采集卡的组成:12/10/2022112④A/D转换器:输入的模拟量转化为数字量输出,并完成信号幅值的量化。随着电子技术的发展,目前通常将采样/保持器同A/D转换器集成在一块芯片上。以上四个部分都处在PC计算机的前向通道,完成对信号数据的采集、放大及模/数转换任务。12/13/2022④A/D转换器:输入的模拟量转化为数字量输出,并完成信号幅113需要注意的两个问题1、是否使用Buffer?2、是否使用外触发启动、停止或同步操作?缓冲(Buffers):缓冲指的是PC内存的一个区域(不是数据采集卡上的FIFO缓冲),它用来临时存放数据。使用BufferI/O的情况:需要采集或产生许多样本,其速率超过了实际显示、存储到硬件,或实时分析的速度。需要连续采集或产生AC数据(>10样本/秒),并且要同时分析或显示某些数据。采样周期必须准确、均匀地通过数据样本。12/13/2022需要注意的两个问题1、是否使用Buffer?12/10/20114registeraddress:U32型。首地址后面的内存空间供采集卡内部寄存器分配使用。outp(*basea,channel); /*向板基地址写入所选模拟信号通道号并启动A/D转换*/当IO=1时,表示A/D转换完毕。vi和PID%toEGU.对于HY–1232采集卡分查询方式和中断方式两种。hwnd:类型=数值,数据类型=无符号32拉整型,传递=值returnnoErr;c选项,则进行add.(5)调用CIN的功能菜单将生成的可执行文件载入CIN图标。float64value;/*定义变量,存放单点的A/D转换结果对应的模拟量*/以NI公司的PCI-6071E多功能采集卡为例,介绍采集卡的一般参数:模拟信号:直流、时域、频域信号。/*软件查询式采集程序*/vi:可以对PID控制器前端由系统反馈来的输入信号做动态补偿。不使用Buff
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 联合门禁系统在商业地产中的应用前景分析
- 2025年度医疗机构与儿科医生合作研究协议
- 跨文化视角下的经典文学作品阅读指导
- 2025年度海洋可再生能源开发海域使用权租赁合同
- 社交媒体在学生时尚背包消费决策中的角色和影响研究
- 未来小学教育趋势与综合素质评价的关系探讨
- 科技赋能AI游戏设计的多维度创新
- 精准营销对公客户信息挖掘与市场分析
- 社交媒体在客户服务优化中的作用
- 科技助力下的家庭急救知识普及
- 2024年4月自考00832英语词汇学试题
- 竞赛试卷(试题)-2023-2024学年六年级下册数学人教版
- 《电力用直流电源系统蓄电池组远程充放电技术规范》
- 2024年中考语文 (湖北专用)专题一 字音、字形课件
- T-ACEF 095-2023 挥发性有机物泄漏检测红外成像仪(OGI)技术要求及监测规范
- 2023年全国高考乙卷历史真题试卷及答案
- 骨科手术的术后饮食和营养指导
- 旅游定制师入行培训方案
- 2024年中国南方航空股份有限公司招聘笔试参考题库含答案解析
- 六年级上册数学应用题100题
- 个人代卖协议
评论
0/150
提交评论