《电子技术应用》
您所在的位置:首页 > 电源技术 > 设计应用 > AT89C51多路数控直流稳压电源
AT89C51多路数控直流稳压电源
摘要: 本文以单片机为核心,构成可同时控制6路正负输出,具有定点显示和巡回显示等功能的数控直流稳压电源。
Abstract:
Key words :
  当今社会人们极大的享受着电子设备带来的便利,但是任何电子设备都有一个共同的电路--电源电路,直流电源趋向多功能和数字化方向。直流稳压电源的供电电源大都是交流电源,当交流供电电源的电压或负载电阻变化时,稳压器的直流输出电压都会保持稳定。直流稳压电源随着电子设备向高精度、高稳定性和高可靠性的方向发展,对电子设备的供电电源提出了高的要求。本文以单片机为核心,构成可同时控制6路正负输出,具有定点显示和巡回显示等功能的数控直流稳压电源。

  1系统的功能和特点

  系统有6路电压输出,其中3路为正,3路为负。电压调节范围为0~35V,最大输出电流(A)分别为5,2和1,具有过流保护功能。数字显示有5位,其中1位显示路号,1位显示电压极性,另3位显示输出电压。键盘设有16个键,数字键0~9及小数点键用于设定电压输出路号及幅值;“↑”键为逐步增加输出电压或路号;“↓”键为逐步减少输出电压或路号;“CLR”键用于清除错误输入,恢复原先状态;“#”键用于启动电压设定状态和确认新设定;“@”键为巡回显示和定点显示切换键。

  本系统设有巡回显示、定点显示和电压设定3种工作状态。当接通电源时,自动设置为巡回显示状态,它将每隔4s在显示器上巡回显示不同路号和相应电压。若再按“#”,则电压显示值出现闪烁现象,表示进入电压设定状态。如果依次按下“2”,“6”,“·”,“3”,再按“#”键确认,新的电压26.3V为实际输出,设定完毕。也可以在电压设定状态下,用“↑”键和“↓”键以0.1V的增量设定电压。系统设有自动识别功能,将不接受超出使用范围的电压设定值。在未按“#”键之前,对误输入的电压可以用“CLR”键清除后重新设定。在定点显示态,可用数字键、“↑”或“↓”键选择监视的电压路号。同样地,系统将不接受超出实际范围的路号设定值。输出电压的正负值由系统自动给出,无需用户输入。巡回显示和定点显示的切换按“@”键即可。

  2硬件电路分析

  系统选用AT89C51单片机为控制核心,完全兼容了8031单片机的指令和功能。同时,它还增加了内置4KB闪速存储器,具有128B内部RAM,3个I/O口,功耗低,体积小巧,不需扩展存储器就能满足系统要求。图1为系统硬件原理图。

系统硬件原理图

  2.1电压输出回路

  电压输出回路原理,如图2所示。其调整管采用共射极连接方式,与常见的共集极连接方式相比,功耗和纹波系数大为降低。增并调整管,适当增加BG2的容量即可扩展功率输出容量。由于电压反馈调节采用了比例积分调节器,输出电压在正常的工作区能完全地跟踪控制电压Uin.经过推导,可得稳态的输出电压值Uo=WinRw/Rr.Rb及BG3等构成过流保护电路。理论可以证明,该回路近似为一阶控制系统,具有绝对的稳定性。因此,它十分适合于系统的设计要求,详细的分析说明可参见文献〔2〕。

电压输出回路原理

  2.2控制电压给定回路

  控制电压给定回路由单片机、D/A转换器和采样保持器等组成。控制电压由D/A提供,系统采用了开环控制方式。一般说来,开环控制的抗干扰能力和精度差〔3〕。但由于本电压输出电路采用了特有的结构,能实现无静差调节。这样,可以省去类似文献〔2〕电路中的A/D采样和比较电路,既降低了成本,又简化了结构。其控制算法简单,可靠性显着增强。D/A输出一般很稳定,但分辨率有限。按本系统的设计要求,输出电压的分辨率必须大于0.1V.已知稳压输出量程为0~35V,若D/A的量程和参考电压以5V计,则D/A的分辨率B应满足2B>35/0.1,B>8.4.故可采用10或12位的D/A转换器。为保证一定裕量,系统采用DAC1210.本系统具有多路正负输出,考虑到高位D/A转换器价格较高。采样-保持电路由数据锁存器74LS273,以及6块采样-保持器LF398组成。当DAC1210输出第N路(1≤N≤6)控制电压时,通过74LS273的第N位输出状态的改变,使相应路的采样/保持器LF398由保持状态变为采样状态。然后,再恢复成保持状态,从而实现对控制电压的采样和保持。

  2.3显示和键盘接口电路

  考虑到本系统监控软件的负担较重,显示采用了静态显示模式〔5〕。不难发现,电源输出的极性决定于输出电压回路的电路结构,与路号有一一对应的关系。因而,可由软件自动设置。故两块数码管完全可以共享一组8位显示数据。这样5位LED只需设4个锁存器(74LS273)。键盘电路设置于P1口,为典型的4×4中断扫描键盘。

  3系统软件设计

  本软件设计通过合理安排中断和划分各功能模块,设置统一的状态字,有效克服了系统的功能多、状态转换复杂给软件设计带来的困难。系统软件流程图,如图3所示。

系统软件设计

  3.1状态字设计

  状态字(SB)占用一个字节,有效位为5位。状态字通道被启动后,控制指定的设备完成规定的操作,同时,通道在执行对外围设备控制的过程中,要记录通道与设备执行情况,为此系统在主存中安排另一个固定单元,用于存放这些被记录状态,有

  SB.0=1,表示处于巡回显示状态,SB.0=0,无意义;

  SB.1=1,表示处于定点显示状态,SB.0=0,无意义;

  SB.2=1,表示处于电压设定状态,SB.0=0,无意义;

  SB.3=1,表示电压设定值有误,SB.3=0,表示电压设定值正确;

  SB.4=1,表示电压非首次数字设定,SB.4=0,表示电压首次数字设定。

  3.2各功能处理模块

  主程序。进行系统初始化设定(I/O口、定时、中断、状态字、各数据缓冲区等初始化),等待中断。定时中断服务程序。输出电压的稳定性是稳压器最重要的指标。考虑到采样-保持器输出有一缓慢的下降速率(当LF398保持电容为0.1μF时,下降速率约200V·min-1),故需定时对其进行保持和电压刷新。本服务程序完成各路电压值刷新和显示。中断申请由定时/计数器T0提出,每隔130ms中断一次,中断服务级为最高级。键盘中断服务程序。根据键码和当前状态字,跳转相应的功能处理程序,中断由INT0引入。键扫描译码程序。将0~9、小数点,以及其它按键译成对应00H~0FH的十六进制码。显示译码程序。将键码缓冲区的内容译成七段码并存入相应的显示缓冲区。D/A译码程序。将键码缓冲区的内容译成对应的12位D/A二进制数码,并存入相应的D/A数据缓冲区(一路输出占2B)。显示子程序。根据路数,将该路数据缓冲区的内容与屏蔽字相或后,送对应数管。错程识别序1.在电压设定状态,判定键入数字码后,键码缓冲区数据格式的错误,恢复键入前的状态并给出相应标志(SB.3)。错程识别序2.在电压设定状态,判定键入“↑”键、“↓”键后,键码缓冲区数据格式的错误恢复键入前的状态,并给出相应标志(SB.3)。

  3.3数据缓冲区设定

  互方之一定义用于数据交换的底层内存分配机制。另一方总是使用已公布的接口来分配或释放缓冲区,从而避免潜在的不一致。这种模型需要双方都坚持一个可能与软件基本功能无关的编程约定,而且在一般情况下,这个编程约定可能使代码更加不可重用。

  驱动数据交换的那一方将负责管理操作——当该方充当数据提供者时,这是一个相对适当的方案。然而,当该方充当数据使用者时,事情就变得棘手了。为避免去发现数据大小,数据使用者可以分配一个任意大小的缓冲区。如果该数据缓冲区没有足够大,就必须对数据提供者发出多次调用。因此这种方法需要围绕该交互调用编写额外的循环代码,以备多次调用之需。

  (1)D/A数据缓冲区。存放各路输出的D/A值二进制码,每路占2B,共12B.(2)键码缓冲区。在电压设定状态,存储键入的数值码(包括小数点),一键码用4位二进制数表示。故每路占2B,共12B.(3)显示缓冲区。存储各路输出电压显示七段码(含路数、输出极性、电压大小),每路占4B,共24B.(4)键码备份缓冲区。进入电压设定状态时,程序将复制当前路键码缓冲区的内容并存入此区,共2B.(5)显示备份缓冲区。进入电压设定状态时,程序将复制当前路显示缓冲区的内容并存入此区,共4B.

  除了上述困难之外,安全性也证明是传统方法存在的问题:传统缓冲区管理方案无法容易地防止恶意用户刻意改写数据缓冲区,从而导致程序异常。考虑到所有这一切,设计一个适当的数据缓冲区接口就势在必行!

  4结束语

本文将单片机控制回路与无静差的电压输出回路有机结合,构成一款新式多路数字可调功率直流稳压电源,非常适合一般教学和科研使用。单片机、DAC与其它外围电路独立供电。DAC采用高稳定性的基准电源为参考电压,面板电源开关可设计成仅切断输出回路的供电电源。还要注意选择特性较理想的、功率适当的晶体管,加装大小适当的散热片。这样,一般不需太多调试就能获得成功。因此,本电源推广容易,可望获得广泛的应用。



 

此内容为AET网站原创,未经授权禁止转载。