数控直流电源的设计(论文).doc
毕业设计(论文)题目名称:数控直流电源的设计年 级: 本科 专科学生学号: 学生姓名: 指导教师: 学生单位: 技术职称: 学生专业:通信工程 教师单位: 数控直流电源的设计 摘要:随着时代的发展,数字电子技术已经普及到我们生活中的各个领域,本文将介绍一种数控直流稳压电源,本电源由模拟电源、显示电路、控制电路、数模转换电路、放大电路五部分组成。准确说就是模拟电源提供各个芯片电源、数码管、放大器所需电压;显示电路用于显示电源输出电压的大小。数控直流电流源能够很好地降低因元器件老化等原因造成的输出误差,最大输出电流2A,最高输出电压30V,电流、电压都具有步进为0.1。硬件电路ATmega8为控制核心,利用闭环控制原理,加上反馈电路,使整个电路构成一个闭环,在软件方面主要利用PID算法来实现对输出电流的精确控制。该系统可靠性高、体积小、操作简单方便、人机界面友好。关键词:数控;直流电源;ATmega8The Design of Numerical Control DirectCurrent PowerAbstract: With the development of the times, digital electronic technology has been popular in all of our lives, work, research, and all fields. This paper introduces a NC DC power supply, the power consists of analogue power supply, display circuit, control circuit, digital-to-analog converter and circuit amplifier. Accurately, analog power supplies voltage for chip power, the digital tube and amplifier; display circuit displays the output voltage. NC DC current source can reduce output error that caused by components aging, with functions of the maximum output current is up to 2A, the maximum output voltage is 30 V, current and voltage are stepping to 0.1 adjustment, output current signal can be shown directly. ATmega8 hardware circuit is the core of control, taking advantage of the closed-loop control principle and feedback circuit, so that the whole constitute a closed-loop circuit. In terms of software it mainly uses the PID algorithm to achieve the precise control of output current. The system has good features of high reliability, small size, simple operation and friendly man-machine interface.Key word: Numerical Control,Direct Current,ATmega8目 录第1章绪 论11.1研究背景及意义11.2国内外研究现状11.3课题研究方法2第2章方案与元件的选择及设计基础知识32.1方案设计与论证32.2单片机的选择52.2.1Mega8-8L简介52.2.2引脚说明62.3液晶显示屏(1602)显示的选择及串口实现原理72.3.1液晶显示屏(1602)简要说明72.4电流驱动管的选择82.5运算器的选择92.5.1LM358M简介92.5.2NE5532AP简介92.6设计基础知识102.6.1相位修正PWM模式102.6.2模数转换器122.6.3ADC 输入通道142.6.4ADC 基准电压源142.6.5模拟输入电路15第3章电路原理和硬件实现163.1电路原理框图163.2 各部分电路图实现分析163.2.1 MCU173.2.2 MCU电源模板183.2.3 显示模板193.2.4 电源输出模板20第4章程序设计224.1主流程框图224.2 主程序框图234.3 程序运行原理234.3.1上电MCU初始化234.3.2液晶显示屏(1602)的运行244.3.3主程序264.3.4按键扫描264.3.5AD转换26第5章 系统调试275.1软件测试275.2系统整体调试275.2.1电压测试275.2.2电流测试285.3ADC 精度分析29结论30参考文献33致谢34附录 设计全程序35 第1章绪 论 1.1研究背景及意义直流稳压电源是电子技术常用的设备之一,广泛的应用于教学、科研等领域。传统的多功能直流稳压电源功能简单、难控制、可靠性低、干扰大、精度低且体积大、复杂度高。普通直流稳压电源品种很多, 但均存在以下二个问题: 1、输出电压是通过粗调(波段开关) 及细调(电位器)来调节。这样, 当输出电压需要精确输出,或需要在一个小范围内改变时(如1. 05 1. 07V ) ,困难就较大。另外, 随着使用时间的增加,波段开关及电位器难免接触不良,对输出会有影响。2、稳压方式均是采用串联型稳压电路,对过载进行限流或截流型保护,电路构成复杂,稳压精度也不高。在家用电器和其他各类电子设备中,通常都需要电压稳定的直流电源供电。但在实际生活中,都是由220V 的交流电网供电。这就需要通过变压、整流、滤波、稳压电路将交流电转换成稳定的直流电。滤波器用于滤去整流输出电压中的纹波,一般传统电路由滤波扼流圈和电容器组成,若由晶体管滤波器来替代,则可缩小直流电源的体积,减轻其重量,且晶体管滤波直流电源不需直流稳压器就能用作家用电器的电源,这既降低了家用电器的成本,又缩小了其体积,使家用电器小型化。传统的直流稳压电源通常采用电位器和波段开关来实现电压的调节,并由电压表指示电压值的大小。因此,电压的调整精度不高,读数欠直观,电位器也易磨损。而基于单片机控制的直流稳压电源能较好地解决以上传统稳压电源的不足。随着科学技术的不断发展,特别是计算机技术的突飞猛进,现代工业应用的工控产品均需要有低纹波、宽调整范围的高压电源,而在一些高能物理领域,更是急需电脑或单片机控制的低纹波、宽调整范围的电源。1.2国内外研究现状从上世纪九十年代末起,随着对系统更高效率和更低功耗的需求,电信与数据通讯设备的技术更新推动电源行业中直流/直流电源转换器向更高灵活性和智能化方向发展。在80年代的第一代分布式供电系统开始转向到20世纪末更为先进的第四代分布式供电结构以及中间母线结构,直流/直流电源行业正面临着新的挑战,即如何在现有系统加入嵌入式电源智能系统和数字控制。早在90年代中,半导体生产商们就开发出了数控电源管理技术,而在当时,这种方案的性价比与当时广泛使用的模拟控制方案相比处与劣势,因而无法被广泛采用。由于板载电源管理的更广泛应用和行业能源节约和运行最优化的关注,电源行业和半导体生产商们便开始共同开发这种名为“数控电源”的新产品。现今随着直流电源技术的飞跃发展,整流系统由以前的分立元件和集成电路控制发展为微机控制,从而使直流电源智能化,具有遥测、遥信、遥控的三遥功能,基本实现了直流电源的无人值守。1.3课题研究方法直流稳压电源是最常用的仪器设备,在科研及实验中都是必不可少的。针对以上问题,我们设计了一套以单片机为核心的智能化直流电源。该电源可以键控,可对输出电压从0.1V到20V(步进0.1V),输出电流从0.1A到2A(步进0.1A),输出由单片机输出PWM波 ,经过滤波后,成为稳定的直流电压控制到场效管。同时稳压方法采用单片机闭环控制,单片机通过A/D 采样输出电压,与设定值进行比较,若有偏差则调整输出,假如越限,那么单片机PWM值减小直到电压输出与设定值相同,假如不到,那么单片机PWM值增加直到电压输出与设定值相同。工作过程中,稳压电源的工作状态(输出电压、电流等各种工作状态) 均由单片机输出驱动液晶显示屏(1602)显示。第2章方案与元件的选择及设计基础知识2.1方案设计与论证根据设计的要求: 1、最大输出电流2A,最高输出电压30V。 2、电压步进0.1V,电流步进0.1A。3、纹波系数尽可能小,输出稳定。4、有限按键操作方便,LCD显示界面。5、闭环控制理论的嵌入式软件实现。特色及基本技术路线:1、低成本解决方案。2、直观的实验效果。3、经典理论验证平台先硬件后软件,先局部后整体。我设计出以下几个方案:方案一:设计开关电源。在前期方案设计中采用PWM脉宽调制。它的功耗小,效率高,稳压范围宽,电路形式灵活多样,功耗小,效率高。在制作过程中发现,PWM占空比的线性变化使相应的电流呈非线性变化,经分析发现滤波电容的存在对占空比很小的PWM波积分效果明显,导致电流的非线性变化更显著,特别是PWM占空比很小时(希望得到输出的电流很小)输出有几十毫伏的电流,PWM脉宽调制会产生高次谐波导致输出电流的纹波电流比较大,加大滤波电容后电流纹波相对减小,但积分作用更加明显。 方案二:用D/A和运算放大器做电流源,即采用D/A输出调节晶体管的偏值电流(电压)。采用此方案能有效的缩短调节时间,并能提高输出精度。但8位D/A芯片的精度达不到题目所需要的精度(步进10mA)。经计算需要采用12位的D/A芯片,但是12位D/A芯片的价格过于昂贵,并且在短时间内很难到货。因此,可以采用双D/A芯片来解决此问题。采用两片DAC8032,一路DAC8032作为粗调,另一路DAC8032作为精调,并通过运算放大器对两路D/A转换电压做加法运算,再经过一级运算放大器后推动后级电流驱动电路,通过电流采样电阻两断的电压给单片机,单片机再控制D/A的输出,形成闭环负反馈调节回路。粗调当中DAC8032的基准电压ref=5V,则一个LSB对应的电压调节精度为4.8mV。精调当中DAC8032的ref=1.25V,则一个LSB对应的电压调节精度为1.2mV。此方案原理上把两个八位的DAC当成16位的DAC应用(实际上由于运算放大器有失调电压存在只能实现10位的精度)。这种方案调节电流是靠调节晶体管的偏值电流实现的,理论上是线性调节,不会产生高次谐波。框图如下:图2-1方案二原理框图方案三:用D/A和运算放大器做电流源,即采用D/A输出调节晶体管的偏值电流(电压)。采用此方案能有效的缩短调节时间,并能提高输出精度。但8位D/A芯片的精度达不到题目所需要的精度。经计算需要采用10位的D/A芯片。为了争取时间,降低成本,我们的解决方案是采用的ATmega8,一路由PWM1的输出,通过积分整形出很平滑的直流电源控制场效应管输出的大小,改变电压的大小,当单片机通过闭环负反馈调节回路的A/D转换检测到电压没达到设定值时,将再次对输出电压进行调制,直到输出电压达到设定值;另一路同样由PWM2的输出,通过积分整形出很平滑的直流电源控制场效应管输出的大小,改变电流的大小,当单片机通过闭环负反馈调节回路的A/D转换检测到电流没达到设定值时,将再次对输出电流进行调制,直到输出电压达到设定值,调节电流是靠调节晶体管的偏值电流实现的,理论上是线性调节,不会产生高次谐波。这种方案易于实现,既保证了调节精度,又降低制作成本。方案原理示意图见图2-2:键盘处理器LCD显示PWM1A/D1PWM2A/D2积分积分电压控制电流控制电压采样电流采样图2-2方案三原理框图依据设计要求中说提出的特色及基本技术路线,所以最后选用方案三。2.2单片机的选择 2.2.1Mega8-8L简介ATmega8是基于增强的AVR RISC结构的低功耗8位CMOS微控制器。由于其先进的指令集以及单时钟周期指令执行时间,ATmega8 的数据吞吐率高达1MIPS/MHz,从而可以缓减系统在功耗和处理速度之间的矛盾。ATmega8 有如下特点:8K 字节的系统内可编程Flash( 具有同时读写的能力,即RWW),512 字节 EEPROM,1K 字节 SRAM,32 个通用I/O 口线,32 个通用工作寄存器,三个具有比较模式的灵活的定时器/ 计数器(T/C),片内/ 外中断,可编程串行USART,面向字节的两线串行接口,10 位6 路 (8 路为TQFP 与MLF 封装)ADC,具有片内振荡器的可编程看门狗定时器,一个SPI 串行端口,以及五种可以通过软件进行选择的省电模式。工作于空闲模式时CPU 停止工作,而SRAM、T/C、 SPI 端口以及中断系统继续工作;掉电模式时晶体振荡器停止振荡,所有功能除了中断和硬件复位之外都停止工作;在省电模式下,异步定时器继续运行,允许用户保持一个时间基准,而其余功能模块处于休眠状态; ADC 噪声抑制模式时终止CPU 和除了异步定时器与ADC 以外所有I/O 模块的工作,以降低ADC 转换时的开关噪声; Standby 模式下只有晶体或谐振振荡器运行,其余功 能模块处于休眠状态,使得器件只消耗极少的电流,同时具有快速启动能力。本芯片是以Atmel 高密度非易失性存储器技术生产的。片内ISP Flash 允许程序存储器通过ISP 串行接口,或者通用编程器进行编程,也可以通过运行于AVR 内核之中的引导程序进行编程。引导程序可以使用任意接口将应用程序下载到应用Flash存储区(Application Flash Memory)。在更新应用Flash存储区时引导Flash区(Boot Flash Memory)的程序继续运行,实现了RWW 操作。 通过将8 位RISC CPU 与系统内可编程的Flash 集成在一个芯片内,ATmega8 成为一个功能强大的单片机,为许多嵌入式控制应用提供了灵活而低成本的解决方案。2.2.2 引脚说明引脚图如下所示:图2-3ATmega8引脚图1、VCC :数字电路的电源。2、GND :地。3、端口B(PB7.PB0)XTAL1/XTAL2/TOSC1/TOSC2:端口B 为8 位双向I/O 口,具有可编程的内部上拉电阻。其输出缓冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,端口被外部电路拉低时将输出电流。在复位过程中,即使系统时钟还未起振,端口B 处于高阻状态。通过时钟选择熔丝位的设置,PB6 可作为反向振荡放大器或时钟操作电路的输入端。通过时钟选择熔丝位的设置PB7 可作为反向振荡放大器的输出端。若将片内标定RC 振荡器作为芯片时钟源,且ASSR 寄存器的AS2 位设置,PB7.6 作为异步 T/C2 的TOSC2.1 输入端。端口B 的其他功能见P 55“ 端口B 的第二功能” 及P 22“ 系统时钟及时钟选项” 。4、端口C(PC5.PC0) :端口C 为7 位双向I/O 口,具有可编程的内部上拉电阻。其输出缓冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,端口被外部电路拉低时将输出电流。在复位过程中,即使系统时钟还未起振,端口C 处于高阻状态。5、PC6/RESET :若RSTDISBL 熔丝位编程,PC6 作为I/O 引脚使用。注意PC6 的电气特性与端口C 的其他引脚不同若RSTDISBL 熔丝位未编程,PC6 作为复位输入引脚。持续时间超过最小门限时间的低电平将引起系统复位。门限时间见P 35Table 15 。持续时间小于门限时间的脉冲不能保证可靠复位。端口C 的其他功能见后。6、端口D(PD7.PD0): 端口D 为8 位双向I/O 口,具有可编程的内部上拉电阻。其输出缓冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,则端口被外部电路拉低时将输出电流。在复位过程中,即使统时钟还未起振,端口D 处于高阻状态。端口D 的其他功能见后。7、RESET :复位输入引脚。持续时间超过最小门限时间的低电平将引起系统复位。门限时间见 P35Table 15 。持续时间小于门限时间的脉冲不能保证可靠复位。AVCC:AVCC 是A/D转换器、端口C (3.0) 及ADC (7.6) 的电源。不使用ADC时,该引脚应直接与VCC 连接。使用ADC 时应通过一个低通滤波器与VCC 连接。注意,端口C (5.4) 为数字电源,VCC。8、AREF: A/D 的模拟基准输入引脚。9、ADC7.6(TQFP 与MLF 封装): TQFP与MLF封装的ADC7.6作为A/D转换器的模拟输入。为模拟电源 且作为10位ADC通道。2.3液晶显示屏(1602)显示的选择及串口实现原理2.3.1液晶显示屏(1602)简要说明表2-1 主要技术参数显示容量162个字符芯片工作电压4.55.5V工作电流2.0mA(5.0V)模块最佳工作电压5.0V字符尺寸2.954.35(WXH)mm表2-2 接口信号说明编号符号引脚说明1VSS电源地2VDD电源正极3VL液晶显示偏压信号4RS数据/命令选择端(H/L)5R/W读/写选择端(H/L)6E使能信号7D0Data 1/08D1Data 1/09D2Data 1/010D3Data 1/011D4Data 1/012D5Data 1/013D6Data 1/014D7Data 1/015BLA背景光源正极16BLK背景光源负极2.4电流驱动管的选择电流驱动管的选择是极其重要的。首先要求该管的功率要大,因为本题要求最大电流是2A,那么至少要选用5A以上的功率管。此时有两种选择:三极管和场效应管。就本题来看,由于缓冲器属于电压驱动,那么最好选用场效应管。但我们采用了IR公司的IRF840,其参数如下:IRF840 单元绝对最大额定功率 Tc=25oC 1、漏极到源极电压:VDS 500V2、漏极到门极电压:(RGS=20kW)VDGR 500V3、连续漏极电流:ID 8.0 A4、TC = 100oC : ID 5.1 A5、脉冲漏极电流:IDM 32 A6、门极到源极电压:VGS ±20 V7、最大功率耗散Dissipation :PD 125 W8、线性减额因子:1.0 W/oC9、单脉冲雪崩能量功率:EAS 510 mJ10、运行与存储温度:TJ,TSTG -55 to 150 oC11、最大焊接温度离箱子1.6毫米 10秒:TL,300oC注意:施加的参数超过在“绝对最大额定功率”里列出的可能会给设备带来永久性的损害。这只是一个设备的运行申明,在这些或任何其他条件高出在这个说明中的操作部分的都没有被包含进来。如上参数已经满足设计要求,加上按照要求温度对该管子的性能影响很小,静态电流噪声小(有效避免电路产生纹波),所以选用了IRF840作为方案的电流驱动管。2.5运算器的选择2.5.1LM358M简介LM358系列由两个独立的,高增益的,内部频率补偿的运作放大器,它们是特别用来在基于大范围的电压运作的单电源供电上工作的。来自分离式电源的运行也同样可行,而且低电源电流和电源电压的数值是独立的。应用区域包括转换放大器,直流增益阻隔和所有现在能在单电源系统更简单运用的一般运算放大器。比如,LM518系列能直接独立运行于标准的被用在数字系统的+5V电源供电,而且能简易的无需另一个±15V。电源供电的前提下提供所需的接口电子。基于国家微SMD封装技术的固定封装(8微SMD)的芯片上的LM358和LM2904已经能够获得。2.5.2NE5532AP简介NE5532AP的基本常数如下:1、平均输入噪声电压 : 5nV/ Typ at 1kHz2、联合增益带宽: 10 MHz Typ3、普通模式电阻率: 100 dB Typ4、高直流增益: 100V/mV Typ5、波峰到波峰输出电压摆幅: =18 V 和 =600Typ6、高回转率: 9 V/Typ7、宽供电电压范围: 3V 20 VNE5532AP的引脚图如下:图2-7NE5532AP引脚图最后,经过再三地比较,在运算器的选择上,还是选择使用LM358M。2.6设计基础知识2.6.1相位修正PWM模式相位修正PWM 模式(WGM13:0 = 1、 2、 3、10 或11) 为用户提供了一个获得高精度的、相位准确的PWM 波形的方法。与相位和频率修正模式类似,此模式基于双斜坡操作。计时器重复地从BOTTOM 计到TOP,然后又从TOP 倒退回到BOTTOM。在一般的比较输出模式下,当计时器往TOP 计数时若TCNT1 与OCR1x 匹配,OC1x 将清零为低电平;而在计时器往BOTTOM 计数时若TCNT1 与OCR1x 匹配,OC1x 将置位为高电平。工作于反向比较输出时则正好相反。与单斜坡操作相比,双斜坡操作可获得的最大频率要小。但其对称特性十分适合于电机控制。相位修正PWM 模式的PWM 分辨率固定为8、9 或10 位,或由ICR1 或OCR1A 定义。最小分辨率为2比特(ICR1或OCR1A设为 0x0003),最大分辨率为16位(ICR1或OCR1A设为MAX)。PWM 分辨率位数可用下式计算:(21)工作于相位修正PWM 模式时,计数器的数值一直累加到固定值0x00FF、0x01FF、0x03FF (WGM13:0 = 1、 2 或3)、ICR1 (WGM13:0 = 10) 或OCR1A (WGM13:0 = 11),然后改变计数方向。在一个定时器时钟里TCNT1 值等于TOP 值。具体的时序图为 图24。图中给出了当使用OCR1A或ICR1来定义TOP值时的相位修正PWM模式。图中柱状的TCNT1 表示这是双边斜坡操作。方框图同时包含了普通的PWM 输出以及反向PWM输出。TCNT1 斜坡上的短水平线表示OCR1x 和TCNT1 的匹配比较。比较匹配后OC1x中断标志置位。相位修正PWM 模式的时序图如下:图2-4相位修正PWM 模式的时序图计时器数值达到BOTTOM 时T/C 溢出标志TOV1 置位。若TOP 由OCR1A 或ICR1 定义,在OCR1x 寄存器通过双缓冲方式得到更新的同一个时钟周期里OC1A 或ICF1 标志置位。标志置位后即可产生中断。改变TOP值时必须保证新的TOP值不小于所有比较寄存器的数值。否则TCNT1与OCR1x不会出现比较匹配。使用固定的TOP 值时,向任意OCR1x 寄存器写入数据时未使用的位将屏蔽为"0”。在图2.4 给出的第三个周期中,在T/C 运行于相位修正模式时改变TOP值导致了不对称输出。其原因在于OCR1x寄存器的更新时间。由于OCR1x的更新时刻为定时器/ 计数器达到TOP 之时,因此PWM 的循环周期起始于此,也终止于此。就是说,下降斜坡的长度取决于上一个TOP 值,而上升斜坡的长度取决于新的TOP 值。若这两个值不同,一个周期内两个斜坡长度不同,输出也就不对称了。若要在T/C 运行时改变TOP 值,最好用相位与频率修正模式代替相位修正模式。若TOP保持不变,那么这两种工作模式实际没有区别。工作于相位修正PWM 模式时,比较单元可以在OC1x 引脚输出PWM 波形。设置COM1x1:0 为2 可以产生普通的PWM,设置COM1x1:0 为3 可以产生反向PWM 。要真正从物理引脚上输出信号还必须将OC1x 的数据方向DDR_OC1x设置为输出。OCR1x 和 TCNT1 比较匹配发生时OC1x 寄存器将产生相应的清零或置位操作,从而产生PWM 波形。工作于相位修正模式时PWM 频率可由如下公式获得: (22)其中变量N 表示预分频因子 (1、 8、 64、 256 或1024)。OCR1x寄存器处于极值时表明了相位修正PWM模式的一些特殊情况。在普通PWM模式下,若OCR1x 等于BOTTOM,输出一直保持为低电平;若OCR1x 等于TOP,输出则保持为高电平。反向PWM 模式正好相反。如果OCR1A 用来定义TOP 值(WGM13:0 = 11) 且COM1A1:0 = 1,OC1A 输出占空比为50% 的周期信号。2.6.2模数转换器1 、模数转换器的特点(1)10 位 精度 (2)0.5 LSB 的非线性度(3)± 2 LSB 的绝对精度(4)13 - 260 s 的转换时间(5)最高分辨率时采样率高达15 kSPS(6)路复用的单端输入通道(7)路附加复用的单端输入通道 (TQFP 与MLF 封装)(8)可选的左对齐ADC 读数(9)0 - VCC 的 ADC 输入电压范围(10)可选的2.56V ADC 参考电压 (11)连续转换或单次转换模式(12)ADC 转换结束中断(13)基于睡眠模式的噪声抑制器ATmega8有一个10位的逐次逼近型ADC。ADC与一个8通道的模拟多路复用器连接,能对来自端口C 的8 路单端输入电压进行采样。单端电压输入以0V (GND) 为基准。ADC 包括一个采样保持电路,以确保在转换过程中输入到ADC 的电压保持恒定。ADC 的框图如图2-2 所示。ADC 由AVCC 引脚单独提供电源。AVCC 与VCC 之间的偏差不能超过± 0.3V。请参考P188“ADC 噪声抑制器” 来了解如何连接这个引脚。标称值为2.56V 的基准电压,以及AVCC,都位于器件之内。基准电压可以通过在AREF引脚上加一个电容进行解耦,以更好地抑制噪声。2、模数转换器方框图 图2-5模数转换器方框图在图中ADC 通过逐次逼近的方法将输入的模拟电压转换成一个10 位的数字量。最小值代表GND,最大值代表AREF引脚上的电压再减去1 LSB。通过写ADMUX寄存器的REFSn位可以把AVCC 或内部2.56V 的参考电压连接到AREF 引脚。在AREF 上外加电容可以对片内参考电压进行解耦以提高噪声抑制性能。模拟输入通道与差分增益可以通过写ADMUX 寄存器的MUX 位来选择。任何ADC 输入引脚,像GND 及固定能隙参考电压,都可以作为ADC 的单端输入。通过设置ADCSRA寄存器的ADEN 即可启动ADC。只有当ADEN 置位时参考电压及输入通道选择才生效。ADEN 清零时ADC 并不耗电,因此建议在进入节能睡眠模式之前关闭ADC。ADC转换结果为10位,存放于ADC数据寄存器ADCH及ADCL中。默认情况下转换结果为右对齐,但可通过设置ADMUX 寄存器的ADLAR 变为左对齐。如果要求转换结果左对齐,且最高只需8 位的转换精度,那么只要读取ADCH 就足够了。否则要先读ADCL,再读ADCH,以保证数据寄存器中的内容是同一次转换的结果。一旦读出ADCL,ADC 对数据寄存器的寻址就被阻止了。也就是说,读取ADCL 之后,即使在读ADCH 之前又有一次ADC 转换结束,数据寄存器的数据也不会更新,从而保证了转换结果不丢失。ADCH 被读出后,ADC 即可再次访问ADCH 及ADCL 寄存器。ADC转换结束可以触发中断。即使由于转换发生在读取ADCH与ADCL之间而造成ADC无法访问数据寄存器,并因此丢失了转换数据,中断仍将触发。2.6.2.3 启动一次转换向 ADC 启动转换位ADSC 位写"1” 可以启动单次转换。在转换过程中此位保持为高,直到转换结束,然后被硬件清零。如果在转换过程中选择了另一个通道,那么ADC 会在改变通道前完成这一次转换。使用ADC 中断标志作为触发源,可以在正在进行的转换结束后即开始下一次ADC 转换。之后ADC 便工作在连续转换模式,持续地进行采样并对ADC 数据寄存器进行更新。第一次转换通过向ADCSRA 寄存器的ADSC 写1 来启动。在此模式下,后续的ADC 转换不依赖于ADC 中断标志ADIF 是否置位。2.6.3ADC 输入通道选择模拟通道时请注意以下指导方针:工作于单次转换模式时,总是在启动转换之前选定通道。在ADSC 置位后的一个ADC 时钟周期就可以选择新的模拟输入通道了。但是最简单的办法是等待转换结束后再改变通道。在连续转换模式下,总是在第一次转换开始之前选定通道。在ADSC 置位后的一个ADC时钟周期就可以选择新的模拟输入通道了。但是最简单的办法是等待转换结束后再改变通道。然而,此时新一次转换已经自动开始了,下一次的转换结果反映的是以前选定的模拟输入通道。以后的转换才是针对新通道的。2.6.4ADC 基准电压源ADC的参考电压源(VREF)反映了ADC的转换范围。若单端通道电平超过了VREF,其结果将接近0x3FF。VREF 可以是AVCC、内部2.56V 基准或外接于AREF 引脚的电压。AVCC通过一个无源开关与ADC相连。片内的2.56V参考电压由能隙基准源(VBG)通过内部放大器产生。无论是哪种情况,AREF 都直接与ADC 相连,通过在AREF 与地之间外加电容可以提高参考电压的抗噪性。VREF 可通过高输入内阻的伏特表在AREF 引脚测得。由于VREF 的阻抗很高,因此只能连接容性负载。如果将一个固定电源接到AREF 引脚,那么用户就不能选择其他的基准源了,因为这会导致片内基准源与外部参考源的短路。如果AREF 引脚没有联接任何外部参考源,用户可以选择AVCC 或2.56V 作为基准源。2.6.5模拟输入电路单端通道的模拟输入电路见图2.6。不论是否用作ADC 的输入通道,输入到ADCn的模拟信号都受到引脚电容及输入泄露的影响。用作ADC 的输入通道时,模拟信号源必须通过一个串联电阻( 输入通道的组合电阻) 驱动采样保持(S/H) 电容。ADC针对那些输出阻抗接近于10 k或更小的模拟信号做了优化。对于这样的信号采样时间可以忽略不计。若信号具有更高的阻抗,那么采样时间就取决于对S/H 电容充电的时间。这个时间可能变化很大。使用输出阻抗低且变化缓慢的模拟信号,因为这可以减少对S/H 电容的电荷传输。频率高于奈奎斯特频率(fADC/2) 的信号源不能用于任何一个通道,这样可以避免不可预知的信号卷积造成的失真。在把信号输入到ADC 之前最好使用一个低通滤波器来滤掉高频信号。模拟输入电路:图2-6模拟输入电路第3章电路原理和硬件实现3.1电路原理框图用D/A和运算放大器做电流源,即采用D/A输出调节晶体管的偏值电流(电压)。采用此方案能有效的缩短调节时间,并能提高输出精度。但8位D/A芯片的精度达不到题目所需要的精度。经计算需要采用10位的D/A芯片。我设计的方案采用的ATmega8,一路由PWM1的输出,通过积分整形出很平滑的直流电源控制场效应管输出的大小,改变电压的大小,当单片机通过闭环负反馈调节回路的A/D转换检测到电压没达到设定值时,将再次对输出电压进行调制,直到输出电压达到设定值;另一路同样由PWM2的输出,通过积分整形出很平滑的直流电源控制场效应管输出的大小,改变电流的大小,当单片机通过闭环负反馈调节回路的A/D转换检测到电流没达到设定值时,将再次对输出电流进行调制,直到输出电流达到设定值,调节电流是靠调节晶体管的偏值电流实现的,理论上是线性调节,不会产生高次谐波。电路原理框图如下:键盘处理器LCD显示PWM1A/D1PWM2A/D2积分积分电压 控 制电流控制电压采样电流采样图3-1原理框图3.2 各部分电路图实现分析本电源由MCU模块、MCU电源模块、显示模块、电源输出模块四部分组成.准确说就是MCU电源模块提供各个芯片电源、数码管、放大器所需电压;显示电路用于显示电源输出电压的大小。下面进行分别介绍:3.2.1 MCUMCU模块即为单片机部分,整个控制都是依靠单片机完成。从功能和价位以及本题目要求来看,我们选择AVR 系列Mega8作为本方案的控制核心。其基本特性如下:1、高性能、低功耗的 8 位AVR® 微处理器 2、先进的RISC 结构3、512 字节的EEPROM4、1K字节的片内SRAM5、可以对锁定位进行编程以实现用户程序的加密6、两个具有独立预分频器8 位定时器/ 计数器,其中之一有比较功能7、一个具有预分频器、比较功能和捕捉功能的16 位定时器/ 计数器8、具有独立振荡器的实时计数器RTC9、三通道PWM10、TQFP与MLF 封装的8 路ADC由于其内部集成8路10位的A/D转换器,采样转换周期104us,免去单独做A/D转换器电路,节约时间,节约成本编程实现容易。MCU的模块图如下:图3-2MCU模块图3.2.2 MCU电源模板MCU电源模块是让220V电源通过变压器降压,整流滤波后经过三端稳压7815,7915得到15V电压为运算放大器供电,同时,在+15V电源经过三端稳压7805为单片机提供工作电源。其图如下所示:图3-3MCU电源模块图3.2.3 显示模板显示的方式很多,主要分为两类:LED 显示,LCD显示。前者显示亮度高,制作成本低,适合做远距离显示,但由于其耗电较大