水温控制系统有程序_第1页
水温控制系统有程序_第2页
水温控制系统有程序_第3页
水温控制系统有程序_第4页
水温控制系统有程序_第5页
已阅读5页,还剩39页未读 继续免费阅读

下载本文档

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

文档简介

1、水温控制系统(c题)重庆大学光电工程学院 参赛队员:吴 蔡 傅摘要 本水温控制系统是基于msp430单片机为主控芯片,键盘输入设定温度,并在lcd1602上显示设定温度和实时温度。通过ds18b20温度传感器对水温进行采样,将采得的数字温度信号送给单片机,单片机对温度进行pid算法,通过改变加热控制方波的占空比达到精确控制温度的目的。本水温控制系统的静态误差0.2c,当设定的温度比实时温度高0.12c时,则启动风扇降温,10分钟左右到达稳定状态。本系统能够很精确地实现水温控制,是一个很好的水温控制方案。关键字 msp430 pid算法 ds18b20温度传感器abstract:the temp

2、erature control system is based on the msp430 microcontroller as the master chip, control temperature is set through keyboard and the lcd1602 display the control temperature and the real-time temperature. temperature sensor ds18b20 samples the water temperature and sents the digital signal to the mi

3、crocontroller, the microcontroller on the temperature of pid algorithm changes the duty cycle of heating control square wave to achieve precise control of temperature. the temperature control system of static error 0.2 c.when the set temperature higher than the real-time temperature 0.12 c, then the

4、 fan starts to cool , reaching the steady state cost about 10 minutes. the system can achieve a very precise temperature control, this temperature control is a good program.keywords: msp430 pid algorithm temperature sensor ds18b20摘要11 方案论证与比较41.1 温度传感器的比较与选择41.2 控制器的选择41.3 加热器的比较与选择41.4 显示器的比较与选择52

5、系统设计52.1总体设计52.2 单元电路设计62.2.1 温度传感器电路设计62.2.2 键盘电路设计72.2.3 电热杯加热电路设计82.2.4 风扇冷却电路设计82.2.4 液晶显示电路设计93 软件设计103.1总体设计103.2 主函数103.3 温度获取函数113.4 端口1中断函数123.5键盘扫描函数133.6 液晶显示函数143.7信号控制函数154 系统测量165 结束语16参考文献16附录171 方案论证与比较1.1 温度传感器的比较与选择方案一、ad590是一种半导体集成电路,它是利用晶体管的 b-e 结压降的不饱和值 vbe 与热力学温 度 t 和通过发射极电流 i

6、的下述关系实现对温度的检测具有线性好,精度适中,灵敏度高,体积小,使用方便等优点。ad590d的输出形式有电流和电压两种形式,要将温度传感器采集的温度值经过ad转换,然后送入单片机进行处理。方案二、采用ds18b20数字温度传感器对水温进行采样,无需进行ad转换。将采集的值直接送入单片机进行处理。ds18b20测温范围 55+125,固有测温分辨率0.5,支持多点组网功能,多个ds18b20可以并联在唯一的三线上,最多只能并联8个,实现多点测温。在市面上ad590比ds18b20贵几倍,同时ad590的外围电路比ds18b20的复杂,就这价格和电路实现难易的考虑,本系统选择方案二。1.2 控制

7、器的选择方案一、采用最简单的51单片机处理温度数据、键盘的输入和lcd的显示。利用51单片机的优点是价格便宜,使用比较方便,缺点是接口少,使用时需扩展,外围电路比较多,运算处理速度不高,功耗高。方案二、利用msp430对温度数据等进行处理,处理能力强、运算速度快、超低功耗、片内资源丰富、方便高效的开发环境。对于实现本系统的功能绰绰有余。综合比较以上两个方案,本系统选择方案二。1.3 加热器的比较与选择方案一、将搪瓷器皿直接放在加热炉上进行加热,方便简单,很容易实现,但是缺点是对于加热一升水能源浪费比较大,不能完全有效地利用加热炉,同时加热炉功率较大,不能很好地精确地控制水温。方案二、用电热杯对

8、一升水进行加热,电热杯功率较小(300w),能够实现很好地精确控制,同时电热杯使用方便,体积小,质量轻,价格便宜。综合比较上面两个方案,本系统选择方案二。1.4 显示器的比较与选择方案一、采用tft_lcd作为显示温度值的器件。每个液晶像素点都是由集成在像素点后面的薄膜晶体管来驱动,从而可以做到高速度、高亮度、高对比度显示屏幕信息,是目前最好的lcd彩色显示设备之一。方案二、采用lcd1602作为显示温度值的器件。lcd1602是工业字符型液晶,能够同时显示16x2个字符,1602采用标准的16脚接口,其中包括8根数据线,三根控制线,电源、地、就液晶驱动电压引脚。使用方便,价格适中。由于本系统

9、只需要显示温度值,对分辨率和颜色方面要求不高,所以综合价格和系统需求考虑,本系统选择方案二。2 系统设计2.1总体设计该系统控制核心采用msp430f149单片机,采用4x4矩阵键盘作为设定温度的输入,采用lcd1602显示数据,采用ds18b20单线温度传感器,单片机通过控制两个继电器,达到分别控制风扇和电热杯的目的。 图1 总体设计框架图2.2 单元电路设计 2.2.1 温度传感器电路设计图2ds18b20采用一总线技术,在使用时需在外部接一个上拉电阻(取经验值4.7k),在总线闲置时为高电平。信息通过单总线接口将数字温度值送入单片机进行处理和显示。ds18b20的特性:(1) 电压范围为

10、3.05.5v,在寄生电源方式下可由数据线供电。(2) 温度使用范围为-55c +125c,在-10c +85c时精度为0.5c。(3) 可编程的分辨率为912位,对应的课分辩温度为0.5c、0.25c、0.125c和0.0625c,可实现高精度测量。(4) 具有负电压特性。2.2.2 键盘电路设计图3键盘的行列线接入单片机的p1口,当有键按下时就会产生中断信号(p1口的每一个位都可以产生中断信号),然后进入中断程度,对键盘进行扫描,确定按键的值。 表一 键盘功能键表行列一二三四i1234ii5678iii90确定iv清除2.2.3 电热杯加热电路设计图4当单片机p5.5脚输出高电平时,三极管

11、8050导通,从而固态继电器打到no端,电热杯与220v交流电形成通路,对水进行加热。二级管in4148固态继电器起着保护作用。2.2.4 风扇冷却电路设计图5当实时温度比设定的温度高出0.12c时,p5.7输出高电平,导通8050,从而使固态继电器打到no端是风扇工作,对水降温。风扇由5v直流电源驱动。2.2.4 液晶显示电路设计图6p3.0、p3.1、p3.2接lcd1602的三个控制引脚,p4口作为lcd1602的数据接口。通过对控制引脚的控制,从而实现温度显示的功能。3 软件设计3.1总体设计总程序一共包含五个c文件,程序结构框图如图7所示:main.c系统初始化调用各种初始化函数端口

12、1(键盘)中断循环执行温度获取函数ds18b20.c温度获取函数写入各种控制命令读取温度转换结果将数字温度转换为bcd码keypad.c键盘初始化按键判断获取键值延时消抖lcd1602.c液晶初始化显示单个字符显示多个字符显示一个字符串control.c显示键盘输入的温度实时与设定温度进行比较pid算法获取控制信号看门狗定时控制加热时间图7 总程序结构框图 开始系统初始化键盘初始化lcd初始化i/o端口初始化温度获取函数图8 主函数流程图3.2 主函数主函数流程图如图8所示yn传感器初始化发送skip命令初始化成功否开始发 送温度转换命令延 时发送skip命令发 送读scratchpad命令读

13、 取温度转换结果将二进制温度转换为可显示的十进制数逐位显示温度确定键按下否温度比较函数返回yn3.3 温度获取函数温度获取函数流程图如图9所示图9 温度获取函数流程图3.4 端口1中断函数端口1(键盘)中断函数如图10所示中断开始中断返回数字键键值判断及获取函数键值性质逐位显示在lcd1602上将输入温度转换为二进制数置位标志位各种控制信号初始化键盘初始化清除键确定键图10 端口1中断函数3.5键盘扫描函数键盘扫描函数流程图如图11所示图11 键盘扫描函数流程图 3.6 液晶显示函数液晶显示函数流程图如图12所示图12 液晶显示函数流程图3.7信号控制函数信号控制函数流程图如图13所示图13

14、信号控制函数流程图4 系统测量经过系统对温控系统加热的过程录像,然后加热时间段每5秒记一次数,到达60度是每2秒记一个数据,最后将获得的数据在matlab中画出相应图。图14 温控响应图 图 15 局部放大图 表2 峰值时间稳定时间超调量6.93min7.30min2.8%5 结束语 由于系统架构设计合理,功能电路实现较好,系统性能优良、稳定,较好地达到了题目要求的各项指标。参考文献1 曹磊msp430单片机c程序设计与实践北京航空航天出版社,2007.52 张德丰matlab控制系统设计与仿真电子工业出版社,2009.63 杨邦文新型继电器实用手册人民邮电出版社,2004.64 岂兴明 唐杰

15、51单片机编程基础与开发实例详解人民邮电出版社,2008.115 杨素行模拟电子技术基础简明教程高等教育出版社,2008.46 阎石数字电子技术基础高等教育出版社,2009.12 附录附录1 系统总电路图附录2 元件清单1c1, c3capacitor polcapacitor10uf2c2, c4, c7capcapacitor1043c5, c6capcapacitor33pf4d1ledled5d2, d3diodediodein41486f1fengshanfengshan7j1con4connectorusb8jp1header 7x2jtag9k1, k2relay-spdtrel

16、ay-spdt10l1lcd1602lcd160211msp430f149ipm1msp430f149ipmmsp430f149ipmmsp430f149ipm12q1, q2npn1npn transistor805013r1res2res214r2res24.7k15r3res_dlsres_dls16r4res200017r5res2100k18r6, r7, r8res21k19r9, r10, r11, r12res25.1k20s1sw-spstsw-spst21s2sw-pbsw-pb22s3, s4, s5, s6, s7, s8, s9, s10, s11, s12, s13

17、, s14, s15, s16, s17, s18buttonbutton23u1volvol24u2ds18b20ds18b2025y1crystalcrystal8m26y2crystalcrystal32.768k说明本系统采用的是msp430f149单片机,软件用的是ira embedded workbench4.20.1版本。并附开发板原理图此系统程序包含键盘扫描程序,温度获取程序(ds18b20),lcd1602显示程序,pid算法程序,以及控制程序。目录main.c2keypad.h4lcd1602.h7ds18b20.h13control.h21pid算法程序24main.c#

18、include #include keypad.h#include lcd1602.h#include ds18b20.h#include control.htypedef unsigned char uchar;typedef unsigned int uint;void initsys(); /函数声明int main(void) wdtctl=wdtpw+wdthold; /关闭看门狗 /*下面六行程序关闭所有的io口*/ p1dir = 0xff;p1out = 0xff; p2dir = 0xff;p2out = 0xff; p3dir = 0xff;p3out = 0xff; p4

19、dir = 0xff;p4out = 0xff; p5dir = 0xff;p5out = 0xff; p6dir = 0xff;p6out = 0xff; p6dir |= bit2;p6out |= bit2; /关闭电平转换 initsys(); /系统初始化 init_keypad(); /键盘初始化 lcdreset(); /lcd初始化 start: disp_18b20(); goto start; /*系统初始化*/void initsys() unsigned int iq0; bcsctl1 &= xt2off; /打开xt2振荡器 do ifg1 &= ofifg; /清

20、除振荡器失效标志 for(iq0=0xff;iq00;iq0-);/延时,等待xt2起振 while(ifg1 & ofifg)!=0); /判断xt2是否起振 bcsctl2=selm_2+sels; /选择mclk,smclk为xt2 tactl |= tassel_2 + id_3; /计数时钟选择smlk=8mhz,1/8分频后为1mhz p5dir |= bit5; /加热器控制端口 p5out &= bit5; p5dir |= bit7; /风扇控制端口 p5out &= bit7; _eint(); /打开全局中断控制,若不需要打开,可以屏蔽本句/*端口1(键盘)中断函数*/#

21、pragma vector=port1_vector_interrupt void port1() key_event(); /判断按键并获取键值 if(key_val16) /输入为数字键 temp_disp(); else if(key_val=12) /输入为确定键 sure=1; temp_set_2=ten2two(); else if(key_val=13) /输入为清除键 temp_clr(); init_keypad(); /键盘初始化keypad.hvoid init_keypad(void);void check_key(void);void delay(unsigned

22、int tmp);void key_event(void);/引用外部变量的声明extern unsigned char key_pressed; extern unsigned char key_val; extern unsigned char key_flag;keypad.c#include typedef unsigned char uchar;typedef unsigned int uint;/*全局变量*/uchar key_pressed; /按键是否被按下:1-是,0-否uchar key_val; /存放键值uchar key_flag; /按键是否已放开:1-是,0-否

23、/设置键盘逻辑键值与程序计算键值的映射uchar key_map = 1,2,3,4,5,6,7,8, 9,0,11,12,13,14,15,16;/k12,清除键。k13,确定键/*init_keypad:初始化扫描键盘的io端口 */void init_keypad(void) p1dir = 0xf0; /p1.0p1.3设置为列输入, p1.4p1.7设置为行输出 p1out=0x0f; / p1.4p1.7输出低电平 p1ifg=0x00; p1sel=0; /p1口设置为一般i/o端口 p1ies=0x0f; p1ie=0x0f; /p1低四位中断开启 key_flag = 0;

24、key_pressed = 0; key_val = 0;/*延时约15ms,完成消抖功能*/void delay(uint tmp) for(;tmp 0;tmp-);/*扫描键盘的io端口,获得键值*/void check_key(void) uchar row ,col,tmp1,tmp2; tmp1 = 0x80; for(row = 0;row =1; if (p1in & 0x0f) 0x0f) /是否p1in的p1.0p1.3中有一位为0 tmp2 = 0x01; / tmp2用于检测出那一位为0 for(col = 0;col 4;col+) / 列检测 if(p1in & t

25、mp2) = 0x00) / 是否是该列,等于0为是 key_val = key_maprow * 4 + col; / 获取键值 return; / 退出循环 tmp2 = 1; / tmp2右移1位 /*检测按键,并获取键值*/void key_event(void) uchar tmp; p1out &= 0x00; / 设置p1out全为0,等待按键输入 tmp = p1in; / 获取 p1in if (key_pressed = 0x00)&(tmp & 0x0f) 0x0f) /如果有键按下 key_pressed = 1; / 如果有按键按下,设置key_pressed标识 d

26、elay(1200); /消除抖动 check_key(); / 调用check_key(),获取键值 else if (key_pressed = 1)&(tmp & 0x0f) = 0x0f) /如果按键已经释放 key_pressed = 0; / 清除key_pressed标识 key_flag = 1; / 设置key_flag标识 else _nop(); lcd1602.hvoid dispstr(unsigned char x,unsigned char y,unsigned char *ptr);void dispnchar(unsigned char x,unsigned

27、char y, unsigned char n,unsigned char *ptr);void locatexy(unsigned char x,unsigned char y);void disp1char(unsigned char x,unsigned char y,unsigned char data);void lcdreset(void);void lcdwritecommand(unsigned char cmd,unsigned char chk);void lcdwritedata( unsigned char data );void waitforenable(void)

28、;void delay5ms(void);void delay400ms(void);extern unsigned char temp_set;lcd1602.c#include #include lcd1602.h#include keypad.htypedef unsigned char uchar;typedef unsigned int uint;uchar temp_set=temp set:_._;uchar temp_now=temp now:;/*宏定义*/#define datadir p4dir#define dataport p4out#define busy 0x80

29、#define ctrldir p3dir#define clr_rs p3out&=bit0; /rs = p3.0#define set_rs p3out|=bit0;#define clr_rw p3out&=bit1;/rw = p3.1#define set_rw p3out|=bit1;#define clr_en p3out&=bit2;/en = p3.2#define set_en p3out|=bit2;/*让液晶从某个位置起连续显示一个字符串x-位置的列坐标y-位置的行坐标ptr-指向字符串存放位置的指针*/void dispstr(uchar x,uchar y,uch

30、ar *ptr) uchar *temp; uchar i,n = 0; temp = ptr; while(*ptr+ != 0) n+; /计算字符串有效字符的个数 for (i=0;in;i+) disp1char(x+,y,tempi); if (x = 0x0f) x = 0; y = 1; /*让液晶从某个位置起连续显示n个字符x-位置的列坐标y-位置的行坐标n-字符个数ptr-指向字符存放位置的指针*/void dispnchar(uchar x,uchar y, uchar n,uchar *ptr) uchar i; for (i=0;in;i+) disp1char(x+,

31、y,ptri); if (x = 0x0f) x = 0; y = 1; /*功 能:向液晶输入显示字符位置的坐标信息参 数:x-位置的列坐标 y-位置的行坐标*/void locatexy(uchar x,uchar y) uchar temp; temp = x&0x0f; y &= 0x01; if(y) temp |= 0x40; /如果在第2行 temp |= 0x80; lcdwritecommand(temp,1);/*功 能:在某个位置显示一个字符参 数:x-位置的列坐标 y-位置的行坐标 data-显示的字符数据*/void disp1char(uchar x,uchar y

32、,uchar data) locatexy( x, y ); lcdwritedata( data );/*lcdreset:对1602液晶模块进行复位操作*/void lcdreset(void) ctrldir |= 0x07; /控制线端口设为输出状态 datadir = 0xff; /数据端口设为输出状态 lcdwritecommand(0x38, 0); /规定的复位操作 delay5ms(); lcdwritecommand(0x38, 0); delay5ms(); lcdwritecommand(0x38, 0); delay5ms(); lcdwritecommand(0x3

33、8, 1);/显示模式设置 lcdwritecommand(0x08, 1);/显示关闭 lcdwritecommand(0x01, 1); /显示清屏 lcdwritecommand(0x06, 1);/写字符时整体不移动 lcdwritecommand(0x0c, 1);/显示开,不开游标,不闪烁 dispnchar(0,0,14,temp_set); /显示预设温度提示 dispnchar(0,1,9,temp_now); /显示实时温度提示/*函数名称:lcdwritecommand功 能:向液晶模块写入命令参 数:cmd-命令, chk-是否判忙的标志,1:判忙,0:不判*/void

34、 lcdwritecommand(uchar cmd,uchar chk) if (chk) waitforenable(); / 检测忙信号? clr_rs; clr_rw; _nop(); dataport = cmd; /将命令字写入数据端口 _nop(); set_en; /产生使能脉冲信号 _nop(); _nop(); clr_en;/*函数名称:lcdwritedata功 能:向液晶显示的当前地址写入显示数据参 数:data-显示字符数据返回值 :无*/void lcdwritedata( uchar data ) waitforenable(); /等待液晶不忙 set_rs;

35、 clr_rw; _nop(); dataport = data; /将显示数据写入数据端口 _nop(); set_en; /产生使能脉冲信号 _nop(); _nop(); clr_en;/*函数名称:waitforenable功 能:等待1602液晶完成内部操作*/void waitforenable(void) p4dir &= 0x00; /将p4口切换为输入状态 clr_rs; set_rw; _nop(); set_en; _nop(); _nop(); while(p4in & busy)!=0); /检测忙标志 clr_en; p4dir |= 0xff; /将p4口切换为输

36、出状态 /*delay5ms:延时约5ms*/void delay5ms(void) uint i=40000; while (i != 0) i-; /*delay400ms:延时约400ms*/void delay400ms(void) uchar i=50; uint j; while(i-) j=7269; while(j-); ds18b20.hvoid delaynus(unsigned int n);unsigned char init_18b20(void);void write_18b20(unsigned char wdata);unsigned char read_18b

37、20(void);void skip(void);void convert(void);void read_sp(void);unsigned int readtemp(void);unsigned int do1convert(void);void disp_numb(unsigned int temper);void disp_18b20(void);extern unsigned char dn6; /要显示的6位温度数字extern unsigned int temp_now_2; /温度值的十六进制存储ds18b20.c#include #include ds18b20.h#include lcd1602.h#include control.htypedef unsigned char uchar;typedef unsigned int uint;#define dq1 p5out |= bit6#define dq0 p5out &= bit6#define dq_in p5dir &= bit6#define dq_out p5dir |= bit6#define dq_val (

温馨提示

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

评论

0/150

提交评论