51单片机-温度传感器DS18B20
本文主要基于51单片机的温度传感器DS18B20开发示例的编程应用来理解开发中如何看时序图,用代码模拟时序图实现器件功能。
1.DS18B20简介
DS18B20的核心功能是它可以直接读出数字的温度数值。温度传感器的精度为用户可编程的9,10,11或12位,分别以0.5℃,0.25℃,0.125℃和0.0625℃增量递增。在上电状态下默认的精度为12位。
DS18B20启动后保持低功耗等待状态,当需要执行温度测量和AD转换时,总线控制器必须发出[44h]命令。转换完以后,产生的温度数据以两个字节的形式被存储到高速暂存器的温度寄存器中,DS18B20继续保持等待状态。
2.内部温度寄存器
这是12位转化后得到的12位数据,存储在DS18B20的两个8位的RAM中,高字节的前5位是符号位,如果测得的温度大于0,这5位为‘0’,只要将测到的数值乘以0.0625即可得到实际温度;如果温度小于0,这5位为‘1’,测到的数值需要先减1再取反再乘以0.0625即可得到实际温度。
3.ROM和RAM指令
用DS18B20“写”功能执行约定代码得到相应的指令功能。该“写”功能根据时序图得到。
4.新建temp库代码实现
4.1.库文件.h
//temp.h
#ifndef _temp_H
#define _temp_H
#include <reg52.h>
#ifndef uchar
#define uchar unsigned char
#ifndef uint
#define uint unsigned int
#endif
sbit DSPORT = P3^7; //接线的引脚
int Ds18b20ReadTemp();//声明函数,方便在主函数调用
#endif
4.2.DS18B20初始化
(1)数据端口拉到低电平“0”。
(2)延时480微秒(该时间的时间范围可以从480到960微秒)。
(3)数据端口拉到高电平“1”。
(4)延时等待80微秒。如果初始化成功则在15到60微妙时间内产生一个由DS18B20所返回的低电平“0”.根据该状态可以来确定它的存在,但是应注意不能无限的进行等待,不然会使程序进入死循环,所以要进行超时判断。
(5)若CPU读到了数据端口上的低电平“0”后,还要做延时,其延时的时间从发出的高电平算起
(第(3)步的时间算起)最少要480微秒。
//temp.c
/*
*初始化函数:Ds18b20Init()
*根据时序图,先拉低电平延时480us~960us,这里用642us,再将数据端口拉高,判断
*是否存在可用的DS18b20(0为存在,1为不存在),如果存在该温度传感器,就初始化返回1,
*否则不存在时先等待5ms(在时序图中要超过控制器RX的480us),在等待5ms后依然是不存在,
*就确定没有可用的温湿度传感器,初始化返回0.
*/
uchar Ds18b20Init()
{
uchar i=0;
DSPORT=0;//数据端口拉低电平
i=70;
while(i--);//642us(延时要求480us~960us)
DSPORT=1;//数据端口拉高电平
i=0;
/*
如果初始化成功得到DSPORT返回的低电平0,跳出while,整个初始化函数返回1,否则判断是否超时,
超过5ms后整个初始化函数返回0
*/
while(DSPORT)
{
Delay1ms(1);
i++;
if(i>5)
{
return 0;
}
}
return 1;
}
3.2.DS18B20“读”
(1).将数据端口拉低“0”。
(2).延时1微秒。(执行一条指令就有1us以上了)
(3).将数据端口拉高“1”,释放总线准备读数据。
(4).延时10微秒。
(5).读数据端口的状态得到1个状态位,并进行数据处理。
(6).延时45微秒。
(7).重复1~7步骤,直到读完一个字节。
//temp.c
uchar Ds18b20ReadByte()
{
uint i,j;
uchar bi,byte;
for(j=8;j>0;j--)
{
DSPORT=0;
i++;//用来延时微秒
DSPORT=1;
i++;//用来延时微秒
i++;//用来延时微秒
bi=DSPORT;
byte=(byte>>1)|