计算机控制课程设计电加热炉计算机温度控制系统设计.doc

上传人:laozhun 文档编号:2882159 上传时间:2023-03-01 格式:DOC 页数:17 大小:289KB
返回 下载 相关 举报
计算机控制课程设计电加热炉计算机温度控制系统设计.doc_第1页
第1页 / 共17页
计算机控制课程设计电加热炉计算机温度控制系统设计.doc_第2页
第2页 / 共17页
计算机控制课程设计电加热炉计算机温度控制系统设计.doc_第3页
第3页 / 共17页
计算机控制课程设计电加热炉计算机温度控制系统设计.doc_第4页
第4页 / 共17页
计算机控制课程设计电加热炉计算机温度控制系统设计.doc_第5页
第5页 / 共17页
点击查看更多>>
资源描述

《计算机控制课程设计电加热炉计算机温度控制系统设计.doc》由会员分享,可在线阅读,更多相关《计算机控制课程设计电加热炉计算机温度控制系统设计.doc(17页珍藏版)》请在三一办公上搜索。

1、目 录 引言1 系统设计及其工作原理1.1 设计内容11.2 系统工作原理1 1.3 系统方案的确定.22硬件设计2.1 单片机连接电路22.2 温度检测电路32.3 AD转换电路32.4 LED温度显示电路42.5 按键和报警电路42.6 加热控制电路部分53软件部分设计3.1 周期采样程序53.2 数字滤波程序63.3 PID程序73.4 总程序84 总结与心得体会.9参考文献.10附录.11 引 言 温度是工业对象中一种重要的参数,特别在冶金、化工、机械各类工业中,广泛使用各种加热炉、热处理炉和反应炉等。由于炉子的种类不同,因此所采用的加热方法及燃料也不同,如煤气、天然气、油和电等。但是

2、就其控制系统本身的动态特性来说,基本上都属一阶纯滞后环节,因而在控制算法上亦基本相同。实践证明,用微型计算机对炉窑进行控制,无论在提高产品质量和数量,节约能源,还是在改善劳动条件等方面都显示出无比的优越性。1 系统设计及其工作原理1.1 设计内容某工业电炉在对产品进行加工的过程中,炉温从室温上升到1000应为30min,然后温度保持到1000,其时间为1小时。最后断电,使电炉自然冷却。电炉的加热源是热阻丝,利用大功率可控硅控制热阻丝两端所加的电压大小,来改变流经热阻丝的电流,从而改变电炉炉内的温度。炉温控制的基本原理是:改变可控硅的导通角即改变电热炉加热丝两端的有效电压,有效电压可在0140V

3、内变化。温度传感器是通过一只热敏电阻及其放大电路组成,温度越高其输出电压越小。外部LED灯的亮灭表示可控硅的导通与关断的占空比时间,如果炉温低于设定值则可控硅导通,系统加热,否则系统停止加热,炉温自然冷却到设定值。设计要求为:一个以单片机为核心,包括主要过程输入输出通道及主要接口,外配LED显示、键盘操作以及包括传感变送器及执行器的小型计算机控制系统。 1.2 系统工作原理 该控制系统使用单片机作为微处理器,连接温度传感器、A/D转换、温度控制电路,并附加LED显示部分及键盘部分。它可以实时地显示温度,实现对温度的自动控制并设有报警电路。还可以通过键盘对PID参数进行设置。 该控制系统使用热电

4、阻测出电阻炉实际温度并转换成电压信号。此电压信号经过温度检测电路AD转换电路转换成与炉温相对应的数字信号送入单片机,而单片机经过数据处理后,控制显示部分显示温度。此外,将温度与设定值比较,根据设定计算出控制量,通过控制电阻丝两端交流电压的通断时间比例来实现电阻丝发热量的控制。1.3系统方案确定图1.系统结构图单片机温度控制系统是以 MS51 单片机为控制核心,辅以温度采样反馈电路,驱动电路,晶闸管主电路对电炉炉温进行控制的微机控制系统。系统的原理框图如图 1 所示,其基本控制原理为:用键盘将温度的设定值送入单片机,启动运行后,通过信号采集电路将温度信号采集到后,送到 A / D 转换电路将信号

5、转换成数字量送入单片机系统进行 PID 控制运算,将控制量输出,控制电阻炉的加热。2 硬件设计 控制系统的硬件设计是系统设计的基础,具有重要意义。主要设计内容包括温度测量、A/D转换、单片机系统、键盘操作系统、温度显示电路、报警电路、D/A转换等部分。下面分步介绍硬件电路设计方法。2.1 单片机连接电路本设计选用了ATMEL公司的AT89C52单片机,该型号单片机片内含8k bytes的可反复擦写的Flash只读程序存储器和256 bytes的随机存取数据存储器(RAM),器件采用ATMEL公司的高密度、非易失性存储技术生产,兼容标准MCS-51指令系统,片内置通用8位中央处理器和Flash存

6、储单元,内部集成了微处理器、储存器、I/O接口、定时/计数器、中断系统、串行接口等基本部件。完全能满足控制要求。最小实现系统示意图如下:图2 单片机最小系统2.2 温度检测电路温度传感器采用热电阻及其放大电路组成, 图3 温度检测电路2.3 AD转换电路AD转换是把从温度传感器送来的模拟量转换成温度数字量输送到单片机,以便可以用单片机进行控制。AD574在由单片机的控制下,可以在初始化程序中将B.C端置为高电平,DR端的状态由芯片内部决定,其初始化也是高电平,此刻输出总线处于高阻态状态。当B.C端输入低电平信号后,AD574便开始转换。此时,DR端及输出状态不变,经25s后转换结束,DR端变低

7、,延时500ns后,数据线上出现转换后的数据。当单片机取完数据后转换命令可以撤销,B/C端置高电平。在B/C变化后的1.5s,DR线随之自动变高,同时数据线呈现高阻态,一次转换完成。之一上次B/C命令撤销与下一次给出新的命令之间的时间间隔不得小于2us。A/D转换结束后,A/D输出芯片会输出转换结束信号,通过单片机读取转换数据。 图4AD转换电路2.4 LED温度显示电路 为了使操作人员能随时掌握每个炉子的温度的变化情况,设计了4位LED显示器,设显示缓冲单元为28H和29H:第一位指示通道号,第2到4号用来显示温度,最大为999度,原理图如下:图5温度显示电路2.5 按键和报警电路图6按键和

8、报警2.6 加热控制电路部分图7温度控制部分MOC3021可以即时触发,只要输入引脚1输入15mA的电流,输出端6引脚、4引脚之间就会导通,内部双向晶闸管导通,触发外部晶闸管导通,当MOC3021输入引脚输入电流为0时,内部双向晶闸管关断,从而外部晶闸管也关断,从而外部晶闸管也关断,通过单片机来控制导通和关断的时刻,从而实现智能调压。热阻丝两端用220V交流进行加热,因此要控制热阻丝功率,可以通过调功实现,即控制交流电的通断时间比例来实现。把交流电经全波整流后通过三极管变成过零脉冲,在反相后加到单片机的中断控制端作为同步基准脉冲。使用定时器T0计时移相时间Ta,然后发出触发脉冲,改变可控硅的导

9、通角即改变电热炉加热丝两端的有效电压,实现炉温控制。 3软件部分设计在该温度控制程序中,温度信号要经过周期采样、数字滤波、PID运算、输出等过程,其过程如图8所示。信号周期采样数字滤波PID运算输出图8 信号流程图3.1 周期采样程序在计算机内部,执行算法时,需要将外部信号进行离散化处理,因此需要对外部模拟信号进行周期采样。从理论上讲,采样频率越高,失真越小,但从控制器本身而言,大都依靠偏差信号E(k)进行调节器计算。当采样周期T太小时,偏差信号E(k),也会过小,此时计算机将会失去调节作用,而采样周期T过长又会引起误差。因此采样周期必须综合考虑,一般而言采样周期根据外部信号变化快慢而定,如在

10、该温度控制系统中,水箱温度变化比较缓慢,因此采样时间T应该适当大一些。其程流程图如图9。周期采样程序定时计数器初始化初值设置开定时计数器中断程序定时器重赋初值启动A/D转换读取转换结果图9 周期采样程流程图3.2 数字滤波程序在工业过程控制系统中,由于被控对象所处的环境比较恶劣,常存在干扰源,如环境温度、电场和磁场等,使得采样值可能偏离真实值。对于各种随机出现的干扰信号,在计算机控制系统中,应该对采样的数据进行判断,以及平滑加工,以提高信号的可信度,减小乃至消除各种干扰及噪声,以保证系统的可靠性。在该系统中,我选用限幅滤波。限幅滤波的基本思路是:求出本次采样值与前一次采样值之差,该差值与最大允

11、许差值比较,若小于或等于,则取本次采样值,若大于,则取上一次采样值,即:数字滤波程流程图如图10所示。温度输出数字滤波程序计算返回图10 数字滤波程序框图3.3 PID程序PID调节由比例调节、积分调节、微分调节三者组成,是技术最成熟、应用最广泛的一种调节方式。PID调节的实质就是根据输入的偏差值,按比例、积分、微分的函数关系进行运算,运算结果用于控制输出。在实际应用中,根据被控对象的特征和控制要求,课灵活地改变PID的结构,取其中一部分环节构成控制规律,如比例调节、比例积分调节、比例积分微分调节等。PID算法表达式: (1)离散化后的PID表达式: (2)在该系统中,选用位置型PID进行程序

12、设计,位置型PID输出表达式如下: (3)在进行程序编写时,一般将(3)式作一下改进: (4)根据该表达式,在计算机内进行具体的PID运算,PID程序流程图如图11。PID程序输入R(k)、M(k)计算计算计算计算计算返回图11 PID程序框图3.4 总程序当把以上程序都编好后,主程序只需要调用子程序即可,这样方便参数调整,以及程序修改,在该系统中主程序需要调用的子程序有:周期采样子程序、数字滤波子程序、PID运算子程序、输出子程序以及系统初始化。主程序程序流程图如图12。总程序初始化周期采样子程序数字滤波子程序PID子程序输出子程序返回图12 主程流程图4总结与心得体会本设计为电加热炉计算机

13、温度控制系统设计,我努力将微型计算机控制技术及单片机技术的理论知识付诸实践,独立完成了一个基于C51单片机的小型自动控制系统的设计。整个系统设计分为四部分:测量检测模块,控制调节,驱动执行,按键报警。软件采用了PID算法控制。整个设计做得比较仓促,其中可能存在一些问题,希望您能够理解。这份耗时近2周的课程设计终于完成了,总的来说,自己收获了很多有用的东西。在紧张而又充实的设计过程中,我认识到:它不单纯只是一个题目,而是要求我对大学三年来所学的知识都要弄懂,并且能够把它们熟练地运用出来,当我完成这份设计的时候,仿佛觉得自己又把大学重新过了一遍,其中的乐趣与收获是很难用言语来表达的。同时我也意识到

14、:在大学生涯结束之前,我不仅要掌握书本上的基本内容,还要灵活思考,善于变换,这样才能够在今后的运用过程中达到事半功倍的效果。毋庸置疑,只有不断的学习,实践,再学习,再实践,才能使自己不被社会淘汰。最后,我要感谢在这次课程设计过程中给予我莫大帮助的老师和同学们,我一定会更加努力,相信我会在毕业设计中做得更好!参考文献1 张荣标. 微型计算机原理与接口技术(第二版) 机械工业出版社,2009.22 谢维成 杨加国单片机原理与应用及C51程序设计(第二版)清华大学出版社,2009.73 王兆安 电力电子技术(第五版) 机械工业出版社,2009.54 李晓莹 传感器与测量技术 高等教育出版社,2002

15、5 付家才 单片机实验与实践 高等教育出版社,20046潘新民 王艳芳 微型计算机控制技术第2版 电子工业出版社 2011附录:控制系统主程序:PCTL8255EQU0F103HPC8255EQU0F102HPB8255EQU0F101HPA8255EQU0F100HLS3731EQU0F200HLS3732EQU0F300HDA1EQU0F400HDA2EQU0F500HDA3EQU0F600HDA4EQU0F700HDA5EQU0F800HDA6EQU0F900HDA7EQU0FA00HDA8EQU0FB00HAD574EQU0FC00HLS175EQU0FD00H;外部RAM地址分配CD

16、ATAEQU00H;数据采集单元首地址FDATAEQU50H;数字滤波后数据首地址SDATAEQU60H;标度变换后数据首地址SETTEMPEQU70H;设定温度首地址TEMPMAXEQU80H;报警上限给定值首地址TEMPMINEQU90H;报警下限给定值首地址FFDATAEQU0A0H;采样温度值首地址ALARMAXEQU00H;上限报警标志位首地址ALARMINEQU08H;下限报警标志位首地址COUNTEQU22H;采样次数单元CHADDREQU23H;采样通道号单元BUFFEQU24H;采样数据缓冲区DPLBUFFEQU25H;显示缓冲区FSETTEMPEQU26H;设定温度首地址C

17、OEFEQU3EH;数字控制器系数及缓冲单元 ORG0000HLJMPMAINORG0003HLJMPINT0ORG000BHLJMPINTT0ORG001BHLJMPINTT1;主程序ORG0100HMAIN:MOVSP,#69HMOVA,#80H;设置8255A工作方式MOVDPTR,#PCTL8255MOVXDPTR,AMOV20H,#00H;清上、下限报警标志单元MOV21H,#00H;清数据单元MOVR0,#00HMOVR1,#50HMOVA,#00HMOVP2,#0F0HCLEAR2:MOVXR0,AINCR0DJNZR1,CLEAR2;清中间结果单元MOVR0,#4DH;清E(K

18、)和U(K)MOVR1,#1EHMOVA,#00HCLEAR2:MOVR0,AINCR0DJNZR1,CLEAR2;清显示及缓冲区MOVA,#00H;清显示缓冲单元MOVCHADDR,AMOVCOUNT,AMOVBUFF,AMOVTMOD,#61H;设T0,T1工作方式SETBP1.7MOVTH1,#0E7H;装入T1时间常数MOVTL1,#0E7HSETBTR1MOVTH1,#3CH;装入T0时间常数MOVTL1,#0B0HLCALLDESPLAY;调显示子程序LCALLALARM;输出报警指示灯SETBTR0SETBET0SETBET1SETBEA . ;调用数据传送及转换子程序 . ;把

19、ROM中存放的数据传送到相应的RAM中 .HERE:AJMPHERE定时采样处理中断服务程序:CLLECT:MOVR0,#CDATA;取采样数据首地址MOVCOUNT,#05H;送采样次数ROUT0:MOVCHADDR,#00H;设通道号初值MOVBUFF,R0;保护通道号ROUT1:MOVA,CHADDR;送通道号MOVDPTR,#LS175MOVXDPTR,A;通道号加1INCCHADDR;延时,使S/H稳定NOPNOPROUT2:MOVDPTR,#AD574;启动A/DMOVXDPTR,AACALLDL30;延时,等待A/D转换结束MOVXA,DPTRMOVP2,#0F0HMOVXR0,

20、A;存放高8位INCDPTR;使A0=1INCR0;求低4位存放地址MOVXA,DPTR;读低4位MOVXR0,A;存放低4位MOVA,R0;求存放下一个通道数据地址ADDA,#09HMOVR0,ACJNEA,#08H,ROUT1;判断8个通道是否采样一次DJNZCOUNT,BRANCH;判断是否采样5次MOVTH0,#3CH;重新装入定时器0时间常数MOVTL0,#0B0HSETBTR0RETBUANCH:MOVR0,BUFF;计算第0通道下一次采样地址INCR0INCR0AJMPROUT0DL30:(延时子程序)报警处理模块:ALARM:LCALLTMAXCOMP;温度上限报警检查LCAL

21、LTMINCOMP;温度下限报警检查MOVA,20HORLA,21HMOVP1,A;输出温度上限、下限报警信MOVA,20HCPLA;求正常信号模型ORLA,21HMOVDPTR,#PC8255MOVXDPTR,A;输出温度下限报警及正常信号模型TMAXCOMP:MOVR0,#TEMPMAX;取上限报警首地址MOVR1,#SDATA;取采样数据首地址MOVR3,#08H;设通道数MOVR2,#02HCOMP1:MOVXA,R1MOVBUFF,AMOVXA,R0CJNEA,BUFF,COMP2;判断上限报警值与采样值高8位是否相等INCR0;求低8位地址 INCR1DJNZR2,COMP1SET

22、BALARMAX;相等,置报警标志COMP4:MOVA,20HRLAMOV20H,A;存入报警标志单元DJNZR3,COMP1;检查8路是否比较完成RET ;清报警标志位COMP3:CLRALARMAXAJMPCOMP4COMP2:JNCCOMP3;置报警标志位SETBALARMAX AJMP:COMP4;下限报警比较子程序TMINCOMP:MOVR0,#TEMPMINMOVR1,#SDATAMOVR3,#08HMOVR2,#02HCOMP11:MOVXA,R1MOVBUFF,AMOVXA,R0CJNZA,BUFF,COMP22INCR0INCR1DJNZR2,COMP11SETBALARMINCOMP44:MOVA,20HRLAMOV20H,ADJNZR3,COMP11RETCOMP33:CLRALARMINAJMPCOMP44COMP22:JCCOMP33SETBALARMINAJMPCOMP44

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑/施工/环境 > 项目建议


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号