智能温度测量仪课程设计_第1页
智能温度测量仪课程设计_第2页
智能温度测量仪课程设计_第3页
智能温度测量仪课程设计_第4页
智能温度测量仪课程设计_第5页
已阅读5页,还剩9页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、一、系统功能说明一、系统功能说明1.11.1 主要技术指标主要技术指标1)测温范围:-200600 摄氏度;2)测温精度:0.5 摄氏度;3)稳定性:0.5 摄氏度1.21.2 PT100PT100 传感器传感器 电阻式温度传感器(RTD, Resistance Temperature Detector)是指一种物 质材料作成的电阻,它会随温度的改变而改变电阻值。 PT100 温度传感器是一种以铂(Pt)做成的电阻式温度传感器,属于正电阻系 数,其电阻阻值与温度的关系可以近似用下式表示: 在 0600范围内: Rt =R0 (1+At+Bt2) 在-2000范围内: Rt =R0 (1+At+

2、Bt2+C(t-100)t3) 式中 A、B、C 为常数, A=3.9684710-3; B=-5.84710-7; C=-4.2210-12;由于它的电阻温度关系的线性度非常好,因此在测量较小范围内其电阻和温度变化的关系式如下:R=Ro(1+T) 其中 =0.00392, Ro 为 100(在 0的电阻值),T 为华氏温度,因此铂做成的电阻式温度传感器,又称为 PT100。1.2.1 PT100 传感器特性PT100 温度传感器的测量范围广:-200+600,偏差小,响应时间短,还具有抗振动、稳定性好、准确度高、耐高压等优点,其得到了广泛的应用,本设计即采用 PT100 作为温度传感器。1.

3、2.2 PT100 传感器测量原理Pt100 是电阻式温度传感器,测温的本质其实是测量传感器的电阻,通常是将电阻的变化转换成电压或电流等模拟信号,然后再将模拟信号转换成数字信号,再由处理器换算出相应温度。采用 Pt100 测量温度一般有两种方法:方案一:设计一个恒流源通过 Pt100 热电阻,通过检测 Pt100 上电压的变化来换算出温度;测温原理:通过运放U1A将基准电压4.096V转换为恒流源,电流流过Pt100时在其上产生压降,再通过运放U1B将该微弱压降信号放大(图中放大倍数为10) ,即输出期望的电压信号,该信号可直接连AD转换芯片。根据虚地概念“工作于线性范围内的理想运放的两个输入

4、端同电位” ,运放U1A的“+”端和“-”端电位V+V-4.096V;假设运放U1A的输出脚1对地电压为Vo,根据虚断概念, (0-V-)/R1+(Vo-V-)/RPt1000,因此电阻Pt100上的压降VPt100Vo-V-V-*RPt100/R1,因V-和R1均不变,因此图1虚线框内的电路等效为一个恒流源流过一个Pt100电阻,电流大小为V- /R1,Pt100上的压降仅和其自身变化的电阻值有关。设计及调试注意点: 1. 等效恒流源输出的电流不能太大,以不超过1mA为准,以免电流大使得Pt100电阻自身发热造成测量温度不准确,试验证明,电流大于1.5mA将会有较明显的影响。2. 运放采用单

5、一5V供电,如果测量的温度波动比较大,将运放的供电改为15V双电源供电会有较大改善。3. 电阻R2、R3的电阻值取得足够大,以增大运放的U1B的输入阻抗。 图 1 恒流源式测温电路由于封装问题,实际原理图如下:方案二:采用惠斯顿电桥,电桥的四个电阻中三个是恒定的,另一个用Pt100 热电阻,当 Pt100 电阻值变化时,测试端产生一个电势差,由此电势差换算出温度。 测温原理:电路采用TL431和电位器VR1调节产生4.096V的参考电源;采用R1、R2、VR2、Pt100构成测量电桥(其中R1R2,VR2为100精密电阻) ,当Pt100的电阻值和VR2的电阻值不相等时,电桥输出一个mV级的压

6、差信号,这个压差信号经过运放LM324放大后输出期望大小的电压信号,该信号可直接连AD转换芯片。差动放大电路中R3R4、 R5R6、放大倍数R5/R3,运放采用单一5V供电。 设计及调试注意点: 1. 同幅度调整R1和R2的电阻值可以改变电桥输出的压差大小; 2. 改变R5/R3的比值即可改变电压信号的放大倍数,以便满足设计者对温度范围的要求 3. 放大电路必须接成负反馈方式,否则放大电路不能正常工作。4. VR2也可为电位器,调节电位器阻值大小可以改变温度的零点设定,例如Pt100的零点温度为0,即0时电阻为100,当电位器阻值调至109.885时,温度的零点就被设定在了25。测量电位器的阻

7、值时须在没有接入电路时调节,这是因为接入电路后测量的电阻值发生了改变。5. 理论上,运放输出的电压为输入压差信号放大倍数,但实际在电路工作时测量输出电压与输入压差信号并非这样的关系,压差信号比理论值小很多,实际输出信号为4.096*(RPt100/(R1+RPt100)- RVR2/(R1+RVR2) (1)式中电阻值以电路工作时量取的为准。 6. 电桥的正电源必须接稳定的参考基准,因为如果直接VCC的话,当网压波动造成VCC发生波动时,运放输出的信号也会发生改变,此时再到以VCC未发生波动时建立的温度-电阻表中去查表求值时就不正确了,这可以根据式(1)进行计算得知。 图2三线制接法桥式测温电

8、路1.31.3 AT89C51AT89C51 单片机单片机AT89C51 是一种带 4K 字节闪存可编程可擦除只读存储器 (FPEROMFlash Programmable and Erasable Read Only Memory)的低电压、高性能 CMOS 8 位微处理器,俗称单片机。AT89C2051 是一种带 2K 字节闪存可编程可擦除只读存储器的单片机。单片机的可擦除只读存储器可以反复擦除 1000 次。该器件采用ATMEL 高密度非易失存储器制造技术制造,与工业标准的 MCS-51 指令集和输出管脚相兼容。由于将多功能 8 位 CPU 和闪烁存储器组合在单个芯片中,ATMEL的 A

9、T89C51 是一种高效微控制器,AT89C2051 是它的一种精简版本。AT89C51 单片机为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。1.41.4 LCDLCD 显示器显示器 液晶显示器是一种采用了液晶控制透光度技术来实现色彩的显示器。和CRT 显示器相比,LCD 的优点是很明显的。由于通过控制是否透光来控制亮和暗,当色彩不变时,液晶也保持不变,这样就无须考虑刷新率的问题。对于画面稳定、无闪烁感的液晶显示器,刷新率不高但图像也很稳定。LCD 显示器还通过液晶控制透光度的技术原理让底板整体发光,所以它做到了真正的完全平面。二、系统总体设计二、系统总体设计测温的模拟电路是把当前 PT

10、100热电阻传感器的电阻值,转换为容易测量的电压值,经过放大器放大信号后送给 A/D 转换器把模拟电压转为数字信号后传给单片机 AT89C51,单片机再根据公式换算把测量得的温度传感器的电阻值转换为温度值,并将数据送出到 LCD 显示器进行显示。本设计系统主要包括温度信号采集单元,单片机数据处理单元,温度显示单元。其中温度信号的数据采集单元部分包括温度传感器、温度信号的获取电路(采样) 、放大电路、A/D 转换电路。系统的总结构框图如图 1-1 所示。 1-1 系统的总结构框图 本温度测量系统设计,是采用 PT100 温度传感器经过放大和 A/D 转换器送到单片机进行控制温度显示。另外本系统还

11、可以通过外接电路扩展实现温度报警功能,从而更好的实现温度现场的实时控制。三、硬件设计硬件设计3.1 放大电路的设计放大电路的设计本次放大电路我选用的是 LM358,其内部包括有两个独立的、高增益、内部频率补偿的双运算放大器,适合于电源电压范围很宽的单电源使用,也适用于双电源工作模式,在推荐的工作条件下,电源电流与电源电压无关。它的使用范围包括传感放大器、直流增益模块和其他所有可用单电源供电的使用运算放大器的场合。3.2 信号调理电路信号调理电路调理电路的作用是将来自于现场传感器的信号变换成前向通道中 A/D 转换器能识别的信号,作为本系统,由于温度传感器是热电阻 PT100,因此调理电路完成的

12、是怎样将与温度有关的电阻信号变换成能被 A/D 转换器接受的电压信号。3.3 A/DA/D 转换器的选择与设计电路转换器的选择与设计电路在我们所测控的信号中均是连续变化的物理量,通常需要用计算机对这些信号进行处理,则需要将其转换成数字量,A/D 转换器就是为了将连续变化的模拟量转换成计算机能接受的数字量。根据 A/D 转换器的工作原理,常用的A/D 转换器可分为两种,双积分式 A/D 转换器和逐次逼近式 A/D 转换器。1. 双积分 A/D 转换器工作原理2. 逐次逼近型 A/D 转换器工作原理在本设计系统中,为了将模拟量温度转换成数字量,采用德州仪器公司生产的 4 通道 12 位串行输出采样

13、模数转换器 ADS7841。具体连线如下图所示:3.4 单片机控制电路单片机控制电路本设计是采用 AT89C51 单片机作为主控电路,AT89C51 单片机是 Atmel 公司的产品,与 Intel 公司的 MCS51 系列兼容。在 AT89C51 单片机内部有作为程序存储器的 Flash 存储器,其容量为 4KB,可以承受不低于 1000 次的反复擦写,调试比较方便。其中 P1 口为 A/D 转换器的通信端口,P2 口为按键控制,P0 口为 LCD 的数据端口,具体电路图如下:3.5 按键和显示电路按键和显示电路本次设计使用 4x4 矩阵键盘,将其行线以及列线接到单片机的 P2 口,其中列线

14、接上拉电阻然后在通过异或逻辑门在接至单片机的 P2.0 到 P2.3 口。具体连线如下图所示:3.6 显示电路显示电路本次设计使用 LCD12864 来显示温度采集结果,其中将 LCD 的数据口接入单片机的 P0 口,具体接线如下图所示: 四、软件设计四、软件设计4.1 软件的流程图软件的流程图 开始系统初始化PT100 温度数据采集处理读到的数据送 LCD 显示结束开始初始化函数A/D 转换器进行 A/D 转换将转换后的电压转换为温度返回 图 1 系统总流程图 图 2 温度转换程序流程图 开始系统初始化调用温度子程序调用显示子程序调用扫描按键程序开始将温度数据写入到LCD读取温度值显示温度值

15、返回 图 3 显示流程图 图 4 主函数流程图4.2 系统软件设计说明系统软件设计说明进行微机测量控制系统设计时,除了系统硬件设计外,大量的工作就是如何根据每个测量对象的实际需要设计应用程序。因此,软件设计在微机测量控制系统设计中占重要地位。对于本系统,软件设计更为重要。在单片机测量控制系统中,大体上可分为数据处理、过程控制两个基本类型。数据处理包括:数据的采集、数字滤波、标度变换等。过程控制程序主要是使单片机按一定的方法进行计算,然后再输出,以便达到测量控制目的。软件设计主要是对温度进行采集、显示,通过按键操作,进行时间的设置与修改。因此,整个软件可分为温度采集子程序、时钟读取程序、按键子程

16、序、显示子程序、及系统主程序。4.3 软件的有关算法软件的有关算法4.3.1 最小二乘理论获取温度电阻公式 根据误差理论,我们要获得较高精度的温度测量值,办法一般有 2 个,要么采用查表法,要么建立高精度的数学模型。如果用查表法,主要有 2 个问题,如果要提高测量精度,则需要建立大量的表格,而且得提前做大量得试验来进行多点校正,还有一个问题是程序的通用性差,这台仪器上校正好得数据可能在另一台上不合适。而采用已知的分度表,建立数学模型,然后通过工程量(标度)变换,通过测量 A/D 转换的结果后计算得到。这里我们考虑第 2 种方法的优点,首先采用分段的方法,将测量范围分段,然后查出该段的数学模型的

17、各个系数,然后计算出温度值,这里,由于时间的关系,我们对整个测量范围分了 3 段,分别为 049、5070、71100,利用分度表进行离线的数学拟合,得到各段的数学模型系数。同时,可通过再将标度值代入可粗略估计在各个测量段内的最大误差值。 我们通过最小二乘法进行线性拟合,得到如下的数学模型为: T1=2.5772R-257.7708 0-49 T2=2.6366R-267.01 5070 T3=2.7206R-281.90 71100上述 3 个数学模型中,最大的理论误差值都小于 0.5,能够满足精度要求,实际上如果有足够的时间,我们完全可以分得再细一些,这样理论的误差将会变得更小。4.3.2

18、 标度变换公式的获取根据上述的线性拟合结果:T=AR-B,这里的 A、B 是上述不同温度段的系数,而 R 值由于在输出为 0V 时,实际上有个对应于 100 欧姆的偏置电路,因此根据 R-R0=U/I,而 I=2.500V/1.500K,而 AD/U/G=4096/4.900V,这里的 AD 值为 A/D 转换得结果 G 为放大器的增益,本设计中的二级放大器放大的倍数为 80倍。将上述条件代入得:T=A(4.9AD/4096/G/I+100)-B五、程序清单五、程序清单ADS7841 驱动程序驱动程序#include #include #include delay.h#include ads7

19、841.h#include LCD1602.h/-ADS7841 控制字节-#define control_byte 0b10011000/bit val description/bit7 1 start,恒为 1/bit6,5,4 001 选择 CH0 为+IN/bit4 1 选择为单端输入/bit2 X 外部 MODE 接 GND,该位无作用,恒为 12 位/bit1,0 00 转换期间 ADC 为掉电模式void port_init(void) PORTA = 0 xFF;/将所有端口初始化为输入,打开上拉 DDRA = 0 x00; PORTB = 0 xFF; DDRB = 0 x0

20、0; PORTC = 0 xFF; DDRC = 0 x00; PORTD = 0 xFF; DDRD = 0 x00; PORTE = 0 xFF; DDRE = 0 x00; PORTF = 0 xFF; DDRF = 0 x00; PORTG = 0 xFF; DDRG = 0 x00;void main() unsigned int result; unsigned char i,array4,table=0123456789; port_init(); /端口初始化 LCD1602_init(); /1602 液晶初始化 ads7841_init(); /ADS7841 初始化 LC

21、D_write_string(0 x80,result:); while(1) ads7841_start(); /启动 ADS7841,即拉低 CS delay_nus(10); result=ads7841_W_R(control_byte); /发送控制字,并得到转换数据 result&=0b0000111111111111; /屏蔽掉高四位 delay_nus(10); ads7841_finish(); /停止 ADS7841,即拉高 CS for(i=0;i4;i+) /以下均为显示部分 arrayi=result%10;/ esult/=10; for(i=0;i4;i+

22、) LCD_write_onechar(0 x87+i,tablearray3-i); delay_nms(300);#ifndef _ads7841_h#define _ads7841_hdefine DCLK PD0#define DCLK_ddr DDRD#define DCLK_port PORTD#define DCLK_pin PIND#define CS PD1#define CS_ddr DDRD#define CS_port PORTD#define CS_pin PIND#define DIN PD2#define DIN_ddr DDRD#define DIN_port

23、PORTD#define DIN_pin PIND#define BUSY PD3#define BUSY_ddr DDRD#define BUSY_port PORTD#define BUSY_pin PIND#define DOUT PD4#define DOUT_ddr DDRD#define DOUT_port PORTD#define DOUT_pin PINDdefine ads7841_start() CS_port&=(1CS) /启运 ADS7841#define ads7841_finish() CS_port|=(1CS) /停止 ADS7841void ads7

24、841_init(void);unsigned int ads7841_W_R(unsigned char byte);#endif#include #include #include delay.h#include ads7841.h/* * 函数名称:ads7841_init()* * 函数功能:初始化 ADS7841 端口* * 备 注:无*/void ads7841_init(void)DCLK_port&=(1DCLK); /时钟端初始化为输出低电平DCLK_ddr|=(1DCLK);CS_port|=(1CS); /片选端初始化为输出高电平CS_ddr|=(1CS); /即

25、不选中 ADS7841DIN_port&=(1DIN); /数据输入端初始化为输出低电平DIN_ddr|=(1DIN);BUSY_port|=(1BUSY); /忙信号初始化为输入,打开上拉BUSY_ddr&=(1BUSY);DOUT_port|=(1DOUT); /数据输出初始化为输入,打开上拉DOUT_ddr&=(1DOUT);/* * 函数名称:ads7841_W_R* * 函数功能:向 ADS7841 写入控制字节,读出转换好的数* * 输入参数:unsigned char byte : 控制字节 unsigned int result: AD 转换好的数* * 备 注:数据从高位到低位写入,从高位到低位读出*/unsigned int ads7841_W_R(unsigned char byte)unsigned char i,temp;unsigned int result=0;for(i=0;i8;i+) /8 位数据计数 DCLK_port&=(1DCLK); /拉低时钟端 if(byte&0 x80) /当前位是否是 1 DIN_port|=(1DIN); /当前位

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论