【毕业设计】73-基于51单片机智能液晶温控风扇设计(说明书+PPT+仿真工程+源代码+原理图)

【毕业设计】73-基于51单片机智能液晶温控风扇设计(说明书+PPT+仿真工程+源代码+原理图)

主要研究内容:
1.单片机;2.直流电机;3.DS18B20;4.液晶显示器LCD。
设计思路:
查阅相关文献资料学习单片机、直流电机,温度传感器,液晶显示器LCD,编程实现单片机控制的智能温控风扇系统设计功能, LCD显示温度及调节上下限等功能。
方法和要求:
1.查阅相关文献资料学习单片机、温度传感器、直流电机,液晶显示器LCD;
2.学习Keil软件,用汇编语言或者C语言编程实现基于单片机的智能温控风扇的设计与实现功能;
3.学习Proteus软件,进行仿真实现基于单片机的智能温控风扇的设计与实现功能。
4.撰写论文。

基于单片机的智能温控风扇的设计与实现的研究意义在于可以通过温度控制实现对风扇进行智能控制。通过单片机读取温度传感器的环境温度信息,通过单片机定时器实现PWM,从而可以使系统达到通过不同温度智能控制风扇转速的功能。在工业的使用环境中,在许多复杂噪音多的环境中可以对风扇无干扰的进行控制。所以对单片机的智能温控风扇设计意义深远。
基于单片机的智能温控风扇的设计,主要由DS1B20温度传感器、直流电机及驱动模块;按键模块;LCD1602显示模块;单片机最小系统这几部分组成。通过DS18B20采集环境温度,通过不同的温度控制直流电机的转速。在本次设计中,温度传感器通过单总线方式传输温度数据,通过单片机定时器实现PWM占空比控制,以实现智能风扇的调速。LCD1602则显示当前温度及控制阈值信息。本论文从一开始构思系统实现的功能,然后设计硬件电路对元器件选型,设计电路、对单片机编写程序,程序需要不停的调试,在调试过程中寻找最佳的控制点,最后利用PROTEUS软件仿真实现智能温控风扇的功能,通过软件自带的模拟示波器显示占空比波形。
在最后也对整个系统做了详细的测试记录,在不同的工作环境中的工作情况,通过观察液晶显示器中的状态,以及电机的运转状态就可以判断是否已达到此系统的设计要求。最后根据参数来对系统进行改进。最后达到自己想要的设计成果。

资料包含:
1.详细设计说明书 1.8W字。
2.答辩PPT -24页
3.仿真工程文件
4.源代码工程文件
5.原理图工程文件
6.原理图截图
7.仿真截图
8.物料清单
9.开题报告

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

#include<reg51.h>
#include<intrins.h>			 //包含头文件
#define LCD1602 P0
#define uchar unsigned char
#define uint unsigned int		 //宏定义

sbit dj=P1^0;//电机控制端接口
sbit DQ=P1^6;//温度传感器接口
sbit SN=P1^1;//使能继电器动作
//按键接口/
sbit key1=P3^5;//设置温度
sbit key2=P3^6;//温度加
sbit key3=P3^7;//温度减

//
sbit RS = P2^7;
sbit EN = P2^6;
uint wen_du;						//温度变量  
uint shang,xia; //对比温度暂存变量
uchar dang;//档位显示
uchar Mode=0;
uchar d1,d2,d3;//显示数据暂存变量
uchar code tab1[]={" P:   T:   .  C "};
uchar code tab2[]={"TH:   C  TL:   C"};
void delay(uint ms)		//延时函数,大约延时
{
	uchar x;
	for(ms;ms>0;ms--)
		for(x=50;x>0;x--);
}
/***********ds18b20延迟子函数(晶振12MHz )*******/ 
void delay_18B20(uint i)
{
	while(i--);
}
/**********ds18b20初始化函数**********************/
void Init_DS18B20() 
{
	 uchar x=0;
	 DQ=1;          //DQ复位
	 delay_18B20(8);  //稍做延时
	 DQ=0;          //单片机将DQ拉低
	 delay_18B20(80); //精确延时 大于 480us
	 DQ=1;          //拉高总线
	 delay_18B20(14);
	 x=DQ;            //稍做延时后 如果x=0则初始化成功 x=1则初始化失败
	 delay_18B20(20);
}
/***********ds18b20读一个字节**************/  
uchar ReadOneChar()
{
	uchar i=0;
	uchar dat=0;
	for (i=8;i>0;i--)
	 {
		  DQ=0; // 给脉冲信号
		  dat>>=1;
		  DQ=1; // 给脉冲信号
		  if(DQ)
		  dat|=0x80;
		  delay_18B20(4);
	 }
 	return(dat);
}
/*************ds18b20写一个字节****************/  
void WriteOneChar(uchar dat)
{
 	uchar i=0;
 	for (i=8;i>0;i--)
 	{
  		DQ=0;
 		DQ=dat&0x01;
    	delay_18B20(5);
 		DQ=1;
    	dat>>=1;
	}
}
/**************读取ds18b20当前温度************/
void ReadTemperature()
{
	uchar a=0;
	uchar b=0;
	uint t=0;
	float tt=0;
	Init_DS18B20();
	WriteOneChar(0xCC);    	// 跳过读序号列号的操作
	WriteOneChar(0x44); 	// 启动温度转换
	delay_18B20(100);       // this message is wery important
	Init_DS18B20();
	WriteOneChar(0xCC); 	//跳过读序号列号的操作
	WriteOneChar(0xBE); 	//读取温度寄存器等(共可读9个寄存器) 前两个就是温度
	delay_18B20(100);
	a=ReadOneChar();    	//读取温度值低位
	b=ReadOneChar();   		//读取温度值高位
	t=b;				  //将高8位数据存入t
	t<<=8;			  //t左移8位
	t=t|a;			  //将t|a得到一个16位的温度数据
	tt=t*0.0625;		  //一个最低位代表0.0625°C,所以要*0.0625得到实际温度,因为有小数运算,所以定义的tt是float浮点型变量
	wen_du= tt*10+0.5;     //放大10倍输出并四舍五入(将温度放大10倍可以得到小数部分)
}

/********液晶写入指令函数与写入数据函数,以后可调用**************/

void write_1602com(uchar com)//****液晶写入指令函数****
{
	RS=0;//数据/指令选择置为指令
//	rw=0; //读写选择置为写
	LCD1602=com;//送入数据
//	delay(10);
	EN=1;//拉高使能端,为制造有效的下降沿做准备
	delay(10);
	EN=0;//en由高变低,产生下降沿,液晶执行命令
}


void write_1602dat(uchar dat)//***液晶写入数据函数****
{
	RS=1;//数据/指令选择置为数据
//	rw=0; //读写选择置为写
	LCD1602=dat;//送入数据
//	delay(10);
	EN=1; //en置高电平,为制造下降沿做准备
	delay(10);
	EN=0; //en由高变低,产生下降沿,液晶执行命令
}


void lcd_init()//***液晶初始化函数****
{
	uchar a;
	write_1602com(0x38);//设置液晶工作模式,意思:16*2行显示,5*7点阵,8位数据
	write_1602com(0x0c);//开显示不显示光标
	write_1602com(0x06);//整屏不移动,光标自动右移
	write_1602com(0x01);//清显示
//	
	write_1602com(0x80);//日历显示固定符号从第一行第1个位置之后开始显示
	for(a=0;a<16;a++)
	{
		write_1602dat(tab1[a]);//向液晶屏写日历显示的固定符号部分
//		delay(3);
	}
	write_1602com(0x80+0x40);//时间显示固定符号写入位置,从第2个位置后开始显示
	for(a=0;a<16;a++)
	{
		write_1602dat(tab2[a]);//写显示时间固定符号,两个冒号
//		delay(3);
	}
}


void KEY()
{
			//功能键
	if(key1==0)
	{
		delay(10);
		if(key1==0)
		{
			Mode++;
			if(Mode==3)
			Mode=0;
		}
		while(key1==0)
		{
			if(Mode==0)
				{
				//	write_1602com(0x80+0x40+6);
					write_1602com(0x0c);
				}	
			else if(Mode==1)
				{
					write_1602com(0x80+0x40+4);
					write_1602com(0x0f);
				}	
			else
				{
					write_1602com(0x80+0x40+13);
					write_1602com(0x0f);
				}							
		}
	}
	//增加
	if(key2==0&&Mode==1)
	{
		delay(10);
		if(key2==0)	
		{
			shang++;
			if(shang>=99)	
			shang=99;
			write_1602com(0x80+0x40+3);
			write_1602dat(shang/10+0x30);
			write_1602dat(shang%10+0x30);
			write_1602com(0x80+0x40+4);	
		}
		while(key2==0);
		
	}
	//减少
	if(key3==0&&Mode==1)
	{
		delay(10);
		if(key3==0)
		{
			shang--;
			if(shang==xia)	
			shang=xia+1;
			write_1602com(0x80+0x40+3);
			write_1602dat(shang/10+0x30);
			write_1602dat(shang%10+0x30);
			write_1602com(0x80+0x40+4);	
		}
		while(key3==0);
	}
	if(key2==0&&Mode==2)
	{
		delay(10);
		if(key2==0)	
		{
			xia++;
			if(xia==shang)	
			xia=shang-1;
			write_1602com(0x80+0x40+12);
			write_1602dat(xia/10+0x30);
			write_1602dat(xia%10+0x30);
			write_1602com(0x80+0x40+13);	
		}
		while(key2==0);
		
	}
	//减少
	if(key3==0&&Mode==2)
	{
		delay(10);
		if(key3==0)
		{
			xia--;
			if(xia<=0)	
			xia=0;
			write_1602com(0x80+0x40+12);
			write_1602dat(xia/10+0x30);
			write_1602dat(xia%10+0x30);
			write_1602com(0x80+0x40+13);	
		}
		while(key3==0);		
	}
}
void zi_dong()//自动温控模式
{
	if(wen_du<(xia*10)){dj=0;dang=0;SN=0;TR0=0;}//低于下限  档位为0 电机停止
	if((wen_du>=(xia*10))&&(wen_du<=(shang*10)))//温度大于下限,小于上限  1挡
	{
		dang=1;
		SN=1;											//档位置1
		TR0=1;		
	}
	if(wen_du>(shang*10)){dj=1;dang=2;SN=1;TR0=0;}//高温全速
}

void init()
{
	TMOD=0x01;
	TH0=0xec;
	TL0=0x78;
	ET0=1;
	TR0=0;
	EA=1;
}
void main()		  //主函数
{
	uchar j;
	dj=0;		  //电机
	for(j=0;j<80;j++)	  //先读取温度值,防止开机显示85
	ReadTemperature();
	delay(500);
	shang=30;
	xia=20;		  //初始上下限值
	ReadTemperature();
	lcd_init();
	init();
	while(1)			  //进入while循环
	{	
		ReadTemperature();	//读取温度值
		KEY();//按键扫描函数
		display();	 //调用显示函数
		zi_dong();
	}
}


基于单片机的温控风扇设计 摘 要 温控风扇在现代社会中的生产以及人们的日常生活中都有广泛的应用,如工业生产中大型机械散热系统中的风扇、现在笔记本电脑上的广泛应用的智能CPU风扇等。本文设计了基于单片机的温控风扇系统,采用单片机作为控制器,利用温度传感器DS18B20作为温度采集元件,并根据采集到的温度,通过一个达林顿反向驱动器ULN2803驱动风扇电机。根据检测到的温度与系统设定的温度的比较实现风扇电机的自动启动和停止,并能根温度的变化自动改变风扇电机的转速,同时用LED八段数码管显示检测到的温度与设定的温度。 关键词:单片机、DS18B20、温控风扇 第一章 整体方案设计 1.1 前 言 在现代社会中,风扇被广泛的应用,发挥着举足轻重的作用,如夏天人们用的散热风扇、工业生产中大型机械中的散热风扇以及现在笔记本电脑上广泛使用的智能CPU风扇等。而随着温度控制技术的发展,为了降低风扇运转时的噪音以及节省能源等,温控风扇越来越受到重视并被广泛的应用。在现阶段,温控风扇设计已经有了一定的成效,可以使风扇根据环境温度的变化进行自动无级调速,当温度升高到一定时能自动启动风扇,当温度降到一定时能自动停止风扇的转动,实现智能控制。 随着单片机在各个领域的广泛应用,许多用单片机作控制的温度控制系统也应运而生,如基于单片机的温控风扇系统。它使风扇根据环境温度的变化实现自动启停,使风扇转速随着环境温度的变化而变化,实现了风扇智能控制。它的设计为现代社会人们的生活以及生产带来了诸多便利,在提高人们的生活质量、生产效率的同时还能节省风扇运转所需的能量。 本文设计了由ATMEL公司的8052系列单片机AT89C52作为控制器,采用DALLAS公司的温度传感器DS18B20作为温度采集元件,并通过一个达林顿反向驱动器ULN2803驱动风扇电机的转动。同时使系统检测到得环境温度以及系统预设的温度动态的显示在LED数码管上。根据系统检测到得环境温度与系统预设温度的比较,实现风扇电机的自动启停以及转速的自动调节。 1.2 系统整体设计设计的整体思路是:利用温度传感器DS18B20检测环境温度并直接输出数字温度信号给单片机AT89C52进行处理,在LED数码管上显示当前环境温度值以及预设温度值。其中预设温度值只能为整数形式,检测到的当前环境温度可精确到小数点后一位。同时采用PWM脉宽调制方式来改变直流风扇电机的转速。并通过两个按键改变预设温度值,一个提高预设温度,另一个降低预设温度值。系统结构框图如下: 结 论 本次设计的系统以单片机为控制核心,以温度传感器DS18B20检测环境温度,实现了根据环境温度变化调节不同的风扇电机转速,在一定范围能能实现转速的连续调节,LED数码管能连续稳定的显示环境温度和设置温度,并能通过两个独立按键调节不同的设置温度,从而改变环境温度与设置温度的差值,进而改变电机转速。实现了基于单片机的温控风扇设计。 本系统设计可推广到各种电动机的控制系统中,实现电动机的转速调节。在生产生活中,本系统可用于简单的日常风扇智能控制,为生活带来便利;在工业生产中,可以改变不同的输入信号,实现对不同信号输入控制电机的转速,进而实现生产自动化,如在电力系统中可以根据不同的负荷达到不同的电压信号,再由电压信号调节不同的发电机转速,进而调节发电量,实现电力系统的自动化调节。综上所述,该系统的设计和研究在社会生产和生活中具有重要地位。 附录2:程序代码 #include <reg52.h> #define uchar unsigned char #define uint unsigned int sbit DQ=P1^7; sbit key1=P1^3; sbit key2=P1^4; sbit dianji=P3^1; float ff; uint y3; uchar shi,ge,xiaoshu,sheding=20,gaonum,dinum; uchar code dispcode[]={ //段码 0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71}; uchar code tablel[]={ //带小数点的段码 0xbf,0x86,0xdb,0xcf, 0xe6,0xed,0xfd, 0x87,0xff,0xef}; uchar dispbitcode[]={ //位选 0xfe,0xfd,0xfb,0xf7, 0xef,0xdf,0xbf,0x7f}; uchar dispbuf[8]={0,0,0,0,0,0,0,0}; void Delay(uint num)// 延时函数 { while( --num ); } void digitalshow(uchar a4,uchar a3,uchar a2,uchar a1,uchar a0) { dispbuf[0]=a0; dispbuf[1]=a1; dispbuf[2]=a2; dispbuf[3]=a3; dispbuf[4]=a4; P2=0xff; P0=dispcode[dispbuf[0]]; P2=dispbitcode[5]; Delay(1);
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叫我Eric

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值