Pt100铂电阻测温电路(稳定版)

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

常用电路图

R2、R3、R4 和Pt100 组成传感器测量电桥,为了保证电桥输出电压信号的稳定性,电桥的输入电压通过TL431 稳至2.5V。从电桥获取的差分信号通过两级运放放大后输入单片机。电桥的一个桥臂采用可调电阻R3,通过调节R3 可以调整输入到运放的差分电压信号大小,通常用于调整零点。

放大电路采用LM358 集成运算放大器,为了防止单级放大倍数过高带来的非线性误差,放大电路采用两级放大,如图 5.1 所示,前一级约为10 倍,后一级约为3倍。温度在0~100 度变化,当温度上升时,Pt100 阻值变大,输入放大电路的差分信号变大,放大电路的输出电压Av 对应升高。

注意:虽然电桥部分已经经过TL431 稳压,但是整个模块的电压VCC 一定要稳定,否则随着VCC 的波动,运放LM358 的工作电压波动,输出电压Av 随之波动,最后导致A/D 转换的结果波动,测量结果上下跳变。

铂热电阻阻值与温度关系为:

式中,A=0.00390802;B=-0.000000580;C=0.0000000000042735。可见Pt100 在常温0~100摄氏度之间变化时线性度非常好,其阻值表达式可近似简化为:RPt=100(1+At),当温度变化1 摄氏度,Pt100 阻值近似变化0.39 欧。

Pt100 的分度表(0℃~100℃)

程序处理

一般在使用PT100 的温度采集方案中,都会对放大器LM358 采集来的模拟信号A V进行温度采样,即进行A/D 转换。

A/D 处理包括两方面内容,一是A/D 值的滤波处理,二是A/D 值向实际温度转换。由于干扰或者电路噪声的存在,在采样过程当中会出现采样信号与实际信号存在偏差的现象,甚至会出现信号的高低波动,为了减小这方面原因造成的测量误差,在实际采样时采样18 个点,然后再除去其中偏差较大的两个点,即一个最大值和一个最小值,再对剩余的16 个点取均值,这样得到的A/D 转换结果比较接近实际值。

在对数值进行滤波操作之后,还要将A/D 值转换为温度,常用的两种方法为查表法和公式法:查表法比较麻烦,而且精度也不高,适合于线性化较差的NTC 温度传感器;公式法比较简单,只需要确定比例系数K 和基准偏差B 即可,适合于线性化较好的传感器温度转换的C 语言实现过程为:

fT = (ADC_data * K) –B; //换算成温度值。

得到温度后,一般还会对被控对象根据实际温度和目标温度进行实时的控制,要又要设计到控制算法,如:模糊控制、PID 调节等。这里简单介绍一下PID 控制原理,更多内容请察看相关书籍。

PID 工作原理

PID(Proportional Integral Derivative)控制是控制工程中技术成熟、应用广泛的一种控制策略,经过长期的工程实践,已形成了一套完整的控制方法和典型的结构。它不仅适用于数学模型已知的控制系统中,而且对于大多数数学模型难以确定的工业过程也可应用,在众多工业过程控制中取得了满意的应用效果。

由于来自外界的各种扰动不断产生,要想达到现场控制对象值保持恒定的目的,控制作用就必须不断的进行。若扰动出现使得现场控制对象值(以下简称被控参数)发生变化,现场检测元件就会将这种变化采集后经变送器送至PID 控制器的输入端,并与其给定值(以下简称SP 值)进行比较得到偏差值(以下简称e 值),调节器按此偏差并以我们预先设定的整定参数控制规律发出控制信号,去改变调节器的开度,使调节器的开度增加或减少,从而使现场控制对象值发生改变,并趋向于给定值(SP 值),以达到控制目的,如图所示,其实PID 的实质就是对偏差(e 值)进行比例、积分、微分运算,根据运算结果控制执行部件的过程。

温度控制PID 算法设计

利用了上面所介绍的位置式PID 算法,将温度传感器采样输入作为当前输入,然后与设定值进行相减得偏差,然后再对之进行PID 运算产生输出结果fOut,然后让fOut 控制定时器的时间进而控制加热器。为了方便PID 运算,首先建立一个PID 的结构体数据类型,该数据类型用于保存PID 运算所需要的P、I、D 系数,以及设定值,历史误差的累加和等信息:

typedef struct PID

{

float SetPoint; // 设定目标Desired Value

float Proportion; // 比例系数Proportional Const

float Integral; // 积分系数Integral Const

float Derivative; // 微分系数Derivative Const

int LastError; // 上次偏差

int SumError; // 历史误差累计值

} PID;

PID stPID; // 定义一个stPID 变量

PID 运算的C 实现代码

float PIDCalc( PID *pp, int NextPoint )

{

int dError,Error;

Error = pp->SetPoint*10 -NextPoint; // 偏差,设定值减去当前采样值

pp->SumError += Error; // 积分,历史偏差累加

dError = Error-pp->LastError; // 当前微分,偏差相减

pp->PrevError = pp->LastError; // 保存

pp->LastError = Error;

return (pp->Proportion * Error+ pp->Integral * pp->SumError-pp->Derivative * dError);

}

其中(pp->Proportion * Error)是比例项;(pp->Integral * pp->SumError)是积分项;(pp->Derivative * dError)是微分。

相关文档
最新文档