例如: 假设温度检测传感器测量温度范围是A0~Am,转换后的电压经
AD转换器转换的数字量是8位的,则其范围是00H~OFFH。
则如果某一时刻,AD转换培宽器转换的数字量是N,那么测量的实际温度
为A,
根据线性传感器、AD转换器转换器的转换信号的关系:可以推出
A=(Am-A0)*N/(255-0)+A0
可以编程由程序实现上述的计算过程。
参考自己实际的情况,就可以写出类似上述的公式,作为编写用热敏
电阻测温度的程序的算法。
算法有了,程序就自己写吧,不是棚困很难了。
1、单片机热敏电阻测温首先要设计电路原理图,如图所示:
上带袜毕图R3为上拉电阻,T1为接热敏电阻端,TC1为单片机AD采集口、电阻R4和电热C6为阻容滤波电路。
2、上拉电阻R3的选择:根据所用温度的范围,选择热敏电阻对应阻值范围的中间值最好,这样检测的温度偏差较小。
3、上拉电阻选定后,根据热敏电阻阻值表,算出温度真值表,蠢芹用于软件查表,计算出温度值。在算温度真值表前,首先要确定单片机AD模块的分辨率。
4、单片机软件编程,滤波方法一般采用多次采集求累加和,去最大值和最小值,最后求好仿平均。
5、单片机选择:一般选用8位单片机就够。但是,单片机自带的温度采集AD模块,最好选用10位分辨率,10位的AD模块分辨率高,温度采集精确。
6、以上为单片机热敏电阻测温的一般流程。
热敏电阻测温度(程序+仿真)#include<reg52.h>
#include<intrins.h>
#include<math.h>
typedef unsignedchar uchar
typedef unsignedint uint
sbit CE = P1^1
sbit STS=P1^0
sbit RC=P1^4
sbit A0=P1^3
sbit CS=P1^2
sbit RS = P1^5
sbit RW = P1^6
sbit EN = P1^7
void delay_ms(uintz)
{
uint x,y
for(x=zx>0x--)
for(y=110y>0y--)
}
uintAD1674_Read(void)
{
uint temp
uchar temp1,temp2
CS=1//片选信号
CE=0//初始化,关闭数据采集
CS=0
A0=0
RC=0
CE=1//CE=1,CS=0,RC=0,A0=0启动12位温度转换
_nop_()
while(STS==1) //等待数据采集结束
CE=0//芯片使能关闭
RC=1
A0=0
CE=1//CE=1,CS=0,RC=1,12/8=1,A0=0 允许高八位数据并行输出
_nop_()
temp1=P0//读取转换结果的高八位
CE=0//芯片使能关闭
RC=1
A0=1
CE=1//CE=1,CS=0,RC=1,12/8=0,A0=1 允许低四位数据 并行输出纯好
_nop_()
temp2=P0 //读做启铅取转换结果的第四位
temp=((temp1<<4)|(temp2&0X0F)) //高位和低位合成实际温度,temp2为PO口的高四位
return (temp) //还回转换结果,右移四位是因为temp2为P0口的高四位
}
/**
* 写数据
*/
voidw_dat(unsigned char dat)
{
RS = 1
//EN = 0
P2 = dat
delay_ms(5)
RW = 0
EN = 1
EN = 0
}
/**
* 写命令
*/
voidw_cmd(unsigned char cmd)
{
RS = 0
// EN = 0
P2 = cmd
delay_ms(5)
RW = 0
EN = 1
EN = 0
}
/**
* 发送字符串到LCD
*/旁睁
voidw_string(unsigned char addr_start, unsigned char *p)
{
unsigned char *pp
pp = p
w_cmd(addr_start)
while (*pp != '\0')
{
w_dat(*pp++)
}
}
/**
* 初始化1602
*/
voidInit_LCD1602(void)
{
EN = 0
w_cmd(0x38) // 16*2显示,5*7点阵,8位数据接口
w_cmd(0x0C) // 显示器开、光标开、光标允许闪烁
w_cmd(0x06) // 文字不动,光标自动右移
w_cmd(0x01) // 清屏
}
void process(uintdate,uchar add)
{
uchar A[7]
A[0]=date/1000%10+'0'
A[1]=date/100%10+'0'
A[2]='.'
A[3]=date/10%10+'0'
A[4]=date%10+'0'
A[5]='C'
w_string(add,A)
}
void main()
{
uintVOL[25]={343,339,332,328,320,316,312,304,300,292,289,285,277,273,265,261,257,250,246,242,234,230,226,222,218}
uintTemper[25]={100,200,300,400,500,600,700,800,900,1000,1100,1200,1300,1400,1500,1600,1700,1800,1900,2000,2100,2200,2300,2400,2500}
uchar i,flag=0
uint result,temp1,temp2
float res
Init_LCD1602()
w_string(0x80,"Temper:")
// w_string(0xC0,word2)
while (1)
{
res=(float)(AD1674_Read())
result=(uint)((res/2048.0-1.0)*500.0)
temp1=abs(result-VOL[0])
for(i=1i<25i++)
{
temp2=abs(result-VOL)
if(temp1>=temp2)
{
temp1=temp2
flag=i
}
}
process(Temper[flag],0x80+7)
//process(result,0xc0)
//delay_ms(1000)
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)