毕业设计基于PIC16F877A单片机的八路温度巡回检测系统设计.doc

上传人:laozhun 文档编号:3975240 上传时间:2023-03-30 格式:DOC 页数:47 大小:2.70MB
返回 下载 相关 举报
毕业设计基于PIC16F877A单片机的八路温度巡回检测系统设计.doc_第1页
第1页 / 共47页
毕业设计基于PIC16F877A单片机的八路温度巡回检测系统设计.doc_第2页
第2页 / 共47页
毕业设计基于PIC16F877A单片机的八路温度巡回检测系统设计.doc_第3页
第3页 / 共47页
毕业设计基于PIC16F877A单片机的八路温度巡回检测系统设计.doc_第4页
第4页 / 共47页
毕业设计基于PIC16F877A单片机的八路温度巡回检测系统设计.doc_第5页
第5页 / 共47页
点击查看更多>>
资源描述

《毕业设计基于PIC16F877A单片机的八路温度巡回检测系统设计.doc》由会员分享,可在线阅读,更多相关《毕业设计基于PIC16F877A单片机的八路温度巡回检测系统设计.doc(47页珍藏版)》请在三一办公上搜索。

1、 课 程 设 计八路温度巡回检测系统设计 院 (系): XXXXXX学院 专 业: XXXXXX 学 号: XXXXXXX 学生姓名: XXX 指导老师: XXX 摘 要本文介绍了一种基于PIC16F877A单片机,利用DS18B20对多路温度采集,并进行温度的控制与检测,并通过12864液晶显示出来。系统中通过控制按钮实现了实时各路的报警温度,并且实现多路与任一单路温度显示切换,从而既可以进行多路的检测又可以进行任一单路的监控,而且还有数字跟图形两种显示方式更为直观。在温度超过设定温度时温度跟时间通过24C02存储起来,以便查看,同时可以通过固定电话远程报警,还能将温度上传至PC机,进行后续

2、处理。关键词:温度检测;单片机;串行通讯;DS18B20;目 录1系统设计72主芯片:PIC16F877A单片机简介92.1 PIC单片机的优越之处:92.2 PIC16F877A引脚图及主要性能102.3 最小系统112.3.1复位功能112.3.2 系统时钟122.4 设计心得总结123LCD12864液晶原理介绍及接口实现123.1 液晶显示模块概述123.2 液晶引脚说明133.3 接口时序143.4 具体指令介绍153.5 显示坐标关系193.5.1、图形显示坐标193.5.2 汉字显示坐标203.6 与单片机的接口实现213.7设计心得总结224DS18B20原理介绍及接口实现22

3、4.1 DS18B20简介224.2DS18B20结构及其工作原理234.3DS18B20的接口实现294.3.1 硬件设计294.3.2 软件设计304.4设计心得总结314.4.1 焊接问题:314.4.2 软件设计:314.4.3 不足:315存储芯片AT24C02简单介绍及接口实现325.1AT24C02功能描述管脚定义325.2管脚定义及接口实现325.3设计心得346 实时时钟DS1302简单介绍及接口实现346.1 DS1302简介346.2 DS1302结构及工作原理346.3DS1302的接口实现357温度上限报警功能377.1 设计原理377.2 设计心得体会378与PC串

4、口通讯及VB上位机简单介绍388.1 与PC串口通信388.2 上位机介绍399 总结43附录44 部分原理图:44 参考文献:45基于PIC单片机的多路温度监控巡回系统1 系统设计在工业生产和日常生活中,经常要对温度进行测量与控制,并且有时是对多个点进行温度测量,比如冷库温度监控、环境温度监测、农业温室监控、粮库温度监控等。在这种情况下,多点温度检测系统应运而生。多点温度检测系统通常能够对多个工作点的温度进行检测,显示当前温度,并能够对温度进行存储和报警,还能将温度上传至PC机,进行后续处理。传统的测温元件有热电偶和热电阻,需很多硬件支持并且电路复杂。本文将设计一款由新型的数字温度传感器DS

5、18B20配合单片机,具有温度检测、显示、存储、自动统计分析及跟电脑通讯连接还利用固定电话远程报警等功能的多点温度监控系统。多路温度监控系统30 PC机通讯4 * 温度传感器固话报警 图 1.1 多路温度监控系统模拟应用温度监控主系统构架框图如图 1.2 所示:PIC16F877A单片机12864液晶显示实时时钟上限报警接口按键控制PC机通讯AT24C02温度储存四路温度采集 图 1.2 多路温度监控系统构架框图图1.3 手工焊接实物图主要技术参数A温度检测范围 : -55+125B测量精度 : 0.0625C 显示方式: LCD12864显示D 报警方式: 固话报警2 主芯片:PIC16F8

6、77A单片机简介2.1 PIC单片机的优越之处:(1)哈佛总线结构:MCS-51单片机的总线结构是冯-诺依曼型,计算机 在同一个存储空间取指令和数据,两者不能同时进行;而PIC单片机的总线结构是哈佛结构,指令和数据空间是完全分开的,一个用于指令,一个用于数据,由于 可以对程序和数据同时进行访问,所以提高了数据吞吐率。正因为在 PIC单片机中采用了哈佛双总线结构,所以与常见的微控制器不同的一点是:程序和数据总线可以采用不同的宽度。数据总线都是8位的,但指令总线位数分别位 12、14、16位。 (2)流水线结构:MCS-51单片机的取指和执行采用单指令流水线结构,即取一条指令,执行完后再取下一条指

7、令;而PIC的取指和执行采用双指令流水线结构,当一条指令被执行时,允许下一条指令同时被取出,这样就实现了单周期指令。 (3)寄存器组:PIC单片机的所有寄存器,包括I/O口,定时器和程序计数器等都采用RAM结构形式,而且都只需要一个指令周期就可以完成访问和操作;而MCS-51单片机需要两个或两个以上的周期才能改变寄存器的内容。 (4)运行速度高:由于采用了哈佛总线结构,以及指令的读取和执行才用了流水作业方式,使得运行速度大大提高。 (5)功耗低:PIC单片机的功率消耗极低,是目前世界上最低的单片机品种之一。在4MHz时钟下工作时耗电不超过2mA,在睡眠模式下耗电可以低到1uA以下。 (6)驱动

8、能力强:I/O端口驱动负载的能力较强,每个I/O引脚吸入和输出电流的最大值可分别达到25mA和20mA,能够直接驱动发光二极管LED、光电耦合器或者轻微继电器等。 (7)外接电路简洁PIC单片机片内集成了上电复位电路、I/O引脚上拉电路、看门狗定时器等,可以最大程度减少或免用外接器件,以便实现“纯单片机”应用。这样,不仅方便于开发,而且还可节省用户的电路空间和制作成本。 (8)程序保密性强目前,尚无办法对其直接进行解密拷贝,可以最大限度的保护用户的程序版权。2.2 PIC16F877A引脚图及主要性能PIC16F877A的详细引脚如图2.21所示。 图 2.2-1 PIC16F877A引脚图

9、图 2.2 -2 PIC16F877A实物图主要性能参数如下所示:l 具有高性能RISC CPUl 仅有35条单字指令l 100000次擦写周期l 除程序分支指令为两个周期外,其余均为单周期指令l 运行速度: DC20MHZ始终输入 DC200ns 指令周期l 8K * 14个 FLASH程序存储器368 * 8 个数据存储器(RAM)字节256 * 8 EEPRM 数据存储器字节l 提供14个中断源l 功耗低在5V, 4MHZ 时钟运行时电流小于 2mA在3V, 32KHZ 时钟运行时电流小于20Ual 支持在线串行编程(ICSP)l 运行电压范围广,2.0V到5.5Vl 输入及输出电流可达

10、到25mAl Timer0:带有预分频器的8位定时器/计数器l Timer1:带有预分频器的16位定时器/计数器,在使用外部晶振震荡时钟时,在睡眠期间仍能工作l Timer2:带有8位周期寄存器,预分频器和后分频器的8位定时器/计数器。l 2个捕捉器,比较器,PWM模块其中: 捕捉器是16位,最大分辨率是12.5ns 比较器是16位,最大分辨率是200ns PWM最大分辨率是10位l 10位多通道模数转换器2.3 最小系统 2.3.1复位功能PIC16F877A的复位功能设计得比较完善,实现复位或引起复位的条件和原因可以归纳成4类:人工复位、上电复位、看门狗复位、欠压复位。这里简单介绍一下人工

11、复位人工复位:无论是单片机在正常运行程序,还是处在睡眠状态或出现死机状态,只要在人工复位端MCLR加入低点平信号,就令其复位。本次设计的电路图如图2.31所示。 图 2.31 PIC最小系统电路图 图2.32 最小系统实物图 2.3.2 系统时钟 数字电路的工作离不开时钟信号,每一步细微动作都是在一个共同的时间基准信号协调下完成的。作为时基发生器的时钟震荡电路,为整个单片机芯片的工作提供系统时钟信号,也为单片机与其他外接芯片之间的通讯提供可靠的同步时钟信号。PIC16F877A的时钟电路是由片内的一个反相器和一个反馈电阻,与外接的1个石英晶体和2个电容,共同构成的一个自激多谐振荡器。电路如图2

12、.31 所示。2.4 设计心得总结 PIC16F877A的最小系统跟51相似,较为简单。芯片自身增加了很多功能,如:自带8路AD转换、增加SPI总线,引脚复位功能多等。芯片自身功能的增加给设计带来了很多灵活性,同时也是学习的难点。3 LCD12864液晶原理介绍及接口实现3.1 液晶显示模块概述12864A-1汉字图形点阵液晶显示模块,可显示汉字及图形,内置8192个中文汉字(16X16点阵)、128个字符(8X16点阵)及64X256点阵显示RAM(GDRAM)。主要技术参数和显示特性:电源:VDD 3.3V+5V(内置升压电路,无需负压);显示内容:128列 64行显示颜色:黄绿显示角度:

13、6:00钟直视LCD类型:STN与MCU接口:8位或4位并行/3位串行配置LED背光多种软件功能:光标显示、画面移位、自定义字符、睡眠模式等3.2 液晶引脚说明引脚号引脚名称方向功能说明1VSS-模块的电源地2VDD-模块的电源正端3V0-LCD驱动电压输入端4RS(CS)H/L并行的指令/数据选择信号;串行的片选信号5R/W(SID)H/L并行的读写选择信号;串行的数据口6E(CLK)H/L并行的使能信号;串行的同步时钟7DB0H/L数据08DB1H/L数据19DB2H/L数据210DB3H/L数据311DB4H/L数据412DB5H/L数据513DB6H/L数据614DB7H/L数据715

14、PSBH/L并/串行接口选择:H-并行;L-串行16NC空脚17/RETH/L复位 低电平有效18NC空脚19LED_A-背光源正极(LED+5V)20LED_K-背光源负极(LED-OV)逻辑工作电压(VDD):4.55.5V电源地(GND):0V工作温度(Ta):060(常温) / -2075(宽温)3.3 接口时序模块有并行和串行两种连接方法,本文采用并行接法(时序如下):8位并行连接时序图MPU写资料到模块程序实现如下:/* 名 称:send_i() * 功 能:写一个字节命令到LCD* 入口参数:unsigned char x 字符*/void send_i(unsigned cha

15、r x)chk_busy(); /检测LCD是否工作繁忙rs = 0; /设置该字节数据为控制命令rw = 0; /设置此次操作为写PORTD = x; /送数据口PORTDe = 1; /使能nop();nop();nop();e = 0; /禁止MPU从模块读出资料程序实现如下:/* 读数据*/unsigned char u8_Lcd12864ReadByte_f( void ) unsigned char byReturnValue ; chk_busy() ; /检测LCD是否工作繁忙TRISD=0XFF; /设置PD口为输入状态 PORTD = 0xff ; /PD初始化为高电平 r

16、s=1; / 读置高 rw=1; / 写置高 e=0; / 使能置低 e=1; / 使能置高 byReturnValue = PORTD ; / 读数据 e=0; / 关使能TRISD=0X00; / 恢复PD口为输出 return byReturnValue ; / 返回读到的数据3.4 具体指令介绍1、清除显示CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLLLLLLLH功能:清除显示屏幕,把DDRAM位址计数器调整为“00H”2、位址归位CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLLLLLLHX功

17、能:把DDRAM位址计数器调整为“00H”,游标回原点,该功能不影响显示DDRAM3、位址归位CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLLLLLHI/DS功能:把DDRAM位址计数器调整为“00H”,游标回原点,该功能不影响显示DDRAM功能:执行该命令后,所设置的行将显示在屏幕的第一行。显示起始行是由Z地址计数器控制的,该命令自动将A0-A5位地址送入Z地址计数器,起始地址可以是0-63范围内任意一行。Z地址计数器具有循环计数功能,用于显示行扫描同步,当扫描完一行后自动加一。4、显示状态 开/关CODE: RW RS DB7 DB6 DB5

18、DB4 DB3 DB2 DB1 DB0LLLLLLHDC B 功能: D=1;整体显示ON C=1;游标ON B=1;游标位置ON5、游标或显示移位控制CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLLLHS/CR/LX X 功能:设定游标的移动与显示的移位控制位:这个指令并不改变DDRAM的内容6、功能设定CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLLHDLX0 REX X 功能:DL=1(必须设为1) RE=1;扩充指令集动作 RE=0:基本指令集动作7、设定CGRAM位址CODE: RW RS D

19、B7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLHAC5AC4AC3AC2AC1 AC0功能:设定CGRAM位址到位址计数器(AC)8、设定DDRAM位址CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLHAC6AC5AC4AC3AC2AC1 AC0 功能:设定DDRAM位址到位址计数器(AC)9、读取忙碌状态(BF)和位址CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LHBFAC6AC5AC4AC3AC2AC1 AC0 功能:读取忙碌状态(BF)可以确认内部动作是否完成,同时可以读出位址计数器(

20、AC)的值10、写资料到RAMCODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0HLD7D6D5D4D3D2D1 D0 功能:写入资料到内部的RAM(DDRAM/CGRAM/TRAM/GDRAM)11、读出RAM的值CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0HHD7D6D5D4D3D2D1 D0 功能:从内部RAM读取资料(DDRAM/CGRAM/TRAM/GDRAM)12、待命模式(12H)CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLLLLLLL H 功能:进入待命

21、模式,执行其他命令都可终止待命模式13、卷动位址或IRAM位址选择(13H)CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLLLLLLH SR 功能:SR=1;允许输入卷动位址 SR=0;允许输入IRAM位址 14、反白选择(14H)CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLLLLLHR1 R0功能:选择4行中的任一行作反白显示,并可决定反白的与否15、睡眠模式(015H)CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLLLLHSLX X功能:SL=1;脱离

22、睡眠模式 SL=0;进入睡眠模式16、扩充功能设定(016H)CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLLHHX1 REG L 功能:RE=1;扩充指令集动作 RE=0;基本指令集动作 G=1;绘图显示ON G=0;绘图显示OFF17、设定IRAM位址或卷动位址(017H)CODE: RW RS DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLLHAC5AC4AC3AC2AC1 AC0 功能:SR=1;AC5AC0为垂直卷动位址 SR=0;AC3AC0写ICONRAM位址18、设定绘图RAM位址(018H)CODE: RW R

23、S DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0LLHAC6AC5AC4AC3AC2AC1 AC0 功能:设定GDRAM位址到位址计数器(AC)备注、1、当模块在接受指令前,微处理顺必须先确认模块内部处于非忙碌状态,即读取BF标志时BF需为0,方可接受新的指令;如果在送出一个指令前并不检查BF标志,那么在前一个指令和这个指令中间必须延迟一段较长的时间,即是等待前一个指令确实执行完成,指令执行的时间请参考指令表中的个别指令说明。2、“RE”为基本指令集与扩充指令集的选择控制位元,当变更“RE”位元后,往后的指令集将维持在最后的状态,除非再次变更“RE”位元,否则使用相同指令集时

24、,不需每次重设“RE”位元。本次设计液晶初始化如下:void lcd_init()rst = 0; /复位LCDdelay(1); /保证复位所需要的时间(1ms)rst = 1; /恢复LCD正常工作/nop();/psb = 1; /设置LCD为8位并口通信send_i(0x30); /基本指令操作send_i(0x01); /清除显示send_i(0x06); /指定在写入或读取时,光标的移动方向send_i(0x0c); /开显示,关光标,不闪烁3.5 显示坐标关系3.5.1、图形显示坐标水平方向X以字节单位 垂直方向Y以位为单位/*函数名称:Draw_PM功 能:在整个液晶屏幕上画图

25、参 数:无返回值 :无*/void Draw_PM(const uchar *ptr) uchar i,j,k; send_i(0x34); /打开扩展指令集i = 0x80; for(j = 0;j 32;j+) send_i(i+); send_i(0x80); for(k = 0;k 16;k+) send_d(*ptr+); i = 0x80; for(j = 0;j 32;j+) send_i(i+); send_i(0x88); for(k = 0;k 0;i-)value = 1;DQ_LOW();NOP();NOP();NOP();NOP();NOP();NOP(); /6us

26、DQ_HIGH(); /拉至高电平NOP();NOP();NOP();NOP();NOP(); /4us j = DQ;if (j) value |= 0x80;delay(2, 7); /63usreturn (value);(3) DS18B20的写时序:对于DS18B20的写时序仍然分为写0时序和写1时序两个过程。 对于DS18B20写0时序和写1时序的要求不同,当要写0时序时,单总线要被拉低至少60us,保证DS18B20能够在15us到45us之间能够正确地采样IO总线上的“0”电平,当要写1时序时,单总线被拉低之后,在15us之内就得释放单总线。 图4.5 DS18B20写时序图/* 名 称:write_byte() * 功 能:写18b20写字节* 入口参数:uch val 待写的数据*

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号