《毕业设计(论文)双CPU数据采集系统.doc》由会员分享,可在线阅读,更多相关《毕业设计(论文)双CPU数据采集系统.doc(56页珍藏版)》请在三一办公上搜索。
1、目 录第一章 绪言31.1 课题的背景和意义31.2 国内外研究概况和发展趋势41.3 本文的主要研究内容5第二章 双CPU数据采集系统的基本原理62.1 正弦交流信号发生与采样62.1.1 正弦交流信号的产生62.1.2 正弦交流信号采样122.2 数据采集132.2.1 ADC0809性能特点132.2.2 ADC0809应用电路原理图16第三章 双机通信原理173.1 双机通信基本方法173.1.1 并行通信方式173.1.2 串行通信方式173.2 串行通信接口标准203.2.1 RS-232握手方式213.3 串口通信电路23第四章 人机交互接口244.1 HD7279244.1.1
2、HD7279的主要特性244.1.2 HD7279引脚说明244.1.3 HD7279控制指令254.2 人机接口电路28第五章 系统软件设计295.1 主机程序295.1.1 主机主程序305.1.2 数据处理子程序315.1.3 HD7279显示子程序315.1.4 HD7279显示字型码325.2 从机程序33第六章 系统调试366.1 数据采集模块调试376.2 人机接口模块调试386.3 信号处理模块386.4 峰值保持模块396.5 总体调试39第七章 总结40参考文献41致谢42附录一 源程序43主机程序43从机程序51附录二 电路与原理总图55第一章 绪言1.1 课题的背景和意
3、义 近年来,数据采集及其应用受到了越来越广泛的关注,数据采集系统也有了较快的发展,它可以广泛的应用于各领域。 数据采集是指从传感器和其它待测设备等模拟和数字被测单元中自动采集信息的过程。 数据采集系统是结合基于计算机(或微处理器)的测量软硬件产品来实现灵活的、用户自定义的测量系统。该数据采集系统是一种基于ADC0809模数转换芯片和单片机的设备,可以把ADC采集的电压信号转换为数字信号,经过微处理器的简单处理而交予数码管实现电压显示功能,并且通过与PC的连接可以实现计算机更加直观化显示。在计算机广泛应用的今天,数据采集的在多个领域有着十分重要的应用。它是计算机与外部物理世界连接的桥梁。利用串行
4、或红外通信方式,实现对移动数据采集器的应用软件升级,通过制订上位机(PC)与移动数据采集器的通信协议,实现两者之间阻塞式通信交互过程。在工业、工程、生产车间等部门,尤其是在对信息实时性能要求较高或者恶劣的数据采集环境中更突出其应用的必要性。例如:在工业生产和科学技术研究的各行业中,常常利用PC或工控机对各种数据进行采集。这其中有很多地方需要对各种数据进行采集,如液位、温度、压力、频率等。现在常用的采集方式是通过数据采集板卡,常用的有A/D卡以及422、485等总线板卡。卫星数据采集系统是利用航天遥测、遥控、遥监等技术,对航天器远地点进行各种监测,并根据需求进行自动采集,经过卫星传输到数据中心处
5、理后,送给用户使用的应用系统。尽管现在已微机为核心的可编程数据采集与处理采集技术的发展方向得到了迅速的发展,而且组成一个数据采集系统只需要一块数据采集卡,把它插在微机的扩展槽内并辅以应用软件,就能实现数据采集功能,但这并不会对基于单片机为核心的数据采集系统产生影响。相比于数据采集板卡的成本和功能的限制,单片机具有多功能、高效率、高性能、低电压、低功耗、低价格等优点。而双单片机具有精度高、转换速度快、能够对多点同时进行采集,因此能够开发出 满足实际应用要求的,电路结构简单的,可靠性高的数据采集系统。这就使得以单片机为核心的数据采集系统在许多领域得到了广泛的应用。单片机因其集成度高,控制能力强,稳
6、定可靠的特点,在家用电器、工业自动化、智能仪表、航空航天、汽车电子等领域得到了广泛的应用。 常规的单片机应用系统的设计,往往都采用一个CPU,加一系列的周围辅助电路以达到相应的设计目的,这种方法在输入输出接口较多的系统当中,必须进行繁琐的编译码,逻辑变换,使得系统硬件复杂,调试困难。而采用双CPU设计,可以大大减少硬件电路,软件资源分配及设计均相对独立,易于修改程序而适合很多应用系统。1.2 国内外研究概况和发展趋势 数据采集系统是通过采集传感器输出的模拟信号并转换成数字信号进行分析处理、传输、存储和显示。它起始于二十世纪中期,在过去的几十年里,随着信息领域各种技术的发展,在数据采集方面的技术
7、也取得了极大的进步,采集数据信息化是目前社会发展的主流方向。各领域都用到了数据采集,在石油勘探、科学实验、地震等数据采集已经得到应用。 随着计算机的软件、硬件技术的发展,在控制系统中大量应用到了计算机新技术,工业自动化将成为一种发展趋势。过去的控制系统,由于受到软硬件的限制,人们首先考虑到的是实现的可行性。当今,硬件方面飞速发展,各种高精密度的温度控制器已经能够满足人们在大多数场合下的控制要求,如何更有效的管理和检测生产现场,如何更有效的利用技术资源、设备资源等成为了用户关注的焦点。 现代世界是一个高速自动化的世界,各种各样的设备已与计算机联机,同时还可以互联机,而最简单的自动化联机方式就是使
8、用串行通信。随着时代的进步,它以稳定性,简单可行和高效率逐渐被广泛应用。 在国内外诸多工业应用中许多极为复杂的控制系统中通常会采用双CPU配置,一个CPU负责数据采集,一个负责控制等工作,使得控制更为精密,系统误差极少。但随着集成电路的发展,CPU处理速度越来越惊人,周边外围电路集成化,使得一个CPU足以负责全部工作,所以在双CPU处理方面研究成果及进展较少。但是在一些有成本限制,但系统复杂的情况下双CPU系统还是有着极为显著地作用。双CPU数据采集系统能够以极低的成本到达极高的性能。1.3 本文的主要研究内容 本文阐述了双机通信的基本原理和高速数据采集的基本实现办法,分析了正弦交流信号产生及
9、采样处理办法。提出了使用双CPU解决单CPU因大量的数据输出和人机对话事件的发生,而直接影响数据采集系统的正常工作,造成部分数据的丢失。采用双CPU数据采集系统不仅实现了所需的高速数据采集而且结构简单成本低等优点。本文的主要研究内容有:(1) 介绍了双CPU数据采集系统基本类型,以及国内外对双CPU数据采集系统的研究现状,分析了高速数 据采集的基本原理。(2) 设计了以ICL8083芯片为基础的波形发生电路,以及周边信号处理电路包括数据采集电路,信号处理电路,峰值保持电路。(3) 对双CPU数据采集控制软件的研究和设计。系统原理框图如下: 图1-1 系统框图 第二章 双CPU数据采集系统的基本
10、原理2.1 正弦交流信号发生与采样2.1.1 正弦交流信号的产生(一) RC振荡电路RC振荡是最为常见的正弦波发生电路,由RC选频网络构成的电路,它适用于低频振荡,一般用于产生1Hz1MHz的低频信号。而常用LC振荡电路产生的正弦波频率较高,若要产生频率较低的正弦振荡,势必要求振荡回路要有较大的电感和电容,这样不但元件体积大、笨重、安装不便,而且制造困难、成本高。因此,200kHz以下的正弦振荡电路,一般采用振荡频率较低的RC振荡电路。本课题要求产生的正弦波频率范围20HZ2KHZ,所以应当采用RC振荡电路。常用的RC振荡电路有相移式和桥式两种。1 RC移相式振荡器,具有电路简单,经济方便等优
11、点,但选频作用较差,振幅不够稳定,频率调节不便,因此一般用于频率固定、稳定性要求不高的场合。其振荡频率是 fo=1/26RC 。2 RC桥式振荡器 将RC串并联选频网络和放大器结合起来即可构成RC振荡电路,放大器件可采用集成运算放大器。 图 2-1 RC振荡电路 如图所示,RC串并联选频网络接在运算放大器的输出端和同相输入端之间,构成正反馈,Rf、R接在运算放大器的输出端和反相输入端之间,构成负反馈。正反馈电路和负反馈电路构成一文氏电桥电路,运算放大器的输入端和输出端分别跨接在电桥的对角线上,所以,把这种振荡电路称为RC桥式振荡电路。 振荡信号由同相端输入,故构成同相放大器,输出电压Uo与输入
12、电压Ui同相,其闭环电压放大倍数等于Au=Uo/Ui=1+(Rf/R1)。而RC串并联选频网络在=o=1/RC时,Fu=1/3,f=0,所以,只要|Au|=1+(Rf/R1)3,即Rf2R1,振荡电路就能满足自激振荡的振幅和相位起振条件,产生自激振荡,振荡频率fo等于 fo=1/2RC 采用双联可调电位器或双联可调电容器即可方便地调节振荡频率。在常用的RC振荡电路中,一般采用切换高稳定度的电容来进行频段的转换(频率粗调),再采用双联可变电位器进行频率的细调。 RC移相式振荡电路具有结构简单、经济等优点。但是其选频作用较差,频率调节不方便,输出幅度不够稳定,输出波形较差。一般用于振荡频率固定且稳
13、定性要求不高的场合,其频率范围为几赫到几十千赫。所以本课题不采用RC振荡电路作为正弦波信号产生。(二) 单片集成函数信号发生器ICL8038 ICL8038的波形发生器是一个用最少的外部元件就能生产高精度正弦,方形,三角, 锯齿波和脉冲波形彻底单片集成电路. 频率(或重复频率) 的选定从0.001hz到300khz可以选用电阻器或电容器来调节, 调频及扫描可以由同一个外部电压完成. ICL8038精密函数发生器是采用肖特基势垒二极管等先进工艺制成的单片集成电路芯片,输出由温度和电源变化范围广而决定. 这个芯片和锁相回路作用, 具有在发生温度变化时产生低的频率漂移,最大不超过250ppm。1 I
14、CL8038的性能特点a. 具有在发生温度变化时产生低的频率漂移,最大不超过50ppm;b. 正弦波输出具有低于1的失真度;c. 三角波输出具有01高线性度;d. 具有0001Hz1MHz的频率输出范围;工作变化周期宽;298之间任意可调;高的电平输出范围;e. 从TTL电平至28V;f. 具有正弦波、三角波和方波等多种函数信号输出;图2-2 ICL8038实物图g. 易于使用,只需要很少的外部条件。2. ICL8038的封装引脚图 图2-2为ICL8038实物图。脚1、12 (Sine Wave Adjust):正弦波失真度调节;脚2(Sine Wave Out):正弦波输出;脚3(Tria
15、ngle Out):三角波输出;脚4、5(Duty Cycle Frequency):方波的占空比调节、正弦波和三角波的对称调节; 脚6(V):正电源10V18V; 脚7(FMBias):内部频率调节偏置电压输; 脚8(FM Sweep):外部扫描频率电压输入; 脚9(SquareWaveOut):方波输出,为开路结构; 脚10(TimingCapacitor):外接振荡电容; 脚11(V orGND):负电原或地; 脚13、14(NC):空脚。如图2-3所示。 图2-3 ICL8038管脚图 3.ICL8038的工作原理 ICL8038 是单片集成函数信号发生器,其内部框图如图2.1.4所示
16、。它由恒流源I1和 I2、电压比较器A和B、触发器、缓冲期和三角波变正弦波电路等组成。 图2-4 ICL8038内部原理图外接电容C由两个恒流源充电和放电,振荡电容C由外部接入,它是由内部两个恒流源来完成充电放电过程。恒流源2的工作状态是由恒流源1对电容器C连续充电,增加电容电压,从而改变比较器的输入电平,比较器的状态改变,带动触发器翻转来连续控制的。当触发器的状态使恒流源2处于关闭状态,电容电压达到比较器1输入电压规定值的23倍时,比较器1状态改变,使触发器工作状态发生翻转,将模拟开关K由B点接到A点。由于恒流源2的工作电流值为2I,是恒流源1的2倍,电容器处于放电状态,在单位时间内电容器端
17、电压将线性下降,当电容电压下降到比较器2的输入电压规定值的13倍时,比较器2状态改变,使触发器又翻转回到原来的状态,这样周期性的循环,完成振荡过程。在以上基本电路中很容易获得4种函数信号,假如电容器在充电过程和在放电过程的时间常数相等,而且在电容器充放电时,电容电压就是三角波函数,三角波信号由此获得。由于触发器的工作状态变化时间也是由电容电压的充放电过程决定的,所以,触发器的状态翻转,就能产生方波函数信号,在芯片内部,这两种函数信号经缓冲器功率放大,并从管脚3和管脚9输出。 适当选择外部的电阻RA和RB和C可以满足方波函数等信号在频率、占空比调节的全部范围。因此,对两个恒流源在I1和I2电流不
18、对称的情况下,可以循环调节,从最小到最大,任意选择调整,所以,只要调节电容器充放电时间不相等,就可获得锯齿波等函数信号。正弦函数信号由三角波函数信号经过非线性变换而获得。利用二极管的非线性特性,可以将三角波信号的上升成下降斜率逐次逼近正弦波的斜率。 4.波形参数计算图 2-5 ICL8038典型电路所有信号波形对称都可由外部时间电阻器来调整。最佳的结果通过保持时间电阻器RA和RB的独立 。RA控制三角波,正弦波的上升的部份和矩形波的1 个状态。三角信号波形的大小被设置在1/3 电源电压,因此三角的上升的部份是和三角波和正弦波下降部分和矩形波的状态。 当RA = RB时占空比为50%,如果占空比
19、仅在50%小范围变化,连接所在图2.1左元器件是稍微比较方便的。1k的电位器不能允许占空比达到50%,在所有仪器中,如果占空比达到50%电位器是用4.7k而不是5k。方波占空比80%相位关系波形变化可以通过连接外部定时电阻时间和频率而不依赖于电源电压,尽管所有的电压都不是由内部集成电路调节。这归结于实际电流和门限是直接的,电源电压是线性函数,因而他们的不起作用。为了减小正弦波失真,在管脚11和12之间的82K电阻最好是可变电阻及电位器也可。这种安排使失真少于1%是可以达到的。为了减少得更多, 二台电位器可能按照上图2-5左显示的连接,这种典型构造使得正弦波失真减少近0.5%,正弦波失真达到最低
20、的连接。4. 课题采用电路图 2-6 信号发生模块 在本课题中信号发生模块使用的是ICL8038经典电路,可以通过调节R5、R6阻值的大小改变信号频率及其占空比。频率计算方法如图 2-7,在使用的时候我们需要占空比为50%的正弦波信号,所以使RA=RB,则f=0.33/RC. 2.1.2 正弦交流信号采样(一) 峰值保持本课题中采用模数转换芯片是的ADC0809,ADC0809采样速率较慢且采样范围在05V,所以我们必须对输入正弦交流信号进行峰值保持处理。峰值保持电路的作用是对输入信号峰值的提取,产生输出Vo = Vpeak,为了实现这样的目标,电路输出值会一直保持,知道一个新的更大的峰值出现
21、或电路复位。正弦交流信号由Ui输入,经过二极管对其整流,只剩下正半轴波形。由正半轴信号对电容进行充电,将峰值电压保持在一个较小的波动范围。但由于电容的放电,测到的峰值电压会比实际值低。如图 2-8。 图 2-8 峰值保持电路(二) 信号处理 本课题计算频率方法是由从机单片机对正弦信号计数,由于单片机只能根据波形下跳沿计数,所以采用信号处理模块将输入正弦信号转换成方波,便于单片机计数。我们采用基于LM339制作的电压比较电路,对正弦信号进行处理。 图 2-9 信号处理电路 如图2.9,将正弦信号与零电压进行比较,当电压低于零电平时,LM339将输出高电平;当正弦信号高于零电平时将输出低电平。通过
22、进行电压比较就将单片机不可测量的正弦信号,转换成可以测量的信号。2.2 数据采集2.2.1 ADC0809性能特点ADC0809是美国国家半导体公司生产的CMOS工艺8通道,8位逐次逼近式A/D模数转换器。其内部有一个8通道多路开关,它可以根据地址码锁存译码后的信号,只选通8路模拟输入信号中的一个进行A/D转换。是目前国内应用最广泛的8位通用A/D芯片。1 ADC0809主要特性1) 8路输入通道,8位A/D转换器,即分辨率为8位。2) 具有转换起停控制端。 3) 转换时间为100s(时钟为640kHz时),130s(时钟为500kHz时)4) 单个+5V电源供电 5) 模拟输入电压范围0+5
23、V,不需零点和满刻度校准。6) 工作温度范围为-40+85摄氏度 7) 低功耗,约15mW。 2. ADC0809的内部结构由下图可知,ADC0809由一个8路模拟开关、一个地址锁存与译码器、一个A/D转换器和一个三态输出锁存器组成。多路开关可选通8个模拟通道,允许8路模拟量分时输入,共用A/D转换器进行转换。三态输出锁器用于锁存A/D转换完的数字量,当OE端为高电平时,才可以从三态输出锁存器取走转换完的数据。图 2-10 ADC0809内部逻辑结构3. ADC0809引脚结构 图2-12 ADC080实物图 2-11引脚功能 ADC0809各脚功能如下:D7-D0:8位数字量输出引脚。IN0
24、-IN7:8位模拟量输入引脚。VCC:+5V工作电压。GND:地。REF(+):参考电压正端。REF(-):参考电压负端。START:A/D转换启动信号输入端。ALE:地址锁存允许信号输入端。(以上两种信号用于启动A/D转换)EOC:转换结束信号输出引脚,开始转换时为低电平,当转换结束时为高电平。OE:输出允许控制端,用以打开三态数据输出锁存器。CLK:时钟信号输入端(一般为500KHz)。A、B、C:地址输入线。 ADC0809对输入模拟量要求:信号单极性,电压范围是05V,若信号太小,必须进行放大;输入的模拟量在转换过程中应该保持不变,如若模拟量变化太快,则需在输入前增加采样保持电路。 地
25、址输入和控制线:4条 ALE为地址锁存允许输入线,高电平有效。当ALE线为高电平时,地址锁存与译码器将A,B,C三条地址线的地址信号进行锁存,经译码后被选中的通道的模拟量进入转换器进行转换。A,B和C为地址输入线,用于选通IN0IN7上的一路模拟量输入。通道选择表如下表2.1所示。表 2.1 通道选择表CBA通道000IN0001IN1010IN2011IN3100IN4101IN5110IN6111IN7数字量输出及控制线:11条 ST为转换启动信号。当ST上跳沿时,所有内部寄存器清零;下跳沿时,开始进行A/D转换;在转换期间,ST应保持低电平。EOC为转换结束信号。当EOC为高电平时,表明
26、转换结束;否则,表明正在进行A/D转换。OE为输出允许信号,用于控制三条输出锁存器向单片机输出转换得到的数据。OE1,输出转换得到的数据;OE0,输出数据线呈高阻状态。D7D0为数字量输出线。 CLK为时钟输入信号线。因ADC0809的内部没有时钟电路,所需时钟信号必须由外界提供,通常使用频率为500KHZ, VREF(),VREF()为参考电压输入。 2.2.2 ADC0809应用电路原理图 如图 2.13,所示,即课题采用的采样电路,ADC0809的数字量输出引脚与P0口相连,数字量由P0输入到单片机进行转换。采样通道控制由P0、P1、P2与ADDA、ADDB、ADDC连接确定。ADC08
27、09的时钟有单片机ALE信号经过74LS74分频得。ADC0809的启动由P1.7的下降沿确定,即当P1.7输出由高变低时则启动了ADC0809进行采样。ADC0809 ENABLE(OE)与单片机P1.6相连,当P1.6为高时,单片机才能收到ADC0809输出数字量。IN2-IN7路来自直流源的5V、4V、3V、2V、1V、0V直流电压。IN1对自制正弦信号采样,与峰值保持电路输出端相连。图 2-13 采样电路第三章 双机通信原理3.1 双机通信基本方法3.1.1 并行通信方式 双机通信是指双CPU之间的数据信息交换。双CPU之间有并行通信和串行通行两种方式。并行通信控制简单、传输速度快;由
28、于传输线较多,长距离传送时成本高且接收方的各位同时接收存在困难。 图 3-1 并行通行方式如图3-1并行通信通常是将数据字节的各位用多条数据线同时进行传送 。所以当距离太远成本过高,传输十分不便。3.1.2 串行通信方式串行通信是指 使用一条数据线,将数据一位一位地依次传输,每一位数据占据一个固定的时间长度。其只需要少数几条线就可以在系统间交换信息,特别使用于计算机与计算机、计算机与外设之间的远距离通信。使用串口通信时,发送和接收到的每一个字符实际上都是一次一位的传送的,每一位为1或者为0。串行通行又分为同步通信和异步通信两种方式。1 异步通信异步通信是指通信的发送与接收设备使用各自的时钟控制
29、数据的发送和接收过程。为使双方的收发协调,要求发送和接收设备的时钟尽可能一致。异步通信中,在异步通行中有两个比较重要的指标:字符帧格式和波特率。数据通常以字符或者字节为单位组成字符帧传送。字符帧由发送端逐帧发送,通过传输线被接收设备逐帧接收。发送端和接收端可以由各自的时钟来控制数据的发送和接收,这两个时钟源彼此独立,互不同步。接收端检测到传输线上发送过来的低电平逻辑0(即字符帧起始位)时,确定发送端已开始发送数据,每当接收端收到字符帧中的停止位时,就知道一帧字符已经发送完毕。串行异步通信时的数据格式:串行数据是以字符为单位进行传输的,字符之间没有固定的时间间隔要求,而每个字符中的各位则以固定的
30、时间传送。收、发双方取得同步的方法是采用在字符格式中设置起始位和停止位。在一个有效字符正式发送前,发送器先发送一个起始位,然后发送有效字符位,在字符结束时再发送一个停止位,起始位至停止位构成一帧。串行异步传输时的数据格式如图3-2所示。 图 3-2 串行异步传输数据格式 从图中可以看到以下几点: 1) 起始位:起始位必须是持续一个比特时间的逻辑“0”电平,标志传送一个字符的开始。2) 数据位:数据位为5-8位,它紧跟在起始位之后,是被传送字符的有效数据位。传送时先传送字符的低位,后传送字符的高位。数据位究竟是几位,可由硬件或软件来设定。 3) 奇偶位:奇偶校验位仅占一位,用于进行奇校验或偶校验
31、,也可以不设奇偶位。4) 停止位:停止位为1位、1.5位或2位,可有软件设定。它一定是逻辑“1”电平,标志着传送一个字符的结束。 5) 空闲位:空闲位表示线路处于空闲状态,此时线路上为逻辑“1”电平。空闲位可以没有,此时异步传送的效率为最高。 串行异步通信时的数据接收 :串行异步通信时,接收方不断地检测或监视串行输入线上的电平变化,当检测到有效起始位出现时,便知道接着是有效字符位的到来,并开始接收有效字符,当检测到停止位时,就知道传输的字符结束了。经过一段随机时间间隔之后,又进行下一个字符的传送过程。 通常接收端的采样时钟周期要比传输字符的位周期短,常用的采样时钟频率为位频率的16倍,采取这种
32、措施是为了提高抗干扰能力。输字符的位周期Td等于采样时钟周期Tc的16倍。接收器的采样时钟的每个上升沿对输入信号进行采样,检验接收数据线上的低电平是否保持8或9个连续的时钟周期,以确定传输线上的低电平是否是真的起始位。这样就可以避免噪声干扰引起的误操作,从而删除假的起始位。相当精确地确定起始位的中间点,从而提供一个时间基准,从这个基准开始,每隔16个Tc对其余数据位采样,以确保传输数据的正确性。 接收端为实现采样数据的基准,可以执行以下步骤: 1) 在接收端设置一采样时钟频率计数器,当检测到起始位下降沿时,将其清零,并开始对采样时钟计数,即每来一个时钟,计数器加1。2) 当计数器计到8时,表示
33、已到达起始位的中间位置,此时采样值为0,说明是真正的起始位,同时将计数器清零;若采样值不为0,则说明一开始检测到的下降沿不是真正的起始位前沿,而是一次干扰,此次检测应作废,计数器清零,并重新开始检测起始位。 3) 检测到真正的起始位后,计数器清零,以后每次计到16时,便采样收到的信号波形(即每一位的中间),将采到的数值暂存起来,同时将计数器清零,重新计数,直至最后的停止位被采样。4) 如果停止位采样正确(为1),则字符被接收,并由暂存器装入寄存器。若停止位采样值为0,说明同步或传输有问题,此次采样所得字符作废,不被接收。 异步通信的特点:1) 起止式异步通信协议传输数据对收发双方的时钟同步要求
34、不高,即使收、发双方的时钟频率存在一定偏差,只要不使接收器在一个字符的起始位之后的采样出现错位现象,则数据传输仍可正常进行。因此,异步通信的发送器和接收器可以不用共同的时钟,通信的双方可以各自使用自己的本地时钟。 2) 实际应用中,串行异步通信的数据格式,包括数据位的位数、校验位的设置以及停止位的位数都可以根据实际需要,通过可编程串行接口电路,用软件命令的方式进行设置。在不同传输系统中,这些通信格式的设定完全可以不同;但在同一个传输系统的发送方和接收方的设定必须一致,否则将会由于收、发双方约定的不一致而造成数据传输的错误与混乱。 3) 串行异步通信中,为发送一个字符需要一些附加的信息位,如起始
35、位、校验位和停止位等。这些附加信息位不是有效信息本身,它们被称为额外开销或通信开销,这种额外开销使通信效率降低。例如一个字符由7位组成,加上一位起始位、一位校验位和一位停止位 ,发送一个字符必须发送10位,而其中只有7位是有效的,其余3位不是有效的,使通信能力的30%成了额外开销。所以异步通信适用于传送数据量较少或传输要求不高的场合。对于快速、大量信息的传输,一般采用通信效率较高的同步通信方式。 4) 串行异步通信依靠对每个字符设置起始位和停止位的方法,使通信双方达到同步。2. 同步通信 同步通信是一种连续串行传送数据的通信方式,一次通信只传送一帧信息。这里的信息帧与异步通信中的字符帧不同,通
36、常含有若干个数据字符。它们均由同步字符、数据字符和校验字符(CRC)组成。其中同步字符位于帧开头,用于确认数据字符的开始。数据字符在同步字符之后,个数没有限制,由所需传输的数据块长度来决定;校验字符有1到2个,用于接收端对接收到的字符序列进行正确性的校验。同步通信的缺点是要求发送时钟和接收时钟保持严格的同步。由于同步通信要求严格时钟同步,所以一般不采用串行通信同步通信方式。3.2 串行通信接口标准目前广泛使用的串行接口标准为RS-232。RS232接口是1970年由美国电子工业协会(EIA)联合贝尔系统、调制解调器厂家及计算机终端生产厂家共同制定的用于串行通讯的标准。它的全名是“数据终端设备(
37、DTE)和数据通讯设备(DCE)之间串行二进制数据交换接口技术标准”。 该标准规定采用一个25个脚的DB25连接器,对连接器的每个引脚的信号内容加以规定,还对各种信号的电平加以规定。随着设备的不断改进,出现了代替DB25的DB9接口,现在都把RS232接口叫做DB9。如图3-3为DB9接口。 图 3-3 DB9接口DB9针脚定义:1 DCD 载波检测 2 RXD 接收数据 3 TXD 发送数据4 DTR 数据终端准备好 5 SG 信号地 6 DSR 数据准备好 7 RTS 请求发送 8 CTS 允许发送9 RI 振铃提示3.2.1 RS-232握手方式RS-232通行方式允许简单连接三线:Tx
38、、Rx和地线。但是对于数据传输,双方必须对数据定时采用使用相同的波特率。尽管这种方法对于大多数应用已经足够,但是对于接收方过载的情况这种使用受到限制。这时需要串口的握手功能。在这一部分,我们讨论三种最常用的RS-232握手形式:软件握手、硬件握手和Xmodem。 a,软件握手:我们讨论的第一种握手是软件握手。通常用在实际数据是控制字符的情况,类似于GPIB使用命令字符串的方式。必须的线仍然是三根:Tx,Rx和地线,因为控制字符在传输线上和普通字符没有区别,函数SetXModem允许用户使用或者禁止用户使用两个控制字符XON和XOFF。这些字符在通信中由接收方发送,使发送方暂停。 例如:假设发送
39、方以高波特率发送数据。在传输中,接收方发现由于CPU忙于其他工作,输入buffer已经满了。为了暂时停止传输,接收方发送XOFF,典型的值是十进制19,即十六进制13,直到输入buffer空了。一旦接收方准备好接收,它发送XON,典型的值是十进制17,即十六进制11,继续通信。输入buffer半满时,LabWindows发送XOFF。此外,如果XOFF传输被打断,LabWindows会在buffer达到75%和90%时发送XOFF。显然,发送方必须遵循此守则以保证传输继续。 b,硬件握手:第二种是使用硬件线握手。和Tx和Rx线一样,RTS/CTS和DTR/DSR一起工作,一个作为输出,另一个作
40、为输入。第一组线是RTS(Request to Send)和CTS(Clear toSend)。当接收方准备好接收数据,它置高RTS线表示它准备好了,如果发送方也就绪,它置高CTS,表示它即将发送数据。另一组线是DTR(DataTerminal Ready)和DSR(Data SetReady)。这些线主要用于Modem通信。使得串口和Modem通信他们的状态。例如:当Modem已经准备好接收来自PC的数据,它置高DTR线,表示和电话线的连接已经建立。读取DSR线置高,PC机开始发送数据。一个简单的规则是DTR/DSR用于表示系统通信就绪,而RTS/CTS用于单个数据包的传输。 在LabWin
41、dows,函数SetCTSMode使能或者禁止使用硬件握手。如果CTS模式使能,LabWindows使用如下规则:当PC发送数据,RS-232库必须检测CTS线高后才能发送数据。当PC接收数据,如果端口打开,且输入队列有空接收数据,库函数置高RTS和DTR。如果输入队列90%满,库函数置低RTS,但使DTR维持高电平。如果端口队列近乎空了,库函数置高RTS,但使DRT维持高电平。 如果端口关闭,库函数置低RTS和DTR。 c,XModem握手:最后讨论的握手叫做Xmodem文件传输协议。这个协议在Modem通信中非常通用。尽管它通常使用在Modem通信中,XModem协议能够直接在其他遵循这个
42、协议的设备通信中使用。在LabWindows中,实际的XModem应用对用户隐藏了。只要PC和其他设备使用XModem协议,在文件传输中就使用LabWindows的XModem函数。函数是XModemConfig,XModemSend和XModemReceive。 XModem使用介于如下参数的协议:start_of_data、end_of_data、neg_ack、wait_delay、start_delay、max_tries、packet_size。这些参数需要通信双方认定,标准的XModem有一个标准的定义:然而,可以通过XModemConfig函数修改,以满足具体需要。这些参数的使用
43、方法由接收方发送的字符neg_ack确定。这通知发送方其准备接收数据。它开始尝试发送,有一个超时参数start_delay;当超时的尝试超过max_ties次数,或者收到接收方发送的start_of_data,发送方停止尝试。如果从发送方收到start_of_data,接收方将读取后继信息数据包。包中含有包的数目、包数目的补码作为错误校验、packet_size字节大小的实际数据包,和进一步错误检查的求和校验值。在读取数据后,接收方会调用wait_delay,然后想发送方发送响应。如果发送方没有收到响应,它会重新发送数据包,直到收到响应或者超过重发次数的最大值max_tries。如果一直没有收
44、到响应,发送方通知用户传输数据失败。 由于数据必须以pack_size个字节按包发送,当最后一个数据包发送时,如果数据不够放满一个数据包,后面会填充ASCII码NULL(0)字节。这导致接收的数据比原数据多。在XModem情况下一定不要使用XON/XOFF,因为XModem发送方发出包的数目很可能增加到XON/OFF控制字符的值,从而导致通信故障。3.3 串口通信电路 图 3-4 MAX232串口通信电路如图3-4所示为RS-232串口通讯电路。当需要将电脑上的程序下到单片机内时,则只需要用串口线连接单片机与电脑,并把接口J1的1与2相连,J2的1与2相连就能进行程序下载。且画板时应注意尽量是
45、这些电容靠在MAX232的旁边保证通讯收到的干扰最小。第四章 人机交互接口人机交互接口模块式基于HD7279可编程数码管/键盘串行接口芯片构成的,具有4*4矩阵按键,8位共阴式数码管。使用者可以通过键盘控制显示,将采样数据通过8位数码管显示出来。4.1 HD72794.1.1HD7279的主要特性1 串行接口,无需外围元件可直接驱动LED。2 各位独立控制译码/不译码及消隐和闪烁属性。3 (循环)左移/(循环)右移指令。4 具有段寻址指令,方便控制独立LED。5 64键键盘控制器,内含去抖动电路。4.1.2 HD7279引脚说明VDD: 正电源 VSS: 地 CS: 片选 CLK: 时钟输入端 DATA: 串行数据输入/输出端 CLK0: 振荡输出端 KEY: 按键有效输出端 RES: 复位端 SG-SA: 段g段a驱动输出