ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:199.47KB ,
资源ID:3960469      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/3960469.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(智能温度测量仪课程设计.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

智能温度测量仪课程设计.docx

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

2、为常数, 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.2.2 PT100传感器测量原理Pt100是电阻式温度传感器,测温的本

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

4、的输出脚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. 运放采用单一5V供电,如果测量的温度波动比较大,将运放的供电改为15V双电源供电会有较大改善。3

5、. 电阻R2、R3的电阻值取得足够大,以增大运放的U1B的输入阻抗。 图1恒流源式测温电路由于封装问题,实际原理图如下:方案二:采用惠斯顿电桥,电桥的四个电阻中三个是恒定的,另一个用Pt100 热电阻,当Pt100电阻值变化时,测试端产生一个电势差,由此电势差换算出温度。 测温原理:电路采用TL431和电位器VR1调节产生4.096V的参考电源;采用R1、R2、VR2、Pt100构成测量电桥(其中R1R2,VR2为100精密电阻),当Pt100的电阻值和VR2的电阻值不相等时,电桥输出一个mV级的压差信号,这个压差信号经过运放LM324放大后输出期望大小的电压信号,该信号可直接连AD转换芯片。

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

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

8、OMFlash Programmable and Erasable Read Only Memory)的低电压、高性能CMOS 8位微处理器,俗称单片机。AT89C2051是一种带2K字节闪存可编程可擦除只读存储器的单片机。单片机的可擦除只读存储器可以反复擦除1000次。该器件采用ATMEL高密度非易失存储器制造技术制造,与工业标准的MCS-51指令集和输出管脚相兼容。由于将多功能8位CPU和闪烁存储器组合在单个芯片中,ATMEL的AT89C51是一种高效微控制器,AT89C2051是它的一种精简版本。AT89C51单片机为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。1.4 LCD显示器

9、 液晶显示器是一种采用了液晶控制透光度技术来实现色彩的显示器。和CRT显示器相比,LCD的优点是很明显的。由于通过控制是否透光来控制亮和暗,当色彩不变时,液晶也保持不变,这样就无须考虑刷新率的问题。对于画面稳定、无闪烁感的液晶显示器,刷新率不高但图像也很稳定。LCD显示器还通过液晶控制透光度的技术原理让底板整体发光,所以它做到了真正的完全平面。二、系统总体设计测温的模拟电路是把当前PT100热电阻传感器的电阻值,转换为容易测量的电压值,经过放大器放大信号后送给A/D转换器把模拟电压转为数字信号后传给单片机AT89C51,单片机再根据公式换算把测量得的温度传感器的电阻值转换为温度值,并将数据送出

10、到LCD显示器进行显示。本设计系统主要包括温度信号采集单元,单片机数据处理单元,温度显示单元。其中温度信号的数据采集单元部分包括温度传感器、温度信号的获取电路(采样)、放大电路、A/D转换电路。系统的总结构框图如图1-1所示。 1-1 系统的总结构框图 本温度测量系统设计,是采用PT100温度传感器经过放大和A/D转换器送到单片机进行控制温度显示。另外本系统还可以通过外接电路扩展实现温度报警功能,从而更好的实现温度现场的实时控制。三、硬件设计3.1放大电路的设计本次放大电路我选用的是LM358,其内部包括有两个独立的、高增益、内部频率补偿的双运算放大器,适合于电源电压范围很宽的单电源使用,也适

11、用于双电源工作模式,在推荐的工作条件下,电源电流与电源电压无关。它的使用范围包括传感放大器、直流增益模块和其他所有可用单电源供电的使用运算放大器的场合。3.2信号调理电路调理电路的作用是将来自于现场传感器的信号变换成前向通道中A/D转换器能识别的信号,作为本系统,由于温度传感器是热电阻PT100,因此调理电路完成的是怎样将与温度有关的电阻信号变换成能被A/D转换器接受的电压信号。3.3 A/D转换器的选择与设计电路在我们所测控的信号中均是连续变化的物理量,通常需要用计算机对这些信号进行处理,则需要将其转换成数字量,A/D转换器就是为了将连续变化的模拟量转换成计算机能接受的数字量。根据A/D转换

12、器的工作原理,常用的A/D转换器可分为两种,双积分式A/D转换器和逐次逼近式A/D转换器。1. 双积分A/D转换器工作原理2. 逐次逼近型A/D转换器工作原理在本设计系统中,为了将模拟量温度转换成数字量,采用德州仪器公司生产的4通道12位串行输出采样模数转换器ADS7841。具体连线如下图所示:3.4单片机控制电路本设计是采用AT89C51单片机作为主控电路,AT89C51单片机是Atmel公司的产品,与Intel 公司的MCS51系列兼容。在AT89C51单片机内部有作为程序存储器的Flash存储器,其容量为4KB,可以承受不低于1000次的反复擦写,调试比较方便。其中P1口为A/D转换器的

13、通信端口,P2口为按键控制,P0口为LCD的数据端口,具体电路图如下:3.5按键和显示电路本次设计使用4x4矩阵键盘,将其行线以及列线接到单片机的P2口,其中列线接上拉电阻然后在通过异或逻辑门在接至单片机的P2.0到P2.3口。具体连线如下图所示:3.6显示电路本次设计使用LCD12864来显示温度采集结果,其中将LCD的数据口接入单片机的P0口,具体接线如下图所示: 四、软件设计4.1软件的流程图 图1 系统总流程图 图2 温度转换程序流程图 图3 显示流程图 图4 主函数流程图4.2系统软件设计说明进行微机测量控制系统设计时,除了系统硬件设计外,大量的工作就是如何根据每个测量对象的实际需要

14、设计应用程序。因此,软件设计在微机测量控制系统设计中占重要地位。对于本系统,软件设计更为重要。在单片机测量控制系统中,大体上可分为数据处理、过程控制两个基本类型。数据处理包括:数据的采集、数字滤波、标度变换等。过程控制程序主要是使单片机按一定的方法进行计算,然后再输出,以便达到测量控制目的。软件设计主要是对温度进行采集、显示,通过按键操作,进行时间的设置与修改。因此,整个软件可分为温度采集子程序、时钟读取程序、按键子程序、显示子程序、及系统主程序。4.3软件的有关算法4.3.1最小二乘理论获取温度电阻公式 根据误差理论,我们要获得较高精度的温度测量值,办法一般有2个,要么采用查表法,要么建立高

15、精度的数学模型。如果用查表法,主要有2个问题,如果要提高测量精度,则需要建立大量的表格,而且得提前做大量得试验来进行多点校正,还有一个问题是程序的通用性差,这台仪器上校正好得数据可能在另一台上不合适。而采用已知的分度表,建立数学模型,然后通过工程量(标度)变换,通过测量A/D转换的结果后计算得到。这里我们考虑第2种方法的优点,首先采用分段的方法,将测量范围分段,然后查出该段的数学模型的各个系数,然后计算出温度值,这里,由于时间的关系,我们对整个测量范围分了3段,分别为049、5070、71100,利用分度表进行离线的数学拟合,得到各段的数学模型系数。同时,可通过再将标度值代入可粗略估计在各个测

16、量段内的最大误差值。 我们通过最小二乘法进行线性拟合,得到如下的数学模型为: 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标度变换公式的获取根据上述的线性拟合结果:T=AR-B,这里的A、B是上述不同温度段的系数,而R值由于在输出为0V时,实际上有个对应于100欧姆的偏置电路,因此根据R-R0=U/I,而I=2.500V/1.500K,而AD/

17、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 ads7841.h#include LCD1602.h/-ADS7841控制字节-#define control_byte 0b10011000/bit val description/bit7 1 start,恒为1/bit6,5,4 001 选择CH0为+IN/bit4 1 选择为单端输

18、入/bit2 X 外部MODE接GND,该位无作用,恒为12位/bit1,0 00 转换期间ADC为掉电模式void port_init(void) PORTA = 0xFF;/将所有端口初始化为输入,打开上拉 DDRA = 0x00; PORTB = 0xFF; DDRB = 0x00; PORTC = 0xFF; DDRC = 0x00; PORTD = 0xFF; DDRD = 0x00; PORTE = 0xFF; DDRE = 0x00; PORTF = 0xFF; DDRF = 0x00; PORTG = 0xFF; DDRG = 0x00;void main() unsigned

19、 int result; unsigned char i,array4,table=0123456789; port_init(); /端口初始化 LCD1602_init(); /1602液晶初始化 ads7841_init(); /ADS7841初始化 LCD_write_string(0x80,result:); while(1) ads7841_start(); /启动ADS7841,即拉低CS delay_nus(10); result=ads7841_W_R(control_byte); /发送控制字,并得到转换数据 result&=0b0000111111111111; /屏蔽掉

20、高四位 delay_nus(10); ads7841_finish(); /停止ADS7841,即拉高CS for(i=0;i4;i+) /以下均为显示部分 arrayi=result%10;/ esult/=10; for(i=0;i4;i+) LCD_write_onechar(0x87+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#def

21、ine CS PD1#define CS_ddr DDRD#define CS_port PORTD#define CS_pin PIND#define DIN PD2#define DIN_ddr DDRD#define DIN_port 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_

22、pin PINDdefine ads7841_start() CS_port&=(1CS) /启运ADS7841#define ads7841_finish() CS_port|=(1CS) /停止ADS7841void ads7841_init(void);unsigned int ads7841_W_R(unsigned char byte);#endif#include #include #include delay.h#include ads7841.h/* * 函数名称:ads7841_init()* * 函数功能:初始化ADS7841端口* * 备 注:无*/void ads784

23、1_init(void)DCLK_port&=(1DCLK); /时钟端初始化为输出低电平DCLK_ddr|=(1DCLK);CS_port|=(1CS); /片选端初始化为输出高电平CS_ddr|=(1CS); /即不选中ADS7841DIN_port&=(1DIN); /数据输入端初始化为输出低电平DIN_ddr|=(1DIN);BUSY_port|=(1BUSY); /忙信号初始化为输入,打开上拉BUSY_ddr&=(1BUSY);DOUT_port|=(1DOUT); /数据输出初始化为输入,打开上拉DOUT_ddr&=(1DOUT);/* * 函数名称:ads7841_W_R* *

24、函数功能:向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&0x80) /当前位是否是1 DIN_port|=(1DIN); /当前

25、位是1,拉高数据端 else DIN_port&=(1DIN); /当前位是0,拉低数据端 delay_nus(10); /调整时钟和脉冲宽度 DCLK_port|=(1DCLK); /时钟上升沿 delay_nus(10); byte=1; /数据左移1位,为送出新数据位做准备 delay_nus(10);DCLK_port&=(1DCLK); /拉低时钟端delay_nus(10);i=BUSY_pin; /读BUSY的状态delay_nus(10);if(i&(1BUSY) /如果为高则说明转换完成,应将其读出/-以下先读出高八位- for(i=1;i=8;i+) result=1; /

26、保存读入的数据位 DCLK_port|=(1DCLK); /时钟上升沿 delay_nus(10); DCLK_port&=(1DCLK); /拉低时钟端 elay_nus(10); if(DOUT_pin&(1DOUT) result|=0x01; else result&=0xfe; /-以下读出低四位- for(i=1;i=4;i+) temp=1; /保存读入的数据位 DCLK_port|=(1DCLK); /时钟上升沿 delay_nus(10); DCLK_port&=(1DCLK); /拉低时钟端 delay_nus(10); if(DOUT_pin&(1DOUT) temp|=0x01; else temp&=0xfe; for(i=1;i=4;i+) /再给ADS7841四个时钟 DCLK_port|=(1DCLK); /时钟上升沿 delay_nus(10); /调整时钟和脉冲宽度 DCLK_port&=(1DCLK); /拉低时钟端 delay_nus(10); /调整时钟和脉冲宽度 result=(result4)+temp; /将结果合成,返回return result;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1