电烤箱温度控制系统Word文档下载推荐.docx
《电烤箱温度控制系统Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《电烤箱温度控制系统Word文档下载推荐.docx(34页珍藏版)》请在冰豆网上搜索。
即方式0、方式1和方式2,而B口只能工作在方式0或方式1下,而C口通常作为联络信号使用。
8255A的工作只有当片选CS效时才能进行。
而控制逻辑端口实现对其他端口的控制。
图2-18255A的内部框图
标识符
最小
最大
测试条件
输入低电平(VIL)
-0.5V
0.8V
输入高电平(VIH)
2.0V
5V
输出低电平(VOL)DB
0.45V
IOL=2.5mA
输出低电平(VOL)PER
IOL=1.7mA
输出高电平(VOH)DB
2.4V
IOH=-400μA
输出高电平(VOH)PER
IOH=-200μA
驱动电流
-1.0mA
-4.0mA
REXT=750Ω,VEXT=1.5V
供应电流
120mA
IIL(INPUTLOADCURRENT)
±
10μA
VIN=0V~5V
IOFL(OUTPUTFLOATLEAKAGE)
VOUT=0.45~5V
表2-18255A的技术参数表
参数说明:
输入最低电压:
min=-0.5V,max=0.8V
输入最高电压:
2.0V
输出最低电压:
0.45V
输出最高电压:
2.4V
(3)8255A的方式控制字
D7D6D5D4D3D2D1D0
1
1:
工作方式A口方式0输出B口方式0输出
C口高4位输入C口低4位输入
图2-28255A的方式控制字表
1方式0的工作特点:
是这种方式通常不用联络信号,不使用中断,三个通道中的每一个都有可以由程序选定作为输入或输出。
2通道的功能为:
两个8位通道:
通道A和B。
两个四位通道:
通道C高4位和低四位,任何一个通道可以作输入/输出,输入是不锁存的,输出是锁存的,在方式0时各个通道的输入/输出可有16种不同的组合。
X
写入位编码
写入内容
写入位编码0写入0
D0-D7000-1111写入1
图2-38255A的置位/控制字表
2、8279芯片
(1)8279芯片在本试验中的作用
使用8279来实现对键盘输入信号的接收和输出控制LED显示器的数据及显示方式。
(2)8279芯片的功能分析
8279的功能是对短矩阵键盘扫描以及控制LED显示器的数据及显示方式。
8279扫描输出信号经译码器译码后三根输出线Y0-Y2作为矩阵键盘的扫描信号,返回信号RL0-RL7与键盘矩阵的8个列输出信号相连接。
扫描译码器经另一译码器译码产生的8个输出信号作为8个显示器的选道信号,轮流刷新8个显示器。
8279A是一个40脚双列直插式芯片,由单一+5V供电.
图2-48279内部结构
8279具有2个端口,8个控制字和一个状态字
A0=0用来接收来自键盘的输入字节数据或输出到显示器的输出字节数据。
键盘扫描方式中,发出读FIFO命令后,从数据口读入数据为:
D7D6D5D4D3D2D1D0
CNTLSHIFT扫描值回送值
KKK
输入方式
000
编码扫描键盘,双键互锁
扫描键盘
001
译码扫描键盘,双键互锁
010
编码扫描键盘,N键互锁
扫描传感器矩阵
011
译码扫描键盘,N键互锁
100
编码传感器矩阵
选通
101
译码扫描传感器矩阵
110
选通输入,编码显示扫描
111
选通输入,译码显示扫描
表2-28279键盘输入方式
DD
输出方式
00
8字符显示,左端输入
显示器输出
01
16字符显示,左端输入
10
8字符显示,右端输入
11
16字符显示,右端
表2-3显示器输入方式
8279共使用8个控制字,高3位D7D6D5的特征位。
这些控制字是由CPU送到数据总线以后,CS=0,A0=1,WR上升沿送入控制寄存器。
名称
格式
备注
设置键盘和显示方式
000DDKKK
DD见上图,KKK见上图
时钟频率
001PPPPP
P为预定值2-31,是外接时钟的分频系数
读FIFO传感器RAM
010AI×
A2A1A0
A2A1A0是CPU读出传感器的存储单元地址
读显示RAM
011AIA3A2A1A0
A3A2A1A0是CPU送出传感器RAM的存储单元地址
禁止写显示器/熄火
101IW1IW0BL1BL0
IW1BL1为A口控制位,IW0BL0为B口控制位。
IW=1时,禁止写;
BL=1时显示器消隐
清除
110CD2CD1CD0CFCA
CA=1,清除FIFO/显示RAM,CF=1,将FIFO置空,并中断输出复位,传感器RAM置成0
结束中断
111E×
×
E=1时,以N键巡回特殊出错方式工作。
传感器矩阵方式中,该命令时IRQ变为的电平
表2-38279的控制字
8279A的的状态字,适用于键盘输入和选通方式检查FIFO,如下:
D7D6D5D4D3D2D1D0
DUS/EOUFNNN
D1D0:
FIFORAM中字符的个数。
取值为000-111。
D3:
FIFORAM满(D3=1);
D4:
FIFORAM空。
(D4=1)
D5:
FIFORAM溢出(D5=1);
D6:
传感器信号结束特征位
D7:
显示无效特征位。
DU=1无效。
3、DS18B20温度传感器
(1)DS18B20温度传感器的作用
利用温度传感器检测温度,并转换为数字量和设定的界限值比较。
(2)DS18B20的功能特点
DS18B20可编程温度传感器有三个管脚。
GND为接地线,DQ为数据输入输出接口,通过一个较弱的上拉电阻与CPU相连。
VDD为电源接口,既可由数据线提供电源,又可由外部提供电源,范围3.0—5.5V。
本系统中使用外部电源供电。
其主要特点为:
①用户可以自行设定报警上下限温度值;
②不需要外部组件,能测量-55—+125°
C范围内的温度;
③在-10—+85°
C范围内的测温准确度为±
0.5°
C;
④通过编程可以实现9—12位的数字读数方式,可在至多750MS内将温度转换成12位数字,测温分辨率可达到0.0625°
⑤独特的单总线接口方式,与微处理器连接时仅需要一条线既可实现和微处理器的双向通讯。
图2-6DS18B20内部结构图
图2-5DS18B20
DS18B20的内部结构主要由四部分组成:
64位光刻ROM,温度传感器,非挥发的温度报警触发器TH和TL,配置寄存器。
光刻ROM中的64位序列号是出厂前被光刻好的,它可以看作是该DS18B20的地址序列码。
64位光刻ROM的排列是:
开始8位(28H)是产品类型标号,接着的48位是该DS18B20自身的序列号,最后8位是前面56位的循环冗余校验码(CRC=X8+X5+X4+1)。
光刻ROM的作用是使每一个DS18B20都各不相同,这样就可以实现一根总线上挂接多个DS18B20的目的。
(3)DS18B20的测温原理和技术参数
DS18B20的测温原理:
图2-7DS18B20的测温原理图
DS18B20的测温原理如图所示,图中低温度系数晶振的振荡频率受温度的影响很小,用于产生固定频率的脉冲信号送给减法计数器1,高温度系数晶振随温度变化其震荡频率明显改变,所产生的信号作为减法计数器2的脉冲输入。
图中还隐含着计数门,当计数门打开时,DS18B20就对低温度系数振荡器产生的时钟脉冲后进行计数,进而完成温度测量。
计数门的开启时间由高温度系数振荡器来决定,每次测量前,首先将-55
℃所对应的基数分别置入减法计数器1和温度寄存器中,减法计数器1和温度寄存器被预置在
-55
℃
所对应的一个基数值。
减法计数器1对低温度系数晶振产生的脉冲信号进行减法计数,当减法计数器1的预置值减到0时温度寄存器的值将加1,减法计数器1的预置将重新被装入,减法计数器1重新开始对低温度系数晶振产生的脉冲信号进行计数,如此循环直到减法计数器2计数到0时,停止温度寄存器值的累加,此时温度寄存器中的数值即为所测温度。
图中的斜率累加器用于补偿和修正测温过程中的非线性,其输出用于修正减法计数器的预置值,只要计数门仍未关闭就重复上述过程,直至温度寄存器值达到被测温度值,这就是DS18B20的测温原理。
表2-4DS18B20温度值格式表
DS18B20中的温度传感器可完成对温度的测量,以12位转化为例:
用16位符号扩展的二进制补码读数形式提供,以0.0625℃/LSB形式表达,其中S为符号位。
这是12位转化后得到的12位数据,存储在18B20的两个8比特的RAM中,二进制中的前面5位是符号位,如果测得的温度大于0,这5位为0,只要将测到的数值乘于0.0625即可得到实际温度;
如果温度小于0,这5位为1,测到的数值需要取反加1再乘于0.0625即可得到实际温度。
DS18B20的存储器:
DS18B20温度传感器的内部存储器包括一个高速暂存RAM和一个非易失性的可电擦除的E2RAM,后者存放高温度和低温度触发器TH、TL和结构寄存器。
根据DS18B20的通讯协议,主机控制DS18B20完成温度转换必须经过三个步骤:
每一次读写之前都要对DS18B20进行复位,复位成功后发送一条ROM指令,最后发送RAM指令,这样才能对DS18B20进行预定的操作。
复位要求主CPU将数据线下拉500微秒,然后释放,DS18B20收到信号后等待16~60微秒左右,后发出60~240微秒的存在低脉冲,主CPU收到此信号表示复位成功。
4、LED显示器
(1)芯片在本设计中的作用
LED发光二极管在本设计中采用7段数字发光二极管,作为终端显示。
显示时间的分秒。
(2)LED的功能分析
物理构造:
LED发光二级管,采用砷化镓、镓铝砷、和磷化镓等材料制成,其内部结构为一个PN结,具有单向导电性。
当在发光二极管PN结上加正向电压时,PN结势垒降低,载流子的扩散运动大于漂移运动,致使P区的空穴注入到N区,N区的电子注入到P区,这样相互注入的空穴与电子相遇后会产生复合,复合时产生的能量大部分以光的形式出现。
将七个发光管进行组合,排列成数字图形8,再根据需要控制七个管的亮与灭,即可显示出定义数字。
有段选码和位选码确定数字1~8的输出并在延时程序中保持复位。
它是一种当外加电压超过额定电压时发生击穿,并因此而产生可见光的器件。
这种数码管是有7段或8段笔画显示器组成一个字符而形成的。
图2-8LED内部结构
图2-9LED显示
表2-5LED显示管段选码编码表
数字
dp
g
f
e
d
c
b
a
二进制编码
C0h
F9h
2
A4h
3
B0h
4
99h
5
92h
6
82h
7
F8h
8
80h
9
90h
(3)LED的技术参数分析
LED发光二极管的压降一般为1.5-2.0V,其工作电流一般取10-20Ma,发光二极管可应用于直流驱动电路、交流驱动电路和脉冲驱动电路。
由于8255A的最大驱动电流为4.0mA,而LED的工作电流一般为10-20mA,所以需要加一个驱动器74LS244。
5、矩阵键盘
(1)矩阵键盘在本设计中的作用
矩阵键盘在工作时,是按照行线和列线交叉点的电平值来识别按键的,由人手按动键盘。
当键释放后,该键就有效。
矩阵键盘将0—F这16哥键按行和列排列成矩阵形式。
对于m×
n哥键的键盘,只需要m+n位I/O端口,我们的实验采用的是4×
4键盘。
(2)矩阵键盘的功能分析
在矩阵键盘中,通过行列交叉点上的电平值来识别按键,而行列线通过键盘数据格式确定,键盘数据格式如下:
表2-6键盘数据格式
CNTLS
SHIFT
SL2
SL1
SL0
R2
R1
R0
控制
移位
行编码
列编码
其中,控制和移位由两个独立的附加开关决定;
SL2SL1SL0为按下键的行编码,来自扫描计数器的低三位,R2R1R0是根据返回信号确定的列编码。
通常使用的键盘是矩阵结构的。
对于4×
4=16个键的键盘,采用矩阵方式只要用8条引线和2个8位端口便完成键盘的连接。
如图,这个矩阵分为4行4列,如果键5按下,则第1行和第1列线接通而形成通路。
如果第1行线接低电平,则键5的闭合,会使第1列线也输出低电平。
矩阵式键盘工作时,就是按行线和列线的电平来识别闭合键的。
图2-104×
4键盘矩阵图
行扫描法识别按键的原理如下:
先使第0行接低电平,其余行为高电平,然后看第0行是否有键闭合。
这是通过检查列线电位来实现的,即在第0行接低电平时,看是否有哪条列线变成低电平。
如果有某列线变为低电平,则表示第0行和此列线相交位置上的键被按下;
如果没有任何一条列线为低电平,则说明第0行没有任何键被按下。
此后,再将第1行接低电平,检测是否有变为低电平的列线。
如此重复地扫描,直到最后一行。
在扫描过程中,当发现某一行有键闭合时,也就是列线输入中有一位为0时,便退出扫描,通过组合行线和列线即可识别此刻按下的是哪一键。
6、数/模转换器DAC0832
(1)DAC0832在本设计中的作用
DAC0832是NationalSemiconductor生产的一款D/A(数字/模拟)转换器,其采用CMOS工艺和R-2RT形电阻解码网络,转换结果为一对差动电流I01和I02输出。
在本设计中主要用来将开关打入的数字信号转换为相应的模拟信号。
(2)DAC0832的功能分析
DAC0832是8位D/A转换器,转换周期为1μs。
它由8位输入锁存器、8位DAC寄存器、8位D/A转换电路组成。
当ILE为高电平,CS为低电平,WR1为负脉冲时,在LE1产生正脉冲;
LE1为高电平时,输入寄存器的状态随数据输入线状态变化,LE1的负跳变将输入数据线上的信息存入输入寄存器。
当Xfer为低电平,WR2输入负脉冲时,则在LE2产生正脉冲;
LE2为高电平时,DAC寄存器的输入与输出寄存器的状态一致,LE2的负跳变,输入寄存器内容存入DAC寄存器。
DAC0832的输出是电流型的。
在微机系统中,通常需要电压信号,电流信号和电压信号之间的转换可由运算放大器实现。
(3)DAC0832的技术参数
DAC0832芯片采用CMOS工艺,四象限乘法型DAC,与微机兼容,数据输入能与双缓冲、单缓冲或直接通过三种方式工作。
是一个8位D/A转换器,输入电平与TTL、CMOS兼容,单电源+5~+15V工作,基准电压的范围为±
10V,电流建立时间为1µ
s,低功耗200mw,20引脚,双列直接式封装。
图2-12内部原理图
7、蜂鸣器
(1)蜂鸣器的作用
在本实验中,蜂鸣器用作声音报警。
(2)蜂鸣器的技术参数
图2-11蜂鸣器内部结构图
它一般包括灵敏度、频率响应、额定功率、额定阻抗、指向性、失真、音质听感评价等。
本实验电压范围为0-5V。
8.74LS138芯片
(1)74LS138在本设计中的作用
将SL0~SL2锁确定的信号经译码器译为矩阵键盘的行选择线。
(2)74LS138的功能分析
74LS138是3/8译码器,即对3哥输入信号进行译码,得到8个输出状态。
其引脚功能图如下所示:
表2-7:
真值表
图2-13引脚图
G1G2AG2B为数据输出端,G2AG2B为低电平有效,G1高电平有效,A、B、C为译码器输入出端,Y0~Y7为译码输出端,低电平有效。
(3)74LS138的技术参数
极限值电源电压-----------------------------------------7V
输入电压------------------------------------------------7V
工作环境温度-----------------------------------------0~70℃
贮存温度--------------------------------------------65~150℃
9、硬件总逻辑图及说明
3、控制程序设计
1、控制程序设计思路说明
本程序采用模块化设计,主程序由若干子程序组成。
首先8279控制键盘输入两个值,时间和温度,在七段LED显示器前四位显示温度后四位显示时间。
DS18B20采集温度传输到8255,并与界限值比较,小于界限就通过DAC0832输出电压加热,大于界限就初始化DAC0832。
温度和时间一秒刷新显示一次,通过调用延时,使主程序循环一次是一秒。
输入的时间以分钟计时,60秒后时间减一。
由于DS18B20采用串行数据传送和单总线数据传输方式,其数据输入输出都由同一条线完成,因此,对读写的操作时序要求严格,需要做较精确的延时。
对8279进行操作时要注意与实际情况相结合修改控制字选择不同的显示方式,同时应注意左入口和右入口的区别。
控制程序流程图
主程序流程图:
延时
NY
N
N
Y
NN
Y
初始化8279:
开始
写入端口地址、命令字及入口方式
调用函数清除LED显示
设置显示方式
RET
结束
扫描按键子函数流程图:
写入8279控制字
有键按下?
NO
YES
NOKEY
读FIFO/ROM,键号转化为键值并输出
显示温度设定值:
保护寄存器SI,BX
将键入的温度值存入中间量buffer2
调用显示子函数,显示值
寄存器出栈
读出DS18B20的温度存放在AX:
首先复位DS18B20
跳过ROM匹配
发出度温度指令
读出温度,存放至AX;
还原寄存器
结束
读温度字操作流程图:
开始时让PC0口维持低电平
写入新的控制字,准备接收温度值
调用延时子程序,温度经由PC0口写入AL
右移AL最低位至标志位CF
标志位转移至BL,备份AL中的值,PC0口置低电平准备读下一位
2、控制程序
.MODELTINY
PCIBAR3EQU1CH;
8位I/O空间基地址(它就是实验仪的基地址,也为DMA&
;
32BITRAM板卡上的8237提供基地址)
Vendor_IDEQU10EBH;
厂商ID号
Device_IDEQU8376;
设备ID号
.STACK300
.DATA
IO_Bit8_BaseAddressDW?
msg0DB'
BIOS不支持访问PCI$'
msg1DB'
找不到StarPCI9052板卡$'
msg2DB'
读8位I/O空间基地址时出错$'
msg3DB'
输入温度和加热时间$'
Con_8255DW00F3H
PC_8255DW00F2H
PB_8255DW00F1H
PA_8255DW00F0H
DAC0832DW00C0H
CMD_8279DW00B0H
TABDB3Fh,06h,5Bh,4Fh,66h,6Dh,7Dh,07h,
7Fh,6Fh,77h,7Ch,39h,5Eh,79h,71h
TEMPDB?
TIMEDB?
LIMIT_1DB?
buffer2DB?
.CODE
START:
MOVAX,@DATA
MOVDS,AX
MOVES,AX
NOP
CALLInitPCI
CALLModifyAddress;
根据PCI提供的基地址,将偏移地址转化为实地址
CALLInit8255
CALLINITDAC0832
LEADX,