维修电工智能排故系统装置毕业设计Word文件下载.docx
《维修电工智能排故系统装置毕业设计Word文件下载.docx》由会员分享,可在线阅读,更多相关《维修电工智能排故系统装置毕业设计Word文件下载.docx(29页珍藏版)》请在冰豆网上搜索。
功能三,能显示排故定时,故障点的编号,以及设置的故障数等,即至少要有三组(两个数码管一组)数码管显示;
功能四,能对电路中的48个点进行选择性控制,来模拟电路中的故障。
功能一的设计讨论。
智能化,采用单片机来实现。
使用单片机的选择有,AT89C51、AT89C52、STC89C51、STC89C52.宏晶STC系列单片机的功能,性能要比AT系列的好。
功能二的设计讨论。
需要的按键,有0~9十个数字按键,因为装置需要输入和设置密码;
有功能键,例如“模式”键、“确认”键、“清零”键、“考核”键等;
即按键数至少要有十四个按键。
功能三的设计讨论。
显示采用三个两位的数码管动态显示。
显示数据的数值和组别的区别,用数码管的闪烁实现。
显示有软件译码和硬件译码。
软件译码比硬件译码占用的I/O口数多。
硬件译码包括位选译码和数据显示译码。
功能四的设计讨论。
功能二和功能三占用了两个I/O口,只剩下两个I/O口可用,要实现功能四,I/O口就必须得扩展。
现有三种扩展I/O口的方法:
方法一,用8255芯片扩展I/O口,使其扩展到48个I/O口,但程序复杂;
方法二,用4线16线译码器与D型触发器控制电路结合使用,但这种方法的成本价高,需要用到24片D型触发器芯片;
方法三,用两片单片机扩展I/O口,采用并行连接法,程序简单,成本价低。
2硬件方案的确定
综合上述的讨论与分析,确定的硬件设计方案为:
采用STC89C52作为该装置的主控CPU芯片,按键采用4×
4矩阵键盘,显示采用硬件译码,输出采用两片单片机STC89C51作为从片CPU芯片与主片CPU芯片STC89C52并行连接,输出控制点的通断用继电器来控制。
其系统结构方框图如图1-1。
3软件方案设计
按维修电工智能排故系统装置的硬件设计,来设计CPU的操作应用系统,即软件的设计。
两从片CPU(STC89C51)的功能是,将主控CPU发过来的信号中转控制继电器的工作状态,并保持当前状态,直到下一个相同的信号到来。
由于它是与主控CPU并行连接,所以,只要读取与主控CPU相连的I/O口的数据,并保持相应的状态就行。
主控CPU(STC89C52)的功能,能对按键的输入进行相应的处理,并能在数码管上显示;
操作按键可实现的功能有,可以输入并设置一个六位数的密码;
设置故障点;
查询故障点;
设置定时时间;
清零功能等等。
由于主控CPU的功能强大,系统程序长,所以主程序的运行采用中断程序法,其它都设计成子程序。
主要子程序有:
动态显示程序;
4×
4矩阵键盘扫描程序;
密码程序;
监控程序;
延时程序;
输出程序;
报警程序;
中段计数程序等
4STC89C51单片机的性能及应用
STC89C51系列单片机是宏晶科技推出的新一代超强抗干扰、高速、低功耗的单片机,指令代码完全兼容传统8051单片机,12时钟/机器周期和6时钟/机器周期可任意选择。
其主要特点如下:
1)增强型6时钟/机器周期,12时钟/机器周期;
2)工作电压:
5.5V-3.4V(5V单片机);
3)工作频率范围:
0-40MHZ,相当于普通8051的0-80MHZ。
实际工作频率可达48MHZ;
4)用户应用程序空间有4K字节;
5)片上集成512字节RAM;
6)通用I/O口(32个),复位后为:
P0、P1、P2、P3是准双向口、弱上拉(普通8051传统I/O口)。
P0口是开漏输出。
作为总线扩展用时,不用加上拉电阻,作为I/O口用时,需要加上拉电阻;
7)ISP(在系统可编程)、IAP(在应用可编程),无需专用编程器、仿真器可通过串口(P3.0/P3.1)直接下载用户程序,下载速度快;
8)EEPROM功能;
9)看门狗;
10)共3个16位定时器、计数器,其中定时器0还可以当成2个8位定时器使用;
11)外部中断4路,下降沿中断或低电平触发中断,POWERDOWN模式可由外部中断低电平触发中断方式唤醒;
12)通用异步串行口(UART),还可用定时软件实现多个UART;
13)工作温度范围:
-40~+85摄氏度;
STC89C52用户存储器空间为8K,其功能与STC89C51相同,这里就不再介绍了。
5成果预测
维修电工智能排故系统装置是根据高级电工培训考核的实际情况而设计的集培训学习、理论验证、实际操作能力、考核鉴定于一体的多功能考核设备。
整个系统装置能完成高级电工考核鉴定中的电力拖动控制与照明电路的实操项目,适应各大、中专、技校、职校初、高级电工、电拖专业教学与实训考核。
一元器件简介
1.主控芯片STC89C52
(1)STC89C52处理芯片
(2)主要性能
与MCS-51单片机产品兼容、8K字节在系统可编程Flash存储器、1000次擦写周期、全静态操作:
0Hz~33Hz、三级加密程序存储器、32个可编程I/O口线、三个16位定时器/计数器八个中断源、全双工UART串行通道、低功耗空闲和掉电模式、掉电后中断可唤醒、看门狗定时器、双数据指针、掉电标识符。
功能特性描述
STC89C52是一种低功耗、高性能CMOS8位微控制器,具有8K在系统可编程Flash存储器。
使用高密度非易失性存储器技术制造,与工业80C51产品指令和引脚完全兼容。
片上Flash允许程序存储器在系统可编程,亦适于常规编程器。
在单芯片上,拥有灵巧的8位CPU和在线系统可编程Flash,使得STC89C52为众多嵌入式控制应用系统提供高灵活、超有效的解决方案。
STC89C52具有以下标准功能:
8k字节Flash,256字节RAM,32位I/O口线,看门狗定时器,2个数据指针,三个16位定时器/计数器,一个6向量2级中断结构,全双工串行口,片内晶振及时钟电路。
另外,STC89C52可降至0Hz静态逻辑操作,支持2种软件可选择节电模式。
空闲模式下,CPU停止工作,允许RAM、定时器/计数器、串口、中断继续工作。
掉电保护方式下,RAM内容被保存,振荡器被冻结,单片机一切工作停止,直到下一个中断或硬件复位为止。
8位微控制器8K字节在系统可编程Flash
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位地址字节。
引脚号第二功能
P1.0T2(定时器/计数器T2的外部计数输入),时钟输出
P1.1T2EX(定时器/计数器T2的捕捉/重载触发信号和方向控制)
P1.5MOSI(在线系统编程用)
P1.6MISO(在线系统编程用)
P1.7SCK(在线系统编程用)
P2口:
P2口是一个具有内部上拉电阻的8位双向I/O口,P2输出缓冲器能驱动4个TTL逻辑电平。
对P2端口写“1”时,内部上拉电阻把端口拉高,此时可以作为输入口使用。
在访问外部程序存储器或用16位地址读取外部数据存储器(例如执行MOVX@DPTR)时,P2口送出高八位地址。
在这种应用中,P2口使用很强的内部上拉发送1。
在使用8位地址(如MOVX@RI)访问外部数据存储器时,P2口输出P2锁存器的内容。
在flash编程和校验时,P2口也接收高8位地址字节和一些控制信号。
P3口:
P3口是一个具有内部上拉电阻的8位双向I/O口,p2输出缓冲器能驱动4个TTL逻辑电平。
对P3端口写“1”时,内部上拉电阻把端口拉高,此时可以作为输入口使用。
P3口亦作为STC89C52特殊功能(第二功能)使用,如下表所示。
在flash编程和校验时,P3口也接收一些控制信号。
端口引脚第二功能
P3.0RXD(串行输入口)
P3.1TXD(串行输出口)
P3.2INTO(外中断0)
P3.3INT1(外中断1)
P3.4TO(定时/计数器0)
P3.5T1(定时/计数器1)
P3.6WR(外部数据存储器写选通)
P3.7RD(外部数据存储器读选通)
此外,P3口还接收一些用于FLASH闪存编程和程序校验的控制信号。
RST——复位输入。
当振荡器工作时,RST引脚出现两个机器周期以上高电平将是单片机复位。
ALE/PROG——当访问外部程序存储器或数据存储器时,ALE(地址锁存允许)输出脉冲用于锁存地址的低8位字节。
一般情况下,ALE仍以时钟振荡频率的1/6输出固定的脉冲信号,因此它可对外输出时钟或用于定时目的。
要注意的是:
每当访问外部数据存储器时将跳过一个ALE脉冲。
对FLASH存储器编程期间,该引脚还用于输入编程脉冲(PROG)。
如有必要,可通过对特殊功能寄存器(SFR)区中的8EH单元的D0位置位,可禁止ALE操作。
该位置位后,只有一条MOVX和MOVC指令才能将ALE激活。
此外,该引脚会被微弱拉高,单片机执行外部程序时,应设置ALE禁止位无效。
PSEN——程序储存允许(PSEN)输出是外部程序存储器的读选通信号,当STC89C52由外部程序存储器取指令(或数据)时,每个机器周期两次PSEN有效,即输出两个脉冲,在此期间,当访问外部数据存储器,将跳过两次PSEN信号。
EA/VPP——外部访问允许,欲使CPU仅访问外部程序存储器(地址为0000H-FFFFH),EA端必须保持低电平(接地)。
需注意的是:
如果加密位LB1被编程,复位时内部会锁存EA端状态。
如EA端为高电平(接Vcc端),CPU则执行内部程序存储器的指令。
FLASH存储器编程时,该引脚加上+12V的编程允许电源Vpp,当然这必须是该器件是使用12V编程电压Vpp。
2.3-8译码器74LS138
引脚图
74LS138为3线-8线译码器,共有54/74S138和54/74LS138两种线路结构型式,
其工作原理如下:
当一个选通端(E3)为高电平,另两个选通端(E1)和/(E2))为
低电平时,可将地址端(A、B、C)的二进制编码在一个对应的输出端以低
电平译出。
利用E1、E2和E3可级联扩展成24线译码器;
若外接一个反
相器还可级联扩展成32线译码器。
若将选通端中的一个作为数据输入端时,74LS138还可作数据分配器。
3.数码管
数码管按段数分为七段数码管和八段数码管,八段数码管比七段数码管多一个发光二极管单元(多一个小数点显示);
按能显示多少个“8”可分为1位、2位、4位等等数码管;
按发光二极管单元连接方式分为共阳极数码管和共阴极数码管。
共阳数码管是指将所有发光二极管的阳极接到一起形成公共阳极(COM)的数码管。
共阳数码管在应用时应将公共极COM接到+5V,当某一字段发光二极管的阴极为低电平时,相应字段就点亮。
当某一字段的阴极为高电平时,相应字段就不亮。
。
共阴数码管是指将所有发光二极管的阴极接到一起形成公共阴极(COM)的数码管。
共阴数码管在应用时应将公共极COM接到地线GND上,当某一字段发光二极管的阳极为高电平时,相应字段就点亮。
当某一字段的阳极为低电平时,相应字段就不亮。
(1)驱动方式
数码管要正常显示,就要用驱动电路来驱动数码管的各个段码,从而显示出我们要的数字,因此根据数码管的驱动方式的不同,可以分为静态式和动态式两类。
①静态显示驱动:
静态驱动也称直流驱动。
静态驱动是指每个数码管的每一个段码都由一个单片机的I/O端口进行驱动,或者使用如BCD码二-十进制译码器译码进行驱动。
静态驱动的优点是编程简单,显示亮度高,缺点是占用I/O端口多,如驱动5个数码管静态显示则需要5×
8=40根I/O端口来驱动,要知道一个89S51单片机可用的I/O端口才32个呢:
),实际应用时必须增加译码驱动器进行驱动,增加了硬件电路的复杂性。
②动态显示驱动:
数码管动态显示接口是单片机中应用最为广泛的一种显示方式之一,动态驱动是将所有数码管的8个显示笔划"
a,b,c,d,e,f,g,dp"
的同名端连在一起,另外为每个数码管的公共极COM增加位选通控制电路,位选通由各自独立的I/O线控制,当单片机输出字形码时,所有数码管都接收到相同的字形码,但究竟是那个数码管会显示出字形,取决于单片机对位选通COM端电路的控制,所以我们只要将需要显示的数码管的选通控制打开,该位就显示出字形,没有选通的数码管就不会亮。
通过分时轮流控制各个数码管的的COM端,就使各个数码管轮流受控显示,这就是动态驱动。
在轮流显示过程中,每位数码管的点亮时间为1~2ms,由于人的视觉暂留现象及发光二极管的余辉效应,尽管实际上各位数码管并非同时点亮,但只要扫描的速度足够快,给人的印象就是一组稳定的显示数据,不会有闪烁感,动态显示的效果和静态显示是一样的,能够节省大量的I/O端口,而且功耗更低。
(2)主要参数
8字高度:
8字上沿与下沿的距离。
比外型高度小。
通常用英寸来表示。
范围一般为0.25-20英寸。
长*宽*高:
长——数码管正放时,水平方向的长度;
宽——数码管正放时,垂直方向上的长度;
高——数码管的厚度。
时钟点:
四位数码管中,第二位8与第三位8字中间的二个点。
一般用于显示时钟中的秒。
数码管应用
数码管是一类显示屏通过对其不同的管脚输入相对的电流会使其发亮从而显示出数字
能够显示时间日期温度等所有可用数字表示的参数
由于它的价格便宜使用简单在电器特别是家电领域应用极为广泛空调热水器冰箱等等
绝大多数热水器用的都是数码管其他家电也用液晶屏与荧光屏
数码管使用的电流与电压
电流:
静态时,推荐使用10-15mA;
动态时,16/1动态扫描时,平均电流为4-5mA,峰值电流50-60mA。
电压:
查引脚排布图,看一下每段的芯片数量是多少?
当红色时,使用1.9V乘以每段的芯片串联的个数;
当绿色时,使用2.1V乘以每段的芯片串联的个数。
(3)常见问题
恒流驱动与非恒流驱动对数码管的影响
1、显示效果:
由于发光二极管基本上属于电流敏感器件,其正向压降的分散性很大,并且还与温度有关,为了保证数码管具有良好的亮度均匀度,就需要使其具有恒定的工作电流,且不能受温度及其它因素的影响。
另外,当温度变化时驱动芯片还要能够自动调节输出电流的大小以实现色差平衡温度补偿。
2、安全性:
即使是短时间的电流过载也可能对发光管造成永久性的损坏,采用恒流驱动电路后可防止由于电流故障所引起的数码管的大面积损坏。
另外,我们所采用的超大规模集成电路还具有级联延时开关特性,可防止反向尖峰电压对发光二极管的损害。
超大规模集成电路还具有热保护功能,当任何一片的温度超过一定值时可自动关断,并且可在控制室内看到故障显示。
为什么数码管亮度不均匀?
关于亮度一致性的问题是一个行业内的常见问题。
有二个大的因素影响到亮度一致性。
一是使用原材料芯片的选取,一是使用数码管时采取的控制方式。
1、原材料--芯片的VF和亮度和波长是一个正态分布,
即使筛选过芯片,VF和亮度和波长已在一个很小的范围了,生产出来的产品还是在一个范围内,结果就是亮度不一致。
2、要保证数码管亮度一样,在控制方式选取上也有差别
最好的办法是恒流控制,流过每一个发光二极管的电流都是相同的,这样发光二极管看起来亮度就是一样的了。
如恒压控制,则导致VF不相同的发光二极管分到的电流不相同,所以亮度也不同。
当然以上二个条件是相辅相成的。
怎样测量数码管引脚,分共阴和共阳?
找公共共阴和公共共阳:
首先,我们找个电源(3到5伏)和1个1K(几百欧的也行)的电阻,VCC串接个电阻后和GND接在任意2个脚上,组合有很多,但总有一个LED会发光的,找到一个就够了,然后GND不动,VCC(串电阻)逐个碰剩下的脚,如果有多个LED(一般是8个),那它就是共阴的了。
相反用VCC不动,GND逐个碰剩下的脚,如果有多个LED(一般是8个),那它就是共阳的。
也可以直接用数字万用表,红表笔是电源的正极,黑表笔是电源的负极。
二硬件设计
1硬件电路设计
(1)显示电路
1)74LS48是一款常用的共阳极数码管专用译码芯片。
它实现的功能是从BCD码到七段数码管的译码和驱动。
引脚图如图2-1所示。
它的a~g脚接七段数码管的七段数字段,而A、B、C、D引脚接单片机的数据线,3个控制引脚接高电平。
这样当A、B、C、D4个引脚输入0~15的数据时,跟它相连接的数码管就显示相应的字符。
2)74LS138芯片是位选译码器,它的A、B、C引脚接单片机的数据线,这样当A、B、C3个引脚输入0~5的数据时,跟它相连接的相应数码管工作。
图2-2显示电路
3)系统显示电路采用了3个2位共阴数码管,如图2-1所示。
3个数码管使用一块74LS138译码器作为位选输出,与主片CPU的P1口低三位相连;
同时采用一块74LS48作为段选译码,与主片CPU的P1口高四位相连。
用74LS48作为段选译码器,则需要在它与数码管之间串联电阻(设计中用了8个300Ω的电阻),其作用是限流,保护数码管灯不被大电流烧坏。
(2)键盘电路
对于图3-3的按键连接,一般情况下在按键被按下和被释放的瞬间,单片机读到的数据并不是理想中的从高电平到低电平和从低电平到高电平的跳变,而是如图3-4所示的有抖动的电压波形。
图2-4中的抖动是由按键的机械特性所决定的,抖动时间一般为10ms左右。
如果不对按键抖动做任何处理而直接读取,对相对操作者来说速度非常快的单片机,在按键被按下和被释放的过程中相当于有多次按下和释放的操作。
为了保证单片机对按键输入的正确判断,必须对按键抖动做出处理,这个过程叫做按键的去抖。
去抖可以采用硬件和软件两种方法。
硬件方法就是在按键的输入通道里加入一定的去抖电路,如加入一个电容或低通滤波器,靠其积分作用来消除抖动;
软件方法是指采用延时的方法把抖动的时间抛掉,等电压稳定之后再读取按键的状态。
由于抖动时间与整个按键操作时间相比很小,所以延时不会对按键状态的判断产生什么影响。
而且软件去抖省去了硬件电路,变得更加经济实用。
装置的键盘电路采用4×
4矩阵键盘电路与主片CPU的P2口连接,电路图如图2-5所示。
键盘电路中没有接上拉电阻,是因为单片机的P2口内有上拉电阻。
图2-5键盘电路
(3)复位电路
复位电路是使单片机的CPU或系统中的其它部件处于某一确定的初始状态,并从这个状态开始工作。
当程序运行出错或操作错误使系统处于死机状态时,则需要有复位键来恢复CPU的正常工作。
通常单片机复位操作有上电复位、信号复位、运行监视复位,运行监视有程序运行监视和电源监视。
系统复位电路如图2-6所示:
上电复位要求接通电源后,单片机自动实现复位操作。
上电瞬间CPU的RESET引脚获得高电平,随着电容的充电,RESET引脚的高电平将逐渐下降。
RESET引脚的高电平只要能保持足够的时间(2个机器周期),单片机就可以进行复位操作。
图2-6复位电路
(4)电源设计
电源的稳压电路根据调整元件类型可以分为电子管稳压电路、三极管稳压电路、可控硅稳压电路、集成稳压电路等;
根据调整元件与负载连接方法,可以分为串联型和并联型;
根据调整元件工作状态不同,可以分线性和开关稳压电路。
直流稳压电源一般由电源变压器、整流滤波电路及稳压电路所组成。
由于本系统对电源要求相对较高,所以配备了一个独立的开关电源,其输出电压为+5V,输出电流为1000mA。
(5)时钟电路设计
时钟电路用于产生单片机工作所需的时钟信号,而时序所研究的是指令执行中各信号之间的相互联系。
单片机本身就如一个复杂的同步时序电路,为了保证同步工作方式的实现,电路应在唯一的时钟信号控制下严格的工作。
系统时钟振荡电路如图3-7所示。
图3-7时钟振荡电路
单片机内部有一个高增益反相放大器,其输入端为芯片引脚XTAL1,其输出端为引脚XTAL2。
而在芯片外部,XTAL1和XTAL2之间跨接晶体振荡器和微调电容,从而构成一个稳定的自激振荡器。
只要在单片机的XTAL1和XTAL2引脚外接晶体振荡器就构成了自激振荡器并在单片机内部产生时钟信号。
电容C1和C2的作用是稳定频率和快速起振,电容值在5-30pF之间。
外部时钟方式是把外部已有的时钟信号引入到单片机内。
一般要求外部信号高电平的持续时间大于20ns,且为频率不大于12MHz的方波。
(4)输出电路
1)电路要对48个继电器进行单独控制,则所需主片CPU的I/O口就要有48个,而主片CPU的I/O口显然是不能满足的。
所以必须扩展I/O口。
电路采用两片单片机与主片CPU并行连接来扩展I/O口,电路原理图如图2-8所示。
用从片U2和U3的P0口分别与主片CPUP1口的低五位和P3口的高五位连接,则两从片CPU剩余的I/O口数刚好为48个。
为了保证数据同步,3块CPU的晶振频率全部为12MHz。
图2-8I/O口扩展电路
2)用两从片剩余的48个I/O口与48个继电器输出控制电路一一对应的连接。
继电器输出控制电路由继电器和ULN2003芯片连接组成。
一片ULN2003芯片有8路输入和8路输出,输入口接单片机,输出口接继电器。
ULN2003具有很强的驱动能力,它可以直接驱动继电器。
其原理图如图2-9所示。
(5)系统原理图
系统总原理图如图3-10所示,
图3-10修电工智能排故系统装置总原理图
2.PC