根据RC充电原理知道:未知Rx=(未知充电时间us/已知充电时间us)*已知电阻k
先自己用10K(或100k或其它精密电阻)根据下图测出所用时间us(我粗测出289us,公式用到)
显示的数码管线路可能不同,我自己焊在P1口上。
制作出来的实物图如下:
其实还可以改精度更高些,主要关键稳定电压,稳定质量电阻电容,还有公式取的精度。
粗陋对比18B20温度
单片机源程序如下:
#include<reg52.h>
#define u8 unsigned char
#define u16 unsigned int
sbit Rc=P0^0;u16 s=0,r=0;
sbit a=P3^4;sbit b=P3^5;sbit c=P3^6;sbit d=P3^7; //4个数码管
u8 code tab[12]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0,0x63};
u8 us,t,dw[4];//数码管显示0--9,0是关显示,0x63是温度符号
u16 code ntc100[]={31076,29541,28090,26720,25424,24199,23039,21942,20904,
19920,18988,18106,17269,16475,15723,15009,14331,13688,13077,12497,11946,
11422,10924,10451,10000,9571,9163,8775,8405,8052,7717,7397,7092,6801,6524,
6259,6007,5766,5536,5316,5106,4906,4714,4531,4356,4189,4029,3875,3729,3588};
//1--50的温度//自己设置需要的温度
void Delay(u16 n){while(--n);}//12M公式n=(延时-6)*0.12493899(us)
void disp()
{ s++;if(s==3000)s=0; //s=3000是延时一会儿再读取温度
dw[0]=10;dw[1]=t%100/10;dw[2]=t%10;dw[3]=11;
P1=tab[dw[0]];a=1;Delay(70);a=0;P1=tab[dw[1]];b=1;Delay(70);b=0;
P1=tab[dw[2]];c=1;Delay(70);c=0;P1=tab[dw[3]];d=1;Delay(70);d=0;P1=0;}
void T0init()
{TMOD=0x02;TH0=0x00;TL0=0x00;ET0=1;EA=1;}
void main(void)
{ long u16 Rxt;u16 temp;u8 j;
T0init();
while(1)
{
if(s==0){Rc=0;Delay(600);//约5ms
Rc=1;TR0=1;while(!Rc);TR0=0;
Rxt=us*256+TL0;TL0=0;us=0;Rc=0;
r=((float)(Rxt*1.0/289*1.0)+0.00005)*10*100;}
//289us是已知电阻(10K)测到的时间*10是10k单位是k,
//*100是取温度有效值,如26度ntc100k是(95.7132k)ntc10k(9.631K)
if((r>3455)&&(r<32500))//阻值在1~50度之间,显示对应的温度
{for(j=0;j<50;j++){temp=ntc100[j];if(r>=temp) break;}
t=j;}
disp();
}}
void t0() interrupt 1
{us++;if(us==255)us=0;}
测试已知电阻充电时间也用上面小改一下,让数码管显示Rxt就是被测时间。
下面下载跟上面一样。上面直接复制到keil改数码管改接口就行。
C52粗测NTC温度.rar
(1.07 KB, 下载次数: 74)
|