马伟力AVR笔记:六、模拟比较器和ADC实验.docx
《马伟力AVR笔记:六、模拟比较器和ADC实验.docx》由会员分享,可在线阅读,更多相关《马伟力AVR笔记:六、模拟比较器和ADC实验.docx(17页珍藏版)》请在三一办公上搜索。
1、AVR学习笔记六、模拟比较器和ADC实验 -基于LT_Mini_M166.1 模拟比较器实验6.1.1 实例功能模拟比较器和模数转换ADC是单片机内部最常见的两种支持模拟信号输入的功能接口。大部分AVR都具备这两种类型的接口。本实例将以ATmage16芯片为例,介绍模拟比较器的使用方法,在下一个实例中介绍模数转换ADC。使用模拟比较器可以实现单片机系统电源电压的检测,更巧妙的应用是利用模拟比较器和一些简单的外围电路,设计简单的模数转换ADC。本实例实现利用模拟比较器比较某一点电压与内部模拟比较器参考电压的高低。共有3个功能模块,分别描述如下: 单片机系统:使用ATmega16单片机的模拟比较器
2、比较某一点的电压与参考电压的关系。 外围电路:利用电阻设计的分压电路。 软件程序:熟悉掌握ATmega16单片机的模拟比较器的使用。通过本实例的学习,掌握相关电路设计,并掌握以下知识点: 了解单片机的模拟比较器。 了解单片机的模拟比较器的使用。 掌握单片机模拟比较器的编程。6.1.2、器件和原理1、模拟比较器的介绍ATmega16的模拟比较器可以实现对两个输入端:正极AIN0和负极AIN1(分别对应于ATmage16的引脚PB2、PB3)的模拟输入电压进行比较。当AIN0上的电压高于AIN1的电压时,模拟比较器输出ACO被设为“1”。比较器的输出还可以被设置作为定时计数器1输入捕获功能的触发信
3、号。此外,比较器的输出可以触发一个独立的模拟比较器中断。用户可以选择使用比较器输出的上升沿、下降沿或事件触发作为模拟比较器中断的触发信号。2、与模拟比较器相关的寄存器与模拟比较器相关的寄存器是SFIOR、ACSR。用户通过这两个寄存器的相关位实现对模拟比较器的设置和控制。1) 特殊功能IO寄存器SFIOR寄存器SFIOR中的第3位ACME为模拟比较器多路使能控制位。当该位为逻辑“1”,同时模数转换(ADC)功能被关闭(ADCSRA寄存器中的ADEN使能位为“0”)时,允许使用ADC多路复用器选择ADC的模拟输入端口作为模拟比较器反向端的输入信号源。当该位为零时,AIN1引脚的信号将加到模拟比较
4、器反向端。本实例中我们使用ADC的模拟输入端口作为模拟比较器反向端的输入信号源,所以需要设置第3位ACME为1.2) 模拟比较器控制和状态寄存器ACSRACSR是模拟比较器主要的控制寄存器,其中各个位的作用如下:1 位7ACD:模拟比较器禁止当该位设为“1”时,提供给模拟比较器的电源关闭。该位可以在任何时候被置位,从而关闭模拟比较器。在MCU闲置模式,且无需将模拟比较器作为唤醒源的情况下,关闭模拟比较器可以减少电源的消耗。要改变ACD位的设置时,应该先将寄存器ACSR中的ACIE位清零,把模拟比较器中断禁止掉。否则,在改变ADC位设置时会产生一个中断。2 位6ACBG:模拟比较器的能隙参考源选
5、择当该位为“1”时,芯片内部一个固定的能隙(Bandgap)参考电源1.22V将代替AIN0的输入,作为模拟比较器的正极输入端。当该位被清零时,AIN0的输入仍然作为模拟比较器的正极输入端。3 位5ACO:模拟比较器输出模拟比较器的输出信号经过同步处理后直接与ACO相连。由于经过同步处理,ACO与模拟比较器的输出之间,会有12个时钟的延时。4 位4ACI:模拟比较器中断标志位当模拟比较器的输出事件符合中断触发条件时(中断触发条件由ACIS1 和ACIS0 定义),ACI由硬件置“1”。若ACIE 位置“1”,且状态寄存器中的I位为“1”时,MCU响应模拟比较器中断。当转入模拟比较中断处理向量时
6、,ACI被硬件自动清空。此外,也可使用软件方式清零ACI:对ACI标志位写入逻辑“1”来清零该位。5 位3ACIE:模拟比较器中断允许当ACIE位设为“1”,且状态寄存器中的I位被设为“1”时,允许模拟比较器中断触发。当ACIE被清“0”时,模拟比较器中断被禁止。6 位2ACIC:模拟比较器输入捕获允许当该位设置为“1”时,定时计数器1的输入捕获功能将由模拟比较器的输出来触发。在这种情况下,模拟比较器的输出直接连到输入捕获前端逻辑电路,从而能利用定时器/计数器1输入捕获中断的噪声消除和边缘选择的特性。当该位被清零时,模拟比较器和输入捕获功能之间没有联系。要使能比较器触发定时器/计数器1的输入捕
7、获中断,定时器中断屏蔽寄存器(TIMSK)中 的TICIE1位必须被设置。7 位1、0ACIS1、ACIS0:模拟比较器中断模式选择这2个位决定哪种模拟比较器的输出事件可以触发模拟比较器的中断。不同的设置参见表6.1.1。表6.1.1 模拟比较器中断模式选择ACIS1ACIS0中 断 模 式00比较器输出的上升沿和下降沿都触发中断01保留10比较器输出的下降沿触发中断11比较器输出的上升沿触发中断注意:当要改变ACIS1、ACIS0时,必须先清除ACSR寄存器中的中断允许位,以禁止模拟比较器中断;否则,当这些位被改变时,会发生中断。在本实例中,我们要使用模拟比较器,所以应当允许模拟比较器,即A
8、CD应为0,选择芯片内部的固定能隙参考电源。即ACBG设置为1,我们不使用中断和捕获,所以不必理会与此相关的各位。3) 模拟比较器的多路输入用户可以选择ADC7.0引脚中的任一路的模拟信号代替AIN1引脚,作为模拟比较器的反向输入端。模数转换的ADC多路复用器提供这种选择的能力,但此时必须关闭芯片的ADC功能。当模拟比较器的多路选择使能位(SFIOR中的ACME位)置“1”,同时ADC被关闭时(ADCSRA中的ADEN位置“0”),由寄存器ADMUX中的MUX2:0位所确定的引脚将代替AIN1作为模拟比较器的反向输入端,如表6.1.2所示。如果ACME被清零,或ADEN被置1,则AIN1仍将为
9、模拟比较器的反向输入端。表6.1.2 模拟比较器多路输入选择ACMEADENMUX2.0模拟比较器反向输入端0xxxxAIN111xxxAIN110000ADC010001ADC110010ADC210011ADC310100ADC410101ADC510110ADC610111ADC7 本实例中我们采用ADC0作为模拟比较器的反向输入端,所以选择ADMUX寄存器中的MUX2:0=0;6.1.3、电路本实例的电路包含分压电路,下面的电路是电阻分压电路,如下图所示。1、电路原理在本实例中利用电位器(即可调电阻)组成分压电路,单片机的PA0连接在电位器的动片引脚上,这个电路实际上相当于两个电阻组成
10、的串联电路,只不过这两个电阻的阻值是可变的,改变动片的位置,就可以改变PA0与地之间的电阻值,根据串联电路分压的原理,当动片移动时,PA0处的电压就会发生变化。2、电路连接电路电位器的动片引脚连接到单片机的PA0口,作为模拟比较器的反向输入端。6.1.4、程序设计1、程序功能程序的功能是使用单片机的模拟比较器比较PA0口的电压与单片机内部的固定能隙电压(1.22V)之间的高低,如果PA0的电压低于1.22V,则D1灯点亮,否则D2灯点亮。2函数说明本程序有两个功能函数,分别是: 端口初始化函数,设置连接D1、D2两个LED的端口PB0、PB1为输出口,输出低电平,使两个LED都处于熄灭状态。
11、模拟比较器初始化函数设置与模拟比较器相关的寄存器,使模拟器按照一定的方式工作。 3、使用WINAVR开发环境,我们使用的是外部12M的晶振,所以需要将makefile文件中的时钟频率修改为12M。另外在程序烧录到单片机的时候,熔丝位也要选择为外部12M晶振(注意是晶振,不是外部振荡器,一定不要选择错了,否则会导致单片机不能再烧写程序)。 4、程序代码#include #include #include /中断函数头文件/函数声明void Port_Init(void); /端口初始化配置void Compare_Init(void); /模拟比较器初始化设置int main(void) Por
12、t_Init();Compare_Init();sei(); /使能全局中断 while(1)if(ACSR & (1 ACO) /判断ADC0的电压是否大于1.22VPORTB = 0X01; /低于1.22V,D1点亮,elsePORTB = 0X02; /高于1.22V,D2点亮,/端口状态初始化设置函数void Port_Init()PORTB = 0X00; /DDRB |= (1 PB0) | (1 PB1); /PB0、PB1设置为输出/模拟比较器初始化函数void Compare_Init()SFIOR |= (1 ACME); /使用ADC多路复用器选择ADC的模拟输入端口
13、/作为模拟比较器反向输入端的信号源。/同时选择ADC的ADC0作为输入端,并且关闭AD转换的使能ACSR |= (1 ACBG); /允许模拟比较器,AIN0设置为内部固定能隙参考电源1.22V6.2 模数转换的ADC实验6.2.1、实例功能AVR的模数转换器ADC具有下列特点:l 10位精度;l 0.5LSB积分非线形误差l 2LSB的绝对精度;l 13s260s的转换时间;l 在最大精度下可达到每秒15kSPS的采样速率;l 8路可选的单端输入通道;l 7路差分输入通道;l 2路差分输入通道带有可选的10和200增益;l ADC转换结果的读取可设置为左端对齐(LEFT ADJUSTMENT
14、);l ADC的电压输入范围0Vcc;l 可选择的内部2.56V的ADC参考电压源;l 自由连续转换模式和单次转换模式;l ADC自动转换触发模式选择;l ADC转换完成中断;l 休眠模式下的噪声抑制器(NOISE CANCELER)。在本实例中,我们将编写程序实现将模数转换后获得的电压值通过单片机的串口发送到计算机,然后通过计算机上的串口助手显示测量的电压值。本实例共有3个功能模块,分别描述如下: 单片机系统:使用单片机的串口实现将模数转换后获得的电压值通过串口发送到计算机。 外围电路:RS232电平转换电路,DB9串行接口插座,模拟电压输入采集电路。 软件程序:进一步熟悉单片机的串行通信,
15、并掌握单片机的模数转换的方法。6.2.2、器件和原理关于串行接口的原理已接单片机与计算机的串口的连接在上一实例中进行了描述,在本实例中不再重复。本实例只介绍ATmega16单片机如何通过内置的模数转换模块采集外界输入的模拟电压。1、ATmega16单片机的模数转换器ADC介绍由于单片机只能处理数字信号,所以外部的模拟信号量需要转变成数字量才能进一步的由单片机进行处理。ATmega16内部集成有一个10位逐次比较(successive approximation)ADC电路。因此使用AVR可以非常方便的处理输入的模拟信号量。ATmega16的ADC与一个8通道的模拟多路选择器连接,能够对以POR
16、TA作为ADC输入引脚的8路单端模拟输入电压进行采样,单端电压输入以0V(GND)为参考。另外还支持16种差分电压输入组合,其中2种差分输入方式(ADC1,ADC0和ACD3,ADC2)带有可编程增益放大器,能在A/D转换前对差分输入电压进行0dB(1),20dB(10)或46dB(200)的放大。还有七种差分输入方式的模拟输入通道共用一个负极(ADC1),此时其它任意一个ADC引脚都可作为相应的正极。若增益为1或10,则可获得8位的精度。如果增益为200,那么转换精度为7位。AVR的ADC功能单元由独立的专用模拟电源引脚AVcc供电。AVcc和Vcc的电压差别不能大于0.3V。ADC转换的参
17、考电源可采用芯片内部的2.56V参考电源,或采用AVcc,也可使用外部参考电源。使用外部参考电源时,外部参考电源由引脚ARFE接入。使用内部电压参考源时,可以通过在AREF引脚外部并接一个电容来提高ADC的抗噪性能。ADC功能单元包括采样保持电路,以确保输入电压在ADC转换过程中保持恒定。ADC通过逐次比较(successive approximation)方式,将输入端的模拟电压转换成10位的数字量。最小值代表地,最大值为AREF引脚上的电压值减1个LSB。可以通过ADMUX寄存器中REFSn位的设置,选择将芯片内部参考电源(2.56V)或AVcc连接到AREF,作为A/D转换的参考电压。这
18、时,内部电压参考源可以通过外接于AREF引脚的电容来稳定,以改进抗噪特性。模拟输入通道和差分增益的选择是通过ADMUX寄存器中的MUX位设定的。任何一个ADC的输入引脚,包括地(GND)以及内部的恒定能隙(fixed bandgap)电压参考源,都可以被选择用来作为ADC的单端输入信号。而ADC的某些输入引脚则可选择作为差分增益放大器的正、负极输入端。当选定了差分输入通道后,差分增益放大器将两输入通道上的电压差按选定增益系数放大,然后输入到ADC中。若选定使用单端输入通道,则增益放大器无效。通过设置ADCSRA寄存器中的ADC使能位ADEN来使能ADC。在ADEN没有置“1”前,参考电压源和输
19、入通道的选定将不起作用。当ADEN位清“0”后,ADC将不消耗能量,因此建议在进入节电休眠模式前将ADC关掉。ADC将10位的转换结果放在ADC数据寄存器中(ADCH和ADCL)。默认情况下,转换结果为右端对齐(RIGHT ADJUSTED)的。但可以通过设置ADMUX寄存器中ADLAR位,调整为左端对齐(LEFT ADJUSTED)。如果转换结果是左端对齐,并且只需要8位的精度,那么只需读取ADCH寄存器的数据作为转换结果就达到要求了。否则,必须先读取ADCL寄存器,然后再读取ADCH寄存器,以保证数据寄存器中的内容是同一次转换的结果。因为一旦ADCL寄存器被读取,就阻断了ADC对ADC数据
20、寄存器的操作。这就意味着,一旦指令读取了ADCL,那么必须紧接着读取一次ADCH;如果在读取ADCL和读取ADCH的过程中正好有一次ADC转换完成,ADC的2个数据寄存器的内容是不会被更新的,该次转换的结果将丢失。只有当ADCH寄存器被读取后,ADC才可以继续对ADCL和ADCH寄存器操作更新。ADC有自己的中断,当转换完成时中断将被触发。尽管在顺序读取ADCL和ADCH寄存器过程中,ADC对ADC数据寄存器的更新被禁止,转换的结果丢失,但仍会触发ADC中断。2、ATmwga16单片机的模数转换器ADC相关的I/O寄存器1ADC多路复用器选择寄存器ADMUX8 位7,6REFS1:0:ADC参
21、考电源选择REFS1、REFS2用于选择ADC的参考电压源,见表6.2.1。如果这些位在ADC转换过程中被改变,新的选择将在该次ADC转换完成后(ADCSRA中的ADIF被置位)才生效。一旦选择内部参考源(AVcc、2.56V)为ADC的参考电压后,AREF引脚上不得施加外部的参考电源,只能与GND之间并接抗干扰电容。表6.2.1 ADC参考电源选择REFS1REFS0ADC参考电源00外部引脚AREF,断开内部参考源连接01AVcc,AREF外部并接电容10保留11内部2.56V,AREF外部并接电容9 位5ADLAR:ADC结果左对齐选择ADLAR位决定转换结果在ADC数据寄存器中的存放形
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 伟力 AVR 笔记 模拟 比较 ADC 实验
链接地址:https://www.31ppt.com/p-1677211.html