根据RC充电原理知道:未知Rx=(未知充电时间us/已知充电时间us)*已知电阻k
先用10K(或100k或其它精密电阻)根据下图测出所用时间us(粗测出289us,公式用到)
显示的数码管线路可能不同,我自己焊在P1口上。
制作出来的实物图如下:
其实还可以改精度更高些,主要关键稳定电压,稳定质量电阻电容,还有公式取的精度。
粗陋对比18B20温度
51单片机源程序:测试已知电阻充电时间也用上面小改一下,让数码管显示Rxt就是被测时间。
- #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;}
复制代码
【必读】版权免责声明
1、本主题所有言论和内容纯属会员个人意见,与本论坛立场无关。2、本站对所发内容真实性、客观性、可用性不做任何保证也不负任何责任,网友之间仅出于学习目的进行交流。3、对提供的数字内容不拥有任何权利,其版权归原著者拥有。请勿将该数字内容进行商业交易、转载等行为,该内容只为学习所提供,使用后发生的一切问题与本站无关。 4、本网站不保证本站提供的下载资源的准确性、安全性和完整性;同时本网站也不承担用户因使用这些下载资源对自己和他人造成任何形式的损失或伤害。 5、本网站所有软件和资料均为网友推荐收集整理而来,仅供学习用途使用,请务必下载后两小时内删除,禁止商用。6、如有侵犯你版权的,请及时联系我们(电子邮箱1370723259@qq.com)指出,本站将立即改正。
|
|