- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基于stc单片机温度控制的程序
#include reg52.H
#include stdlib.h
#include math.h
#include intrins.h
unsigned int pp1;
unsigned int j=0;
unsigned int ReceiveData; //计算机向单片机发送的数据
unsigned int ADdat2;
unsigned char cH;
unsigned char cL;
unsigned char INPUT_ZH;
unsigned char INPUT_X;
unsigned int GivenTemper,measure,Error;
float pp;
sbit DS=P2^4;
sbit ss1=P2^0;
sbit ss2=P2^1;
#define uchar unsigned char
#define uint unsigned int
uchar Temp_Value[]={0x00,0x00};
void delay(unsigned int i);
uchar a,b,c;
float tt;
unsigned int temp;
/*************************此部分为18B20的驱动程序*************************************/
bit ds18b20isok=1;
//===============================================
void Delay(uint x) //延时程序
{unsigned i;
x=x*5/4;
for(i=0;ix;i++);
}
//===============================================
uchar InitDS18B20() //初始化
{
uchar status;
DS=1;Delay(8);DS=0;Delay(500);DS=1;Delay(100);
status=DS;Delay(100);
DS=1;
return status;
}
//=================================================
void WriteByte (uint dat) //单字节写入
{
uchar i;
for (i=0;i8;i++)
{
DS=0;
_nop_();
Delay(10);
DS=dat0x01;
Delay(40); //delay 45 uS //5
DS=1;
dat = 1;
}
}
//==================================================
uchar ReadByte (void) //读取单字节
{
uchar dat=0,i;
DS=1;
_nop_();
for(i=0;i8;i++)
{
DS = 0;
_nop_();
dat = 1;
DS = 1;
_nop_();
_nop_();
if(DS) dat |= 0x80;
Delay (45);
DS=1;
}
return dat;
}
uchar readtemperature()
{
if (InitDS18B20()==1)
ds18b20isok=0;
else
{
WriteByte(0xCC);
WriteByte(0x44);
InitDS18B20();
WriteByte(0xCC);
WriteByte(0xBE);
Temp_Value[0]=ReadByte();
Temp_Value[1]=ReadByte();
a =Temp_Value[0] ; //读取到的第一个字节为温度LSB
b = Temp_Value[1];
ds18b20isok=1;
}
}
/*****************************************************
函数功能:延时1ms
(3j+2)*i=(3×33+2)×10=1010(微秒),可以认为是1毫秒
***************************************************/
void delay1ms()
{
unsigned
您可能关注的文档
最近下载
- DB4403_T 77-2024 电动汽车充电安全监控平台数据采集规范.docx
- 基层网络舆情监测工作的实践与思考.docx VIP
- 加强政治机关建设提升机关工作质量.pptx VIP
- 作业3:《windows服务器基础配置与局域网组建》工学一体化课程学习任务设计.docx VIP
- 某小区供配电系统设计本科生毕业设计论文.doc VIP
- DG_TJ 08-2242-2023 民用建筑外窗应用技术标准.docx
- 胶带简介介绍.ppt
- 文化创意产品设计开发合同.doc VIP
- 瓦工:高级瓦工(强化练习).docx VIP
- 作业11:《windows服务器基础配置与局域网组建》工学一体化课程教学进度计划表.docx VIP
文档评论(0)