51单片机数字温度计的设计

51单片机数字温度计的设计

ID:43403136

大小:83.50 KB

页数:7页

时间:2019-10-01

51单片机数字温度计的设计_第1页
51单片机数字温度计的设计_第2页
51单片机数字温度计的设计_第3页
51单片机数字温度计的设计_第4页
51单片机数字温度计的设计_第5页
资源描述:

《51单片机数字温度计的设计》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、一.任务及功能要求设计制作一个数字温度计,该温度计要求测温范围在-30℃~110℃,误差在±0.5℃以内,用LED数码管直读显示。二.方案论证传统的测温元件有热电偶和热电阻,而它们测出的一般都是电压,再转换成对应的温度,需要比较多的外部硬件支持,电路复杂,软件调试复杂,制作成本高。所以我们改用一种智能传感器DS18B20作为检测元件,测温范围-55℃~125℃,分辨率最大可达0.0625℃。DS18B20可以直接读出被测温度值。而且采用3线制与单片机相连,减少了外部硬件电路,具有低成本和易使用的特点。三.系统硬件电路

2、设计系统由3个模块组成:主控制器.测温电路和显示电路。结构框图如下所示。3.1主控制器单片机使用AT89S52。易于调试及烧录。3.2显示电路显示电路采用4位共阳LED数码管,从P1口输出段码,列扫描用P3.2~P3.5来实现,列驱动用9012三极管。3.3系统设计电路原理图:四.系统程序的设计系统程序的设计主要包括C程序主函数.DS18B20复位函数.DS18B20写字节函数.DS18B20读字节函数.温度计算转换函数和显示函数等。程序清单:#include"reg51.h"#include"intrins.h"#

3、definedisdataP1#definediscanP3#defineucharunsignedchar#defineuintunsignedintsbitDQ=P3^7;sbitDIN=P1^7;uinth;ucharcodeditab[16]={0X00,0x01,0x01,0x02,0x03,0x03,0x04,0x04,0x05,0x06,0x06,0x07,0x08,0x08,0x09,0x09};ucharcodedis_7[12]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x8

4、2,0xf8,0x80,0x90,0xff,0xbf};ucharcodescan_con[4]={0xfb,0xf7,0xef,0xdf};uchardatatemp_data[2]={0x00,0x00,};uchardatadisplay[5]={0x00,0x00,0x00,0x00,0x00};voiddelay(uintt){for(;t>0;t--);}scan(){chark;for(k=0;k<4;k++){disdata=dis_7[display[k]];if(k==1){DIN=0;}disc

5、an=scan_con[k];delay(90);discan=0xff;}}ow_reset(void){charpresence=1;while(presence){while(presence){DQ=1;_nop_();_nop_();DQ=0;delay(50);DQ=1;delay(6);presence=DQ;}delay(45);presence=~DQ;}DQ=1;}voidwrite_byte(ucharval){uchari;for(i=8;i>0;i--){DQ=1;_nop_();_nop_

6、();DQ=0;_nop_();_nop_();_nop_();_nop_();_nop_();DQ=val&0x01;delay(6);val=val/2;}DQ=1;delay(1);}ucharread_byte(void){uchari;ucharvalue=0;for(i=8;i>0;i--){DQ=1;_nop_();_nop_();value>>=1;DQ=0;_nop_();_nop_();_nop_();_nop_();DQ=1;_nop_();_nop_();_nop_();_nop_();if(

7、DQ)value=0x80;delay(6);}DQ=1;return(value);}read_temp(){ow_reset();write_byte(0xcc);write_byte(0xbe);temp_data[0]=read_byte();temp_data[1]=read_byte();ow_reset();write_byte(0xcc);write_byte(0x44);}work_temp(){ucharn=0;if(temp_data[1]>127){temp_data[1]=(256-temp

8、_data[1]);temp_data[0]=(256-temp_data[0]);n=1;}display[4]=temp_data[0]&0x0f;display[0]=ditab[display[4]];display[4]=((temp_data[0]&0xf0)>>4)((temp_data[1]&0x0f)<<4);display[

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。