《593638875单片机课程设计基于MCS51的8路模拟数据采集系统.doc》由会员分享,可在线阅读,更多相关《593638875单片机课程设计基于MCS51的8路模拟数据采集系统.doc(19页珍藏版)》请在三一办公上搜索。
1、 基于MCS51的8路模拟数据采集系统一、 项目要求1、该系统能够采集8路0 -5V的模拟信号,要采集哪路数据,受操作者控制;2、该系统可以保存采集到的数据,并且可以显示该路数据;3、该系统能够提供多种工作方式;即:连续工作方式和随机工作方式;二、项目分析1、要采集8路模拟信号,需要将模拟信号转化成数字信号,因此,设计需要A/D转换器,在此,我选用ADC0809;2、由于MCS51单片机芯片的数据存储器很小,要保存采集到的数据就需要进行数据存储器的扩展,在此,我选用6264芯片;3、该系统包含多部分的程序设计,如:键盘输入部分,数码显示部分,保存部分,采集部分等。因此,也需要对程序存储器进行扩
2、展,在此,我选用27128芯片;4、该系统要对8路数据的采集进行控制及多种工作方式的选择,因此需要设计键盘。设计键盘要占用I/O,因此就要对I/O口进行扩展,在此,我选用8255A芯片;5、该系统要显示所采集的数据,需要设计数码显示电路;三、原理框图(2位)电源RAM扩展I/O扩展80C32AD转换数码显示ROM扩展 四、主要芯片简介1、ADC0809概述1主要特性1)8路输入通道,8位A/D转换器,即分辨率为8位。 2)具有转换起停控制端。 2外部特性(引脚功能)ADC0809芯片有28条引脚,采用双列直插式封装,如图1323所示。下面说明各引脚功能。 IN0IN7:8路模拟量输入端。 2-
3、12-8:8位数字量输出端。 ADDA、ADDB、ADDC:3位地址输入线,用于选通8路模拟输入中的一路 ALE:地址锁存允许信号,输入,高电平有效。 START: A/D转换启动脉冲输入端,输入一个正脉冲(至少100ns宽)使其启动(脉冲上升沿使0809复位,下降沿启动A/D转换)。 EOC: A/D转换结束信号,输出,当A/D转换结束时,此端输出一个高电平(转换期间一直为低电平)。 OE:数据输出允许信号,输入,高电平有效。当A/D转换结束时,此端输入一个高电平,才能打开输出三态门,输出数字量。 CLK:时钟脉冲输入端。要求时钟频率不高于640KHZ。 REF(+)、REF(-):基准电压
4、。 Vcc:电源,单一+5V。 GND:地。2、6264概述1外部特性(引脚功能)6264的容量为8KB,是28引脚双列直插式芯片,采用CMOS工艺制造A12A0:地址线,可寻址8KB的存储空间。 D7D0:数据线,双向,三态。 OE:读出允许信号,输入,低电平有效。 WE:写允许信号,输入,低电平有效。 CS1:片选信号1,输入,在读/写方式时为低电平。 CS2:片选信号2,输入,在读/写方式时为高电平。 VCC:+5V工作电压。 GND:信号地。 2、 6264的操作方式Intel 6264的操作方式由, CS1 , CS2的共同作用决定 写入:当和为低电平,且和CS2为高电平时,数据输入
5、缓冲器打开,数据由数据线D7D0写入被选中存储单元。 读出:当和为低电平,且和CS2为高电平时,数据输出缓冲器选通,被选中单元的数据送到数据线D7D0上。 保持:当为高电平,CS2为任意时,芯片未被选中,处于保持状态,数据线处于高阻状态。3、27128概述1主要特性是一种程序存储器ROM,存储容量为16KBA13A0: 为14条地址信号输入线,说明芯片容量为2的14次方,即16KBD7D0: 数据线,表示芯片的每个存储单元存放一个字节(8位二进制数),对芯片读数时,作为输出线,对芯片编程时,作为输入线。CE:为输入信号,低电平有效。(有称作片选信号)OE:为输出允许信号,低电平有效PGM:为编
6、程脉冲输入端,当对芯片编程时,由此端加入编程脉冲信号;读取数据时PMG的值为1Vcc和Vpp都是接电源的,正常工作时是+5V4、8255A概述8255A,具有24条输入/输出引脚、可编程的通用并行输入/输出接口电路8255A在使用前要写入一个方式控制字,选择A、B、C三个端口各自的工作方式,共有三种; 方式0 :基本的输入输出方式,即无须联络就可以直接进行的 I/O方式。其中A、B、C口的高四位或低四位可分别设置成输入或输出。 方式1 :选通I/O,此时接口和外围设备需联络信号进行协调,只有A口和B口可以工作在方式1,此时C口的某些线被规定为A口或B口与外围设备的联络信号,余下的线只有基本的I
7、/O功能,即只工作在方式0. 方式2: 双向I/O方式,只有A口可以工作在这种方式,该I/O线即可输入又可输出,此时C口有5条线被规定为A口和外围设备的双向联络线,C口剩下的三条线可作为B口方式1的联络线,也可以和B口一起方式0的I/O线。 8255A是一个并行输入、输出器件,具有24个可编程设置的I/O口,包括3组8位的I/O为PA口、PB口、PC口,又可分为2组12位的I/O口:A组包括A口及C口高4位,B组包括B口及C组的低4位。6、74LS373概述74LS373为三态输出的八D透明锁存器,373 的输出端 O0O7 可直接与总线相连。 当三态允许控制端 OE 为低电平时,O0O7 为
8、正常逻辑状态,可用来驱动负载或总线。当 OE 为高电平时,O0O7 呈高阻态,即不驱动总线,也不为总线的负载,但锁存器内部的逻辑操作不受影响。 当锁存允许端 LE 为高电平时,O 随数据 D 而变。当 LE 为低电平时,O 被锁存在已建立的数据电平。当 LE 端施密特触发器的输入滞后作用,使交流和直流噪声抗扰度被改善 400mV。 引出端符号: D0D7: 数据输入端 OE: 三态允许控制端(低电平有效) LE: 锁存允许端 O0O7: 输出端五、硬件设计方案1、ROM扩展2、RAM扩展3、I/O扩展4、数据采集5、键盘电路6、数码显示7、系统总电路六、地址分析1、片外ROMA15 A14 A
9、13 A12 A11 A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 A0 起始地址: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0最大地址: 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1片外ROM的地址范围:0000H3FFFH2、片外RAMA15 A14 A13 A12 A11 A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 A0 起始地址: 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0最大地址: 0 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1片外RAM的地址范围:4000H5FFFH3、扩展
10、I/OA15 A14 A13 A12 A11 A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 A0 起始地址: 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 最大地址: 1 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1A口:8000H B口:8001H C口:8002H 状态寄存器:8003H七、软件设计1、 键盘扫描程序ORG 0100HKEYPRO: ACALL KEXAM JZ KEYPRO ACALL D10ms ACALL KEXAM JZ KEYPRO KEY1: MOV R2,#0FEH MOV R3,#00H MOV R4,#00H
11、KEY2: MOV DPTR , #8000H MOV A, R2 MOVX DPTR ,A MOV DPTR, #8001H MOVX A, DPTR CPL A ANL A, #0FFH JNZ KEY3 MOV A, R4 ADD A, 04H MOV R4,A MOV A,R2 MOV R2,AJB ACC.4, KEY2AJMP KEYPROKEY3: CPL AKEY4: INC R3 RRC AJC KEY4KEY5: ACALL D10ms ACALL KEXAM JNZ KEY5 MOV A, R4 ADD A, R3 MOV BUFF, A AJMP KEYADRD10ms
12、: MOV R5, #14HDL: MOV R6, #10FFHDL0: DJNZ R6, DL0 DJNZ R5, DL RETBUFF EQU 30HKEXAM: MOV DPTR, 8000H MOV A, #00H MOV DPTR, A MOV DPTR, # 8001H MOV A, DPTR CPL A ANL A, #0FFH RET ORG 0500HKEYADR: MOV A, BUFF CJNE A, #07H, KYADR1 AJMP DIGPROKYADR1: JC DIGPROKEYTBL: MOV DPTR,#JMPTBL CLR C SUBB A,#08H RL
13、 A JMP A+DPTRBUFF EQU 30HJMPTBL: AJMP SUI AJMP LIAN AJMP BG-IN AJMP E-ND SJMP STARTDIGPRO: MOV A, BUFF INC A MOV P0, A SJMP START SUI: SETB CMOV P1.0, C JB P1.2, SUISUI0: JB P1.2,E-ND SJMP A000LIAN: SETB CMOV P1.0, CJB P1.2, NEXTACALL STARTSJMP LIANNEXT: CLR C MOV P1.0, C ACALL START MOV R7, #0FFHLO
14、OP1: NOP NOP DJNZ R7, LOOP1 JB P1.1, E-ND SJMP LIANBG-IN: SETB C, MOV P1.1,CE-ND: CLR C MOV P1.1, CSJMP $2、 数据采集程序ORG 1000HSTART: MOV R0, #00H MOV P2,#40H MOV R3,#00H MOV R4,#00H MOV R6,#08HAGAIN0: MOV DPTR, #2000HAGAIN: MOVX DPTR, ALOOP2: JB P1.2, LOOP2LOOP3: JNB P1.2, LOOP3 MOVX A, DPTR MOVX R0,A
15、PUSH DPH PUSH DHL MOV DPH, P2 MOV DPL,R0 ACALL DISPLY POP DPL POP DPH INC DPTR INC P2 DJNZ R6,AGAIN DJNZ R3,DONE RETDONE: INC R4 MOV P2, #0A0H MOV A,R4 MOV R0, A MOV R6,#08H AJMP AGAIN0 RET3、 数码显示程序ORG 1500HDISPLY: MOVX A, DPTR ANL A, #0FH SWAP A MOV B, A INC DPTR MOV A, DPTR ANL A, #0FH ADD A, B MO
16、VX 8002H, A RET八、设计总结虽然我做的系统是很小个,但圆满的完成整个系统也花了不少时间,最主要是是前期的准备阶段,刚接到课程设计题目时,我并没有马上就动手做设计,一开始我就复习新编单片机原理教材的单片机MCS51的RAM、ROM及I/O的扩展,接着就看刚发的微型计算机控制技术,学习里面的键盘设计,数码显示设计,及采集的部分设计,了解了该系统的设计原理和思想,在大脑中有了初步的设计构思,我想把系统设计好,于是就通过查资料、写程序学习了很多知识。在设计系统硬件连接图的时候,也让我学会了Proteus软件的使用。通过这次设计让我体会到学习其实也是一种享受的过程,当投入到知识海洋的时候,
17、有一种思维的逻辑递归的过程,我总是用联想的办法把刚要接触的知识,用已学过知识框架去学习,把刚学的知识跟学过的知识搭成一座桥梁,形成一个框架,而且我喜欢各科的知识点联系起来。通过这次设计我也领悟到了书本知识和具体操作实践是完全不同的,书本知识知识基础,合理应用才是目的。现在很多人都在倡导实践,而我觉得理论知识还是占主导地位,只是老师教给我们的东西我们不懂得学以致用而已,如果能把每个老师教的知识串通起来,加上你愿意花功夫学,相信没有什么可以难倒你的,通过做了这个系统之后我让我感触最深的是一定要细心。 参考文献1 潘新民,王燕芳.微型计算机控制技术实用教程.北京:电子工业出版社,2010.63-74.2 潘永雄.新编单片机原理及应用.西安电子科技大学出版社,2009.72-175.1设计方案的可行性本课题是设计一个8路模拟数据采集系统,能够实现保存数据,显示当前采集的模拟量及让其有多种工作方式等各项功能。本设计采用A/D转换器ADC0809,80C32,RAM扩展芯片6264 ,ROM扩展芯片27128,I/O扩展芯片8255A,及键盘和数码显示电路,能够完成系统所要求的功能。因此,只要设计合理,该系统是可以实现的。