- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
江汉大学物理与信息工程学院
单片机课程设计报告
课题名称: 高温报警系统
专 业: 电子与信息工程
班 级: 电信一班
学生姓名: XXXXXXXXXX
2012
一、设计要求
1.通过四个独立按键设置高温报警阈值温度,同时可以随时修改阈值温度。
2.利用温度芯片(DS18B20)实时监测当前温度并通过4位共阴数码管显示当前温度。
3.当检测到当前温度超过阈值温度接通蜂鸣器报警,当温度回落低于阈值温度警报解除。
二、设计方案
高温报警系统主要基于NI-51-A单片机开发板设计而成,整个系统的设计如下图所示:
三、系统电路
电源模块:
通过USB数据线将开发板接到电脑USB端口,由1、4端口将+5V电源接入开发板,为各个部件提供标准工作电压。
51最小系统模块:
51最小系统模块主要实现在接入+5v电源时可简单控制整个系统的开关、复位。对获取的数据进行处理,并对相关模块进行控制。
数码管显示模块:
4位共阴数码管用来显示温度信息,可精确到0.01℃
独立按键模块:
通过独立按键来控制程序进入阈值温度设置状态,并进行阈值温度调节,设置完成后通过独立按键退出设置状态,恢复温度显示。
温度检测模块:
实时检测当前温度并获取的温度值传送给51芯片,进行分析、处理。
蜂鸣器报警模块:
当温度超过阈值时,由51芯片控制蜂鸣器接通,发出警报声。
四、proteus仿真电路
五、程序设计
通过4个独立按键设置阈值温度(超过该阈值温度发出警报),通过温度芯片(DS18B20)实时监测当前温度,蒋获取的温度数据送给51芯片进行数据分析、处理,并控制4位共阴数码管显示当前温度信息。当检测到当前温度超过阈值温度便控制蜂鸣器发出警报声,当温度回落至阈值温度以下解除警报。需要修改阈值温度时,通过4个独立按键配合使用来调节阈值温度(精度为1℃)。
程序流程图:
程序源代码:
#includereg52.h
#include intrins.h
#define uchar unsigned char
#define uint unsigned int
sbit fm=P3^4; //蜂鸣器位定义
sbit key1=P2^0;//独立按键位定义
sbit key2=P2^1;
sbit key3=P2^2;
sbit key4=P2^3;
sbit s1=P2^4; //数码管位定义
sbit s2=P2^5;
sbit s3=P2^6;
sbit s4=P2^7;
sbit DQ=P3^5; //温度芯片位定义
uchar code tab[10]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};
uint a,keyflag;
void delay1(int ms) //延时函数
{
uint i,j;
for(i=0;ims;i++)
for(j=0;j125;j++);
}
void display(uint n) //数码管显示函数
{
uint ge,shi,bai,qian,flag;
ge=n%10;
shi=n/10%10;
bai=n/100%10;
qian=n/1000;
if(bai==0qian==0)flag=1;
else flag=0;
if(flag==1)
{
s3=s4=1;
s1=0;
P0=tab[ge];
delay1(5);
s1=1;
s2=0;
P0=tab[shi];
delay1(5);
s2=1;
}
else
{
s1=0;
P0=tab[ge];
delay1(5);
s1=1;
s2=0;
P0=tab[shi];
delay1(5);
s2=1;
s3=0;
P0=tab[bai]0x7f;
delay1(5);
s3=1;
s4=0;
P0=tab[qian];
delay1(5);
s4=1;
}
}
void speaker(uint temp)
{
uint i,m;
m=temp/100;
if(m=a)
{
for(i=0;i9;i++)
{
fm=0;
display(temp);
delay1(120);
fm=1;
delay1(40-4*i);
}
}
else
display(temp);
}
void delay(uint us)
文档评论(0)