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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

空调控制系统范本.docx

1、空调控制系统范本空调控制系统设计要求:设计一空调房间温度控制系统1,该系统能准确测量房间温度,并根据设定温度进行有效控制。空调设计变频空调制冷(热)量与压缩机转速有关,经过控制压缩机转速频率来控制所需热量。空调模型相当于一个积分环节与一个惯性环节的串联。房间模型主要考虑室内外温度干扰与散热片热量共同作用于具有初始温度房间,经空气导热延迟,简化为具有一阶惯性环节。设房间热惯性时间常数=450,空气导热延迟=35,选择合适的控制算法进行控制。1 课程设计的目的与意义经过该课程的学习使我们对计算机控制系统有一个全面的了解、掌握常规控制算法的使用方法、掌握简单微型计算机应用系统软硬的设计方法,进一步锻

2、炼同学们在微型计算机应用方面的实际工作能力。课程设计是一项综合性的专业实践活动,目的是让学生将所学的基础理论和专业知识运用到具体的工程实践中,以培养学生综合运用知识能力、实际动手能力和工程实践能力,计算机科学在自动化控制应用上得到了飞速发展,因此,学习这方面的知识必须紧密联系实际,掌握这方面的知识更要强调解决实际问题的能力。我们要着重学会面对一个实际问题,如何去自己的收集资料,如何自己去学习新的知识,如何自己去制定解决问题的方案并经过实践不断地提高分析和解决问题的能力。2 设计任务2.1 设计内容设计一空调房间温度控制系统,该系统能准确测量房间温度,并根据设定温度进行有效控制。空调设计变频空调

3、制冷(热)量与压缩机转速有关,经过控制压缩机转速频率来控制所需热量。空调模型相当于一个积分环节与一个惯性环节的串联。房间模型主要考虑室内外温度干扰与散热片热量共同作用于具有初始温度房间,经空气导热延迟,简化为具有一阶惯性环节2。2.2 计划设计进程一、总体方案设计二、控制系统的建模和数字控制器设计三、硬件的设计和实现1、选择计算机字长(选用 51内核的单片机)2、设计支持计算机工作的外围电路(EPROM、RAM、I/O端口、键盘、显示接口电路等);3、设计输入信号接口电路;4、设计信号输出控制电路;5、其它相关电路的设计或方案(电源、通信等)。四、软件设计1、分配系统资源,编写系统初始化和主程

4、序模块框图;2、编写A/D转换和位置检测子程序框图;3、编写控制程序和D/A转换控制子程序模块框图;4、其它程序模块(显示与键盘等处理程序)框图。五、编写课程设计说明书,绘制完整的系统电路图(A3幅面)。3 设计方案空调控制系统能够划分为七大部分:系统控制部分、室内温度采集部分、键盘控制部分、温度显示部分、压缩机控制部分、四通阈控制部分、风机控制部分。各模块电路的框图如图所示。图1 各模块电路的框图4 空调模型4.1 模型分析(1)空调模型相当于一个积分环节与一个惯性环节的串联。房间模型主要考虑室内外温度干扰与散热片热量共同作用于具有初始温度房间,经空气导热延迟,简化为具有一阶惯性环节。 (2

5、)由任务书给定条件:房间热惯性时间常数为450,空气导热延迟=35,经过分析,我们选择PID控制算法进行控制。4.2 MATLAB仿真图2 MATLAB仿真4.3 仿真结果图3 MATLAB仿真结果5 硬件设计5.1硬件系统框图根据任务书可知,该系统需要人机界面(按键输入LCD1602显示),AD采样,以及单片机控制部分等模块,而且能够得到以下硬件系统框图图4 硬件系统框图5.2 各部分的硬件设计1温度传感器选择3根据任务要求我们选择了AT590作为温度传感器。AD590电流输出型两端温度传感器是美国模拟器件公司生产的单片集成两端感温电流源。它的主要特性如下: (1)流过器件的电流(mA)等于

6、器件所处环境的热力学温度(开尔文)度数,即:mA/K式中:流过器件(AD590)的电流,单位为mA;T热力学温度,单位为K。 2、AD590的测温范围为-55+150。 3、AD590的电源电压范围为4V30V。电源电压可在4V6V范围变化,电流 变化1mA,相当于温度变化1K。AD590能够承受44V正向电压和20V反向电压,因而器件反接也不会被损坏。4、精度高。AD590共有I、J、K、L、M五档,其中M档精度最高,在-55+150范围内,非线性误差为0.3。其规格如下: 温度每增加1,它会增加1A输出电流。 可量测范围-55至150。 供应电压范围+4V至30V。AD590的接脚图及零件

7、符号如下图所示: AD590的输出电流值说明如下: 其输出电流是以绝对温度零度(-273)为基准,每增加1,它会增加1A输出电流,因此在室温25时,其输出电流Io=(273+25)=298A。 Vo的值为Io乘上10K,以室温25而言,输出值为2.98V(10K298A)。 量测Vo时,不可分出任何电流,否则测量值会不准。电路分析:AD590的输出电流I=(273+T)A(T为摄氏温度),因此电压V为(273+T)A 10K= (2.73+T/100)V。为了将电压量测出来又需使输出电流I不分流出来,我们使用电压追随器其输出电压V2等于输入电压V。 由于一般电源供应较多零件之后,电源是带杂讯的

8、,因此我们使用齐纳二极体作为稳压零件,再利用可变电阻分压,其输出电压V1需调整至2.73V。接下来我们使用差动放大器其输出Vo为(100K/10K)(V2-V1)=T/10V。如果现在为摄氏28度,输出电压为2.8V。 (2)AD转换器的选择因为温度变化范围是-50-50度,理论上AD位数只要7位(128级)就够了,因此系统采用了经典的ADC0809(8位AD)作为AD采样芯片。温度的计算公式:V=5*Rt/(R+R1+Rt)。ADC0809是带有8位A/D转换器、8路多路开关以及微处理机兼容的控制逻辑的CMOS组件。它是逐次逼近式A/D转换器,能够和单片机直接接口。a.ADC0809的内部逻

9、辑结构图5 ADC0809内部原理由图5可知,ADC0809由一个8路模拟开关、一个地址锁存与译码器、一个A/D转换器和一个三态输出锁存器组成。多路开关可选通8个模拟通道,允许8路模拟量分时输入,共用A/D转换器进行转换。三态输出锁器用于锁存A/D转换完的数字量,当OE端为高电平时,才能够从三态输出锁存器取走转换完的数据。b 引脚结构(如图)IN0IN7:8条模拟量输入通道图6 ADC0809引脚图ADC0809对输入模拟量要求:信号单极性,电压范围是05V,若信号太小,必须进行放大;地址输入和控制线:4条。ALE为地址锁存允许输入线,高电平有效。当ALE线为高电平时,地址锁 存与译码器将A,

10、B,C三条地址线的地址信号进行锁存,经译码后被选中的通道的模拟量进转换器进行转换。A,B和C为地址输入线,用于选通IN0IN7上的一路模拟量输入。通道选择表如表1所示。CBA选择的通道000IN0001IN1010IN2011IN3100IN4101IN5110IN6111IN7表 1数字量输出及控制线:11条ST为转换启动信号。当ST上跳沿时,所有内部寄存器清零;下跳沿时,开始进行A/D转换;在转换期间,ST应保持低电平。EOC为转换结束信号。当EOC为高电平时,表明转换结束;否则,表明正在进行A/D转换。OE为输出允许信号,用于控制三条输出锁存器向单片机输出转换得到的数据。OE1,输出转换

11、得到的数据;OE0,输出数据线呈高阻状态。D7D0为数字量输出线。CLK为时钟输入信号线。因ADC0809的内部没有时钟电路,所需时钟信号必须由外界提供,一般使用频率为500KHZ,VREF(),VREF()为参考电压输入。c.ADC0809应用说明ADC0809内部带有输出锁存器,能够与AT89S51单片机直接相连。初始化时,使ST和OE信号全为低电平。送要转换的哪一通道的地址到A,B,C端口上。在ST端给出一个至少有100ns宽的正脉冲信号。是否转换完毕,我们根据EOC信号来判断。当EOC变为高电平时,给OE为高电平,转换的数据就输出给单片机了。(3)按键输入因为按键数目不多,因此系统直接

12、采用非编码方式,直接连接单片机I/O口。图7 按键电路(4)显示部分系统采用LCD1602,P0和P3.0-P3.2作为输出口,控制LCD显示器,如图8。图8 LCD1602(5)输出控制设计使用LCD1602显示当前设定温度和实际测量温度,用两个LED指示当前空调状态(加热或制冷),51单片机的低电平驱动能力较强,LED能够直接连接单片机的I/O口;单片机输出PWM 波经驱动电路从而控制压缩机的转速。(6)系统硬件设计图图9 硬件原理图6 软件设计6.1 工作模式分析由系统要求能够列出表2工作模式设定温度实际温度压缩机制冷25.0度小于25.0度工作制热25.0度小于25.0度工作保持25.

13、0度小于25.0度不工作表 2根据上表,我们列出一系列子程序,再根据当前状况选择相应的子程序。例如控制部分子程序如下:void output(int temp1,int temp2) unsigned char table3; table2=temp1%10; table1=(temp1/10)%10; table0=(temp1/100)%10; DisplayString(0,1,Current T:); /显示当前测量温度 DisplayOneChar(10,1,table0+0x30); DisplayOneChar(11,1,table1+0x30); DisplayOneChar(

14、8,1,.); DisplayOneChar(12,1,table2+0x30); DisplayOneChar(13,1,C); table2=temp2%10; table1=(temp2/10)%10; table0=(temp2/100)%10; DisplayString(0,0,SetUp T:); /显示空调设定温度 DisplayOneChar(10,0,table0+0x30); DisplayOneChar(11,0,table1+0x30); DisplayOneChar(8,0,.); DisplayOneChar(12,0,table2+0x30); DisplayO

15、neChar(13,0,C); if(temp1temp2)motor=0; cold=0;hot=1; /当前温度大于设定温度,制冷 else if(temp1temp2)motor=0; cold=1;hot=0; /当前温度小于设定温度,加热 else motor=1; cold=1;hot=1; /当前温度等于设定温度,保持 6.2 系统程序流程图图10 系统流程图6.3 AD转化程序设计(1) 进行A/D转换之前,要启动转换的方法:ABC000选择第一通道。ST0,ST1,ST0产生启动转换的正脉冲信号(2) 进行A/D转换时,采用查询EOC的标志信号来检测A/D转换是否完毕,若完毕

16、则把数据经过P1端口读入进行处理。6.4 PID算法设计void pid(void) error=ideal_speed-pulse_speed; d_error = error - pre_error; pre_error = error; pre_d_error = d_error ; PWM+=kp*d_error + ki*error + kd*(error+pre_d_error-2*pre_error); 心得体会经过本此课程设计我已经能够熟练使用一些控制算法及设计方法。与此同时,也锻炼了我们的基本设计能力,为我们日后的学习打下了坚实的基础。经过这次课程设计,进一步加深了对计算机控

17、制技术的了解,让我对它有了更加浓厚的兴趣。特别是每当程序编写调试成功时,心里特别的开心。可是有时也遇到了不少问题,特别是硬件之间的连接,总是有错误的存在,可是在我们细心的检查下,终于找出了错误和警告的所在,排除困难后,心里终于舒了一口气。在空调控制系统的设计过程中,再一次认识到团队精神以及协同合作的重要性和优越性,无论是学习,还是日常生活,都应该继承和发扬这种珍贵的团队精神。虽然这次学习时间并不长,可是对自主学习的要求提高了,经过这样的学习形式,提高了我的学习能力。此次的计算机控制技术课程设计,得到了不少的启示。思考问题以及进行实践都要严谨,缜密。真所谓小心取证,就是这个道理。让我重新认识了团

18、队精神的重要性及如何在团队中尽可能的发挥自己的长处、优势;如何去学习别人的长处、优点来弥补自身的不足都有了一定程度的提升。经过学习空调控制系统的设计,更加了解可编程控制器的构造及应用,激发我们的创新意识。在学习与进行设计的过程中,利用已经掌握的知识及查阅的资料,自行完成课程设计任务以及设计完成。“学无止境,上下求索”,在今后的工作中,我将把学到的知识和自己的同伴的知识融合,并灵活的运用到学习、工作和生活当中。课程设计的学习生活使我的人生有了较高的起点,在这个起点上,我将不断向前,用自己辛勤的汗水,铿锵的脚步和竖韧不拔的精神,体验人生的涵义,谱写对生命的承诺。只有不断挑战自己、超越自己,才能跟上

19、时代的步伐。参考文献1于海生 编著 计算机控制技术. 北京:机械工业出版社, 2余锡存 曹国华著 单片机原理与接口技术西安:西安电子科技大学出版社, 。3田良 黄正谨著 综合电子设计与实践 南京:东南大学出版社, 。附录#include void Lcd_WriteData(unsigned char TempData); void Lcd_WriteCmd(unsigned char TempData,unsigned char BuysC); void Lcd_ReadStatus(void); void Lcd_Init(void); /LCD初始化 unsigned char Lcd_

20、ReadData(void);void DisplayString(unsigned char X, unsigned char Y, unsigned char *DData); void DisplayOneChar(unsigned char X, unsigned char Y, unsigned char DData); void Delay(unsigned int delaytime); unsigned int ADC0809();void setup(unsigned char);void output(int temp1,int temp2);unsigned char k

21、ey_scan();/* 全局变量定义*/ sbit Lcd_RS=P30; sbit Lcd_RW = P31; sbit Lcd_E = P32; #define Lcd_Data P0 sbit ST=P25;sbit EOC=P26;sbit OE=P27; sbit CLK=P24;#define ADC_OUT P1sbit up=P34;sbit down=P35;sbit motor=P20;sbit hot=P21;sbit cold=P22;int setup_t=250/* 主函数*/void main(void) unsigned int current_t; unsi

22、gned char key; Lcd_Init(); /lcd初始化 while(1) current_t=ADC0809(); key=key_scan(); setup(key); output(current_t,setup_t); /* 子函数定义*/unsigned char key_scan() unsigned char temp=0; if(up=0) temp=1; while(!up); else if(down=0) temp=2;while(!down); return(temp); void setup(unsigned char t1) if(t1=1) setup

23、_t+; if(t1=2) setup_t-;void output(int temp1,int temp2) unsigned char table3; table2=temp1%10; table1=(temp1/10)%10; table0=(temp1/100)%10; DisplayString(0,1,Current T:); DisplayOneChar(10,1,table0+0x30); DisplayOneChar(11,1,table1+0x30); DisplayOneChar(12,1,.); /LCD显示测量值 DisplayOneChar(13,1,table2+

24、0x30); DisplayOneChar(14,1,C); table2=temp2%10; table1=(temp2/10)%10; table0=(temp2/100)%10; DisplayString(0,0,SetUp T:); DisplayOneChar(10,0,table0+0x30); DisplayOneChar(11,0,table1+0x30); DisplayOneChar(12,0,.); /LCD显示测量值 DisplayOneChar(13,0,table2+0x30); DisplayOneChar(14,0,C); if(temp1temp2)moto

25、r=0; cold=0;hot=1; else if(temp1temp2)motor=0; cold=1;hot=0; else motor=1; cold=1;hot=1; void pid(void) /电机 error=ideal_speed-pulse_speed; d_error = error - pre_error; pre_error = error; pre_d_error = d_error ; PWM+=kp*d_error + ki*error + kd*(error+pre_d_error-2*pre_error); /* A/D转换程序*/unsigned int

26、 ADC0809() unsigned int adc; unsigned long int getdata; ST=0; OE=0; ST=1; ST=0; while(1) CLK=CLK ; if(EOC=1) break; /AD时钟脉冲 OE=1; getdata=ADC_OUT; OE=0; adc=getdata*500/256; return(adc);/* LCD1602驱动程序*/void Lcd_WriteData(unsigned char TempData) Lcd_ReadStatus(); Lcd_Data = TempData; Lcd_RS = 1; Lcd_

27、RW = 0; Lcd_E = 0; Lcd_E = 0; Lcd_E = 1; Lcd_E = 0; /写指令void Lcd_WriteCmd(unsigned char TempData,unsigned char BuysC) if (BuysC) Lcd_ReadStatus(); Lcd_Data = TempData; Lcd_RS = 0; Lcd_RW = 0; Lcd_E = 0; Lcd_E = 0; Lcd_E = 1; Lcd_E = 0; Lcd_E = 0; /读数据unsigned char Lcd_ReadData(void) Lcd_RS = 1; Lcd_RW = 1; Lcd_E = 0; Lcd_E = 0; Lcd_E = 0; Lcd_E = 0; Lcd_E = 1; Lcd_E = 0; return(Lcd_Data);void Lcd_ReadStatus(void) Delay(100);void Lcd_Init(void) /

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

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