参考文献
[1]周云波;由DS18B20单线数字温度计构成的单线多点温度测量系统[J];电子技术应用;1996年10期
[2]李敏;DS18B20单结数字温度计的使用方法[J];电子产品世界;1996年06期. [3]沈荣金;DS18B20数字温度计的应用[J];电子技术应用;1997年04期 [4]李农FPGA与DS18B20型温度传感器通信的实现[J].国外中电子元器件.2006. [5]李朝青.单片机原理及接口技术(简明修订版).杭州:北京航空航天大学出版社,1998
[6]刘明军 王汉功 查柏林 ;基于DS18B20和并口的温度测量系统占君;仪器仪表用户 ;2006年 第04期
[7]姜志海;单片微型计算机原理及应用;机械工业出版社;2007
[8]王勇 叶敦范.《基于AT89S51 的便携式实时温度检测仪》[J].选自《仪表技术与传感器》.2006
[9]Stefan Blechschmidt. Temperature monitoring with Linux. [EB /OL].www.linuxfocus. org/Engli sh/November2003/artic1e315.shtm
[10]美国
Dallas
半导体公司
DS18B20 datasheet [EB/OL].
http://www.datasheetcatalog.com/datasheets_pdf/D/S/I/S/DS 1820. shtml
[11]美国Maxim公司.www.ibutton.com/ibutton /standard.pdf[EB/OL]
26
致谢
27
附录
程序:
#include\#include\#define Disdata P1 #define discan P3
#define uchar unsigned char #define uint unsigned int sbit DQ=P3^7; sbit DIN=P1^7; uint h; uchar code
ditab[16]={0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x06,0x07,0x08,0x08,0x09,0x09}; uchar code dis_7[12]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xff,0xbf}; uchar code scan_con[4]={0xfe,0xfd,0xfb,0xf7}; uchar data temp_data[2]={0x00,0x00}; uchar data display[5]={0x00,0x00,0x00,0x00,0x00};
void delay(uint t) {
for(;t>0;t--); } scan() {
char k; for(k=0;k<4;k++) { Disdata=dis_7[display[k]]; if(k==1){DIN=0;} discan=scan_con[k];delay(90);discan=0xff; } }
ow_reset(void) {
char presence=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; }
void write_byte(uchar val) {
uchar i;
for(i=8;i>0;i--) {
DQ=1;_nop_();_nop_();
DQ=0;_nop_();_nop_();_nop_();_nop_();_nop_();
DQ=val&0x01; delay(6); val=val/2; }
DQ=1; delay(1); }
uchar read_byte(void) {
uchar i;
uchar value=0; for(i=8;i>0;i--) {
DQ=1;_nop_();_nop_(); value>>=1;
28
DQ=0;
_nop_();_nop_();_nop_();_nop_();
DQ=1;_nop_();_nop_();_nop_();_nop_(); if(DQ)value|=0x80; delay(6); }
DQ=1;
return(value); ow_reset();
write_byte(0xCC); write_byte(0x44); for(h=0;h<500;h++) { scan(); }
while(1) }
{ 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() {
uchar n=0;
if(temp_data[1]>127) { temp_data[1]=(256-temp_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[3]=display[4]/100; display[1]=display[4]0; display[2]=display[1]/10; display[1]=display[1]; if(!display[3]){display[3]=0x0A;if(!display[2]){display[2]=0x0A;}} if(n){display[3]=0x0B;} }
main() {
Disdata=0xff; discan=0xff;
for(h=0;h<4;h++){display[h]=8;}
29
read_temp(); work_temp(); for(h=0;h<500;h++) {scan();}
30