温度数据采集
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
西安郵電大学
PLC课程设计报告书基于S7-200的温度采集系统设计
院(系)名称:自动化学院
35号:陈有元34号:徐星杰学生姓名:
30号:穆磊 28号:朱瑶
专业名称:测控技术与仪器
班级:测控1003班
2013 年 09 月 09 日至
时间:
2013 年 09 月 22 日
温度数据采集
一、设计要求
1.温度通过DS18B20进行控制;
2.通过单片机及DAC0832把信号变为0-5伏;
3.PLC采集此模拟信号,并进行工程量转换;
4.进行现场总线测量,对测量精度进行量化。
二、实验步骤
1.根据单片机原理,分析实验要求,编写程序。
2.设计硬件电路,并且在Proteus中进行模拟仿真。
3.仿真成功后,合理布线,进行焊接。
4.进行检查调试。
三、所需元器件
表 1 所需器件
元器件数量
AT89C52 1个
DS18B20 1个
晶振1个
电容3个
DAC0832 1个
放大器1个
电阻若干
导线若干
四、主要功能描述
利用DS18B20数字温度传感器实现对温度进行准确的测量,使温度值显示到数码管上。利用DS18B20数字温度传感器进行温度的采集,单片机作为控制器件,数据通过串口(RS232)传至计算机,进行温度的采集。
五、实验电路图:
图 1 硬件模拟电路仿真图
六、实验源程序及流程图
源程序:
#include
#include
typedef unsigned char uint8;
sbit DQ= P3^0;
unsigned char Code[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0x F8,0x80,0x90};
void mDelay(uint8 Delay)
{
while(Delay--);
}
Init_DS18B20(void)
{
uint8 x = 0;
DQ = 1;
mDelay(8);
DQ = 0;
mDelay(80);
DQ = 1;
mDelay(20);
x = DQ;
mDelay(30);
}
ReadOneChar(void)
{
uint8 i = 0;
uint8 dat = 0;
for(i=8;i>0;i--)
{
DQ = 0;
dat>>=1;
DQ = 1;
if(DQ)
{
dat |= 0x80;
}
mDelay(8);
}
return(dat);
}
WriteOneChar(uint8 dat) {
uint8 i = 0;
for(i=8;i>0;i--)
{
DQ = 0;
DQ = dat&0x01;
mDelay(10);
DQ = 1;
dat >>= 1;
}
mDelay(4);
}
ReadTemperature(void) {
uint8 L = 0;
uint8 H = 0;
uint8 temp = 0;
Init_DS18B20(); WriteOneChar(0xCC); WriteOneChar(0x44);
Init_DS18B20(); WriteOneChar(0xCC); WriteOneChar(0xBE);
L = ReadOneChar();
H = ReadOneChar();
L = L>>4;
temp = H<<4;
temp = temp|L;
return(temp);
}
void main(void)
{
uint8 temp;
while(1)
{
temp = ReadTemperature(); P1=temp;
}
}
七、设计原理:
图 2 PDIP芯片引脚功能图
如图表2引脚功能描述:
VCC:电源
GND:地
P0口:P0口是一个8位漏极开路的双向I/O口。作为输出口,每位能驱动8个TTL逻辑电平。对P0端口写“1”时,引脚用作高阻抗输入。当访问外部程序和数据存储器时,P0口也被作为低8位地址/数据复用。在这种模式下,P0 具有内部上拉电阻。在flash编程时,P0口也用来接收指令字节;在程序校验时,输出指令字节。程序校验时,需要外部上拉电阻。
P1口:P1口是一个具有内部上拉电阻的8位双向I/O口,p1输出缓冲器能驱动4个TTL逻辑电平。对P1端口写“1”时,内部上拉电阻把端口拉高,此时可以作为输入口使用。作为输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流(IIL)。此外,P1.0和P1.2分别作定时器/计数器2的外部计数输入(P1.0/T2)和时器/计数器2的触发输入(P1.1/T2EX),具体如下表所示。在flash 编程和校验时,P1口接收低 8 位地址字。
P2口:P2口是一个具有内部上拉电阻的8位双向I/O口,P2输出缓冲器能驱动4个TTL逻辑电平。对P2端口写“1”时,内部上拉电阻把端口拉高,此时可以作为输入口使用。作为输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流(IIL)。
P3口:P3口是一个具有内部上拉电阻的8位双向I/O口,p2输出缓冲器能驱动4个TTL逻辑电平。对P3端口写“1”时,内部上拉