ImageVerifierCode 换一换
格式:DOCX , 页数:26 ,大小:143.90KB ,
资源ID:11620445      下载积分:1 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-11620445.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(多路数据采集系统设计报告.docx)为本站会员(b****3)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

多路数据采集系统设计报告.docx

1、多路数据采集系统设计报告多路数据采集系统设计报告第1章 绪论设计目的及要求1.1 绪 论随着计算机技术的飞速发展和普及,数据采集系统也迅速地得到应用。在生产过程中,应用这一系统可对生产现场的工艺参数进行采集,监视和记录,为提高产品质量,降低成本提供信息和手段。在科学研究中,应用数据采集系统可获得大量的动态信息,是研究瞬间物理过程的有力工具,也是获取科学奥秘的重要手段之一。总之,不论在哪个应用领域中,数据采集与处理越及时,工作效率就越高,取得的经济效益也越高。本设计采用ATMEGA16单片机作为数据采集系统的控制核心,系统分为数据采集模块、A/D转换模块、系统控制模块、键盘模块、显示模块等几部分

2、。1.2 设计目的利用单片机为核心设计一个多路数据采集系统,要求每个通道的信号经A/D转换后以10进制数在LED 显示器上显示,并能够通过键盘操作切换显示不同通道的采样值。1.3 设计要求 本课题要求利用单片机为核心设计一个八路数据采集系统,要求每个通道的信号经A/D转换后以10进制数在LED 显示器上显示,并能够通过键盘操作切换显示不同通道的采样值。本系统中包括8路模拟量输入,范围0-5V。要求对8个通道的模拟量进行巡回采样,再将采集的数据进行工程量化转换后在LED显示器上显示,并能通过按键切换所选通道的采样数据。 第2章 系统总体方案选择与说明2.1硬件设计框图典型数据采集系统配置如图2.

3、1所示,有的已实现集成化,多个传感器的预处理电路输出接入多路模拟开关,然后经过取样/保持电路和A/D转换后进入CPU系统。 图2.2 典型数据采集系统配置图(1)传感器是经典的利用各种原理将被测物理量转化为电信号。(2)预处理模块是将模拟信号进行调整、放大,在模拟电路方便实现的基础上对信号进行自动补偿、自动校正,抑制温漂的模块。(3)数据采集A/D模块将模拟信号进行采样、量化,转化为数字信号.(4)计算机可能为PC机、单片机或其他专用处理器,(5)(6)第3章 数据采集系统概述、工作原理及其说明3.1数据采集系统概述数据采集是信息科学的一个主要组词成部分,信息技术的核心是信息获取,通信和计算机

4、技术,常被称为3C技术,其中信息获取是基础和前提。数据采集是获取信息的主要手段,它随着科学技术的进步而得到迅速发展。目前各种各样的数据采集系统已得到广泛应用,新型数据采集系统仍不断涌现。随着科学技术的发展与普及,数字设备正越来越多地取代模拟设备,在生产过程控制和科学研究等广泛领域中,计算机控制技术正发挥着越来越主要的作用,然而外部世界的大部分信息是以连续变化的物理量形式出现的,例如温度、压力、位移、速度等。要将这些信息送入计算机进行处理,就必须先将这些连续的物理量离散化,并进行量化编码,从而变成数字量,这个过程就是数据采集。数据采集系统是计算机与外部世界联系的桥梁。数据采集技术是信息科学的主要

5、组成部分,它是以传感器技术、信号检测与处理、电子学、计算机技术等方面技术为基础而形成的一个综合应用技术学科,已广泛应用于国民经济和国防建设的各个领域,并且随着科学技术的发展,尤其是计算机技术的发展与普及,数据采集技术有广阔的发展前景。 3.2工作原理及其说明 1 、采用80C52单片机和ADC0809构成一个八路数据采集系统。 2 、能够顺利采集各个通道的信号。 3 、采集信号的动态范围:05V。 4 、每个通道采样速率:100 sps。 5 、在面包板上完成电路,将采集的数据送入单片机70H77H存储单元。 6 、编写相应的单片机采集程序到达规定的性能: 8路输入模拟信号数值显示电路由A/D

6、转换、数据处理及显示控制等组成。A/D转换由集成电路0809完成。0809具有8路模拟输入端口,地址线(2325脚)可决定对哪一路模拟输入作A/D转换。第22脚为地址锁存控制,当输入为高电平时,对地址信号进行锁存;6脚为测试控制,当输入一个2微秒宽脉冲时,就开始A/D转换;7脚为A/D转换结束标志,当A/D转换数据结束时,7脚输出高电平;9脚为A/D转换数据输出允许控制,当OE脚为高电平时,A/D转换数据从端口输出;10脚为0809的时钟输入端,利用单片机30脚的六分频晶振信号再通过74hc193二分频得到。单片机的P1、P3端口作4位LED数码管显示控制,P0端口作A/D转换数据读入用,P2

7、端口用作A/D转换控制。第4章 各单元硬件设计及说明4.1单片机的时钟源4.1.1单片机时钟源电容C1、C2和晶振(6MHz)组成8031的外部时钟源电路(如图4.1.1),将C1、C2和晶振组成的回路称为LC并联谐振回路,晶振起电感的作用,谐振频率由晶振的频率所决定,8031单片机的晶振可以选12MHz12MHz。电容C1、C2的取值一般在20Pf100pF之间(在60pF70pF时,频率比较稳定)。图4.1.1单片机时钟源采用80C52单片机作为数据处理及显示芯片,80C52的芯片管脚图如下:图3.1 80C52单片机引脚图各管脚说明: VCC(40): 供电电源 GND(20):接地 P

8、0(3239)口:P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。当P1口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在FIASH编程时,P0 口作为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。 P1(18)口:P1口是一个内部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。P1口管脚写入1后,被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在FLASH编程和校验时,P1口作为第八位地址接收。 P2(2128)口:P2口为一

9、个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器的内容。P2口在FLASH编程和校验时接收高八位地址信号和控制信号。 P3(1017)口:P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内

10、部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3口将输出电流(ILL)这是由于上拉的缘故。P3口作为AT89C51的一些特殊功能口,管脚 备选功能 表4.1 80C52单片机P3口引脚功能端口引脚第二功能P3.0RXD (串行输入口)P3.1TXD(串行输出口)P3.2 (外部中断0)P3.3(外部中断1)P3.4T0(定时器0)P3.5T1(定时器1)P3.6(外部数据存储器写选通)P3.7(外部数据存储器都选通)RST(9):复位输入。当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。 PSEN(29):外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机

11、器周期两/PSEN有效。但在访问外部数据存储器时,这两次有效的/PSEN信号将不出现。EA / VPP(31):当/EA保持低电平时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。注意加密方式1时,/EA将内部锁定为RESET;当/EA端保持高电平时,此间内部程序存储器。在FLASH编程期间,此引脚也用于施加12V编程电源(VPP)。 XTAL1(18):反向振荡放大器的输入及内部时钟工作电路的输入。 XTAL2(19):来自反向振荡器的输出。电容C1、C2和晶振(6MHz)组成8031的外部时钟源电路,将C1、C2和晶振组成的回路称为LC并联谐振回路,晶振起电

12、感的作用,谐振频率由晶振的频率所决定,8031单片机的晶振可以选12MHz12MHz。电容C1、C2的取值一般在20Pf100pF之间(在60pF70pF时,频率比较稳定)。4.2 ADC0809(模数转换芯片)本系统采用ADC0809来转换模拟信号,其管脚图如下:ADC0908引脚功能说明: 图4.2 ADC0809引脚图ADC0809引脚功能说明 IN0IN7(15,2628):8路模拟量输入端。 2-12-8(8.14.15.17.18.19.20.21):8位数字量输出端。 ADDA、ADDB、ADDC(2325):3位地址输入线,用于选通8路模拟输入中的一路 ALE(22):地址锁存

13、允许信号,输入,高电平有效。 START(6): AD转换启动脉冲输入端,输入一个正脉冲(至少100ns宽)使其启动(脉冲上升沿使0809复位,下降沿启动A/D转换)。 EOC(7): AD转换结束信号,输出,当AD转换结束时,此端输出一个高电平(转换期间一直为低电平)。 OE(9):数据输出允许信号,输入,高电平有效。当AD转换结束时,此端输入一个高电平,才能打开输出三态门,输出数字量。 CLK(10):时钟脉冲输入端。要求时钟频率不高于640KHZ。 REF(+)、REF(-)(12.16):基准电压。 Vcc(11):电源,单一5V。 GND(13):地。4.3 程序存储器和数据存储器电

14、路设计 EPROM2716是8031单片机的程序存储器,用于存放指令,常数及表格。其地址范围为0000H07FFH。片选端接地,表示2716总是处于选通状态。开机后,由8031的PSEN控制端(低电平有效),自动执行从0000H开始的程序。如果从EPROM中取常数或查表,则需要执行MOVCA,A+DPTR指令。RAM6116是8031单片机的数据存储器,用于存放采集的数据及数据的计算与处理结果等。它的地址范围也是0000H07FFH,但不会与EPROM2716的地址发生冲突。因为它的片选端是通过8031的地址线控制的。当地址线P26 =0 时,RAM6116才选通。8031执行MOVXDPTR

15、,A指令可以产生信号,将累加器A的内容送片外数据存储器。执行MOVX A,DPTR指令可以产生信号,将片外数据存储器由DPTR指定的地址单元中的内容送至累加器A。DPTR表示16位的地址计数器的内容,它可以通过执行MOVDPTA,#addrl6指令被赋值。第5章 软件设计与说明 5.1设计条件本系统8路模拟量输入,范围0-5V。要求对8个通道的模拟量进行巡回采样,再将采集的数据进行工程量转换后在LED显示器上显示,并能通过按键切换所选通道的采样数据。5.2编程思想和流程图编程思想:根据硬件电路图,我们应用汇编语言进行编程。首先在P2.4和P2.3引脚提供正脉冲,启动A/D转换,因转换需要一定的

16、时间,所以需延时等待;然后读取数据,利用软件编程,将二进制数转换为十进制数,送到数码管显示;从左到右轮流点亮显示器各位,对于显示器的每一位来说,每隔一段时间点亮一次,利用人的视觉暂留功能可以看到整个显示,但必须保证扫描速度足够快,字符才不闪烁,利用单片机的P1口提供显示段码,P3口的低四位提供位码,数码管的第一位显示通道数,后三位显示0255的采集数据。流程图如下所示:5.1 主程序流程图5.2.1主程序流程图5.2.2 模数转换流程图5.3 模块程序设计1、初始化程序 系统上电时,将70H77H内存单元清0,P2口置1.CLEARMEMIO: CLR A MOV P2,A ;P2口置0 MO

17、V R0,#70H ;内存循环清零(70H7BH) MOV R2,#0CH LOOPMEM: MOV R0,A INC R0 DJNZ R2,LOOPMEM MOV A,#OFFH MOV P0,A ;P0,P1,P3端口置1 MOV P1,A MOV P3,A RET ;子程序返回2、主程序 在刚上电时,因70H77H内存单元的数据为0,则每一通道的数码管显示值都是000.当进行一次测量后,将显示出每一通道的AD转换值。每个通道的数据显示时间在1S左右。主程序在调用显示程序和测试程序之间循环,其流程图如5.1.1。汇编程序:START: LCALL CLEARMEMIO ;初始化MAIN:

18、LCALL DISPLAY ;显示数据一次 LCALL TEST ;测量一次 AJMP MAIN ;返回MAIN循环 NOP ;PC值出错处理 NOP ;空操作 NOP ;空操作 LJMP START ;重新复位启动DISPLAY: MOV R3,#08H ;8路信号循环显示控制 MOV R0,#70H ;显示数据初值(70H77H) MOV 7BH,#00H ;显示通道路数(07)DISLOOP1:MOV A,R0 ;显示数据转为3位十进制BCD MOV B,#100 ;7AH、79H、78H显示单元内 DIV AB ;显示数据除100 MOV 7AH,A ;商入7AH MOV A,#10

19、;A放入数10 XCH A,B ;余数与数10交换 DIV AB ;余数除10 MOV 79H,A ;商入79H MOV 78H,B ;余数入78H MOV R2,#0FFH ;每路显示时间控制4ms*255DISLOOP2:LCALL DISP ;调4位LED显示程序 DJNZ R2,DISPLOOP2 ;每路显示是时间控制 INC R0 ;显示下一路 INC 7BH ;通道显示数值加1 DJNZ R3,DISLOOP1 ;8路显示未完转DISLOOP1再循环 RET ;8路显示完子程序结束LED共阳显示子程序,显示内容78H7BH,数据在P1输出,列扫描在P3.0P3.3口DISP: MO

20、V R1,#78H ;赋显示数据单元首地址 MOV R5,#0FEH ;扫描字PLAY: MOV P1,#0FFH ;关显示 MOV A,R5 ;取扫描字 ANL P3,A ;开显示 MOV A,R1 ;取显示数据 MOV DPTR,#TAB ;取段码表首地址 MOVC A,A+DPTR ;查显示数据对应段码 MOV P1,A ;段码放入P1口 LCALL DL1MS ;显示1ms INC R1 ;指向下一地址 MOV A,P3 ;取P3口扫描字 JNB ACC.3,ENDOUT ;4位显示完转ENDOUT RL A ;扫描字循环左移 MOV R5,A ;扫描字放入R5暂存 MOV P3,#0

21、FFH ;显示暂停 ALMP PLAY ;转PLAY循环 ENDOUT: MOV P3,#0FFH ;显示数据,端口置1 MOV P1,#0FFH RET ;子程序返回LED数码显示管用共阳段码表,分别对应09,最后一个是“熄灭符”TAB: DB 0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90H,0FFH,1ms延时子程序,LED显示用DL1MS: MOV R6,#14HDL1: MOV R7,#19HDL2: DJNZ R7,DL2 DJNZ R6,DL1 RET3、显示子程序采用动态扫描法实现4位数码管的数值显示。测量所得的AD转换数据放70H77H

22、内存单元中。测量数据在显示时需经过转换成十进制BCD码放在78H7BH中,其中7BH存放通道表指数。寄存器R3用作8路循环控制,R0用作显示数据地址指针。4、模数转换测量子程序 模数转换测量子程序是用来控制对0809 八路模拟输入电压的AD转换,并对应的数值移入70H77H内存单元,其流程图如5.1.2。TEST: CLR A ;清累加器A MOV P2,A ;清P2口 MOV R0,#70H ;转换值存放首地址 MOV R7,#08H ;转换8次控制 LCALL TESRART ;启动测试WAIT: JB P3.7,MOVD ;等A/D转换结束信号后转MOVD: AJMP WAIT ;P3.

23、7为0,等待TESTART: SETB P2.3 ;锁存测试通道地址 NOP ;延时2微秒 NOP CLR P2.3 ;测试通道地址锁存完毕 SETB P2.4 ;启动测试,发开始脉冲 NOP ;延时2微秒 NOP CLR P2.4 ;发启动脉冲完毕 NOP ;延时4微秒 NOP NOP NOP ;子程序调用结束 RET取A/D转换数据至70H77H内存单元MOVD: SETB P2.5 ;0809输出允许 MOV A,P0 ;将A/D转换值入A MOV R0,A ;放入内存单元 CLR P2.5 ;关闭0809输出 INC R0 ;内存地址加1 MOV A,P2 ;通道地址移入A INC A

24、 ;通道地址加1 MOV P2,A ;通道地址送0809 CLR C ;清进位标志 CJNE A,#08H,TESTCON ;通道地址不等于8转TESTCON在测试 JC TESTCON ;通道地址小于8转TESTCON在测试 CLR A ;大于或等于8,A/D转换结束,恢复端口 MOV P2,A ;P2口置0 MOV A, #0FFH MOV P0,A ;P0口置1 MOV P1,A ;P1口置1 MOV P3,A ;P3口置1 RET ;取A/D转换数据结束TESTCON: LCALL TESTART ;再发测试启动脉冲 LJMP WAIT ;跳至WAIT,等待A/D转换结束信号 END

25、;程序结束第6章 调试步骤及使用说明由于程序比较多,整体调试不容易发现和改正错误,故采取子程序调试的方法,但要明确子程序的具体功能。例如:调试显示子程序时,只将显示子程序进行汇编,确认无误后单步执行,观察CPU窗口和DATA窗口以及CODE窗口相应单元的变化是否跟预期的一样。如果有问题找出问题所在。采取各个击破的方法调试好各个子程序。 确定各子程序无误后,再调试完整的程序,要注意各子程序之间的衔接以及和主程序之间的调用和返回。运行后,观察有无键盘显示功能。若运行结果不正确,首先应根据程序运行的实际现象分析判断哪些因素可引起相关故障,再通过调试方法逐一认证和排除。通过反复调试,发现并排除软件与硬

26、件存在的各类问题,以满足系统设计的预期目的。 第7章 设计总结课程设计是培养学生综合运用所学知识,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程.随着科学技术发展的日新日异,单片机已经成为当今计算机应用中空前活跃的领域, 在生活中可以说得是无处不在。因此作为二十一世纪的大学来说掌握单片机的开发技术是十分重要的。回顾起此次单片机课程设计,我仍感慨颇多,的确,从选题到定稿,从理论到实践,在接近两星期的日子里,可以说得是苦多于甜,但是可以学到很多很多的的东西,同时不仅可以巩固了以前所学过的知识,而且学到了很多在书本上所没有学到过的知识。通过这次课程设

27、计使我懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正为社会服务,从而提高自己的实际动手能力和独立思考的能力。在设计的过程中遇到问题,可以说得是困难重重,这毕竟第一次做的,难免会遇到过各种各样的问题,同时在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固,比如说不懂一些元器件的使用方法,对单片机汇编语言掌握得不好通过这次课程设计之后,一定把以前所学过的知识重新温故。这次课程设计终于顺利完成了,在设计中遇到了很多编程问题,最后在同学们的探讨下在蔡老师的辛勤指导下,终于游逆而解。同时,在蔡

28、老师那里我学得到很多实用的知识,在次我表示感谢!同时,对给过我帮助的所有同学和各位指导老师再次表示忠心的感谢!参考文献1. 单片机应用系统设计 何立民 编 北航出版社2. 单片机原理及应用 王迎旭 主编 机械工程出版社3. 51系列单片机设计实例 楼然苗 等编 北航出版社4. 51单片机应用系统开发典型实例戴家 等编 中国电力出版社5. 单片微型计算机原理及接口技术陈光东 等编 华中科技大学出版社6. 单片机实用系统设计技术房小翠 编 国防工业出版社附 录 A、系统电路原理图:系统电路原理图B、程序7077H存放采样值,78H7BH存放显示数据,一次个位,十位百位,通道标志。 主程序和中断程序

29、入口ORG 0000H ;程序执行开始地址LJMP START ;跳至START执行ORG 0003H ;外中断0中断入口地址RETI ;中断返回(不开中断)ORG 000BH ;定时器T0中断入口地址RETI ;中断返回(不开中断)ORG 0013H ;外中断1中断入口地址RETI ;中断返回(不开中断)ORG 001BH ;定时器T1中断入口地址RETI ;中断返回(不开中断)ORG 0023H ;串行口中断入口地址RETI ;中断返回(不开中断)ORG 002BH ;定时器T2中断入口地址RETI ;中断返回(不开中断)初始化程序中的各变量CLEARMEMIO: CLR A MOV P2

30、,A ;P2口置0 MOV R0,#70H ;内存循环清零(70H7BH) MOV R2,#0CH LOOPMEM: MOV R0,A INC R0 DJNZ R2,LOOPMEM MOV A, #OFFH MOV P0, A ;P0,P1,P3端口置1 MOV P1, A MOV P3, A RET ;子程序返回主程序START: LCALL CLEARMEMIO ;初始化MAIN: LCALL DISPLAY ;显示数据一次 LCALL TEST ;测量一次 AJMP MAIN ;返回MAIN循环 NOP ;PC值出错处理 NOP ;空操作 NOP ;空操作 LJMP START ;重新复位启动DISPLAY: MOV R3,#08H ;8路信号循环显示控制 MOV R0,#70H ;显示数据初值(70H77H) MOV 7BH,#00H ;显示通道路数(07)D

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2