历史上的今天
今天是:2024年10月28日(星期一)
2019年10月28日 | ATmega16单片机ad电流和电压采样程序
2019-10-28 来源:51hei

四通道PWM
8路10位ADC,8个单端通道,2个具有可编程增益(1x, 10x, 或200x)的差分通道
端口A(PA7..PA0) 端口A 做为A/D 转换器的模拟输入端。端口A 为8 位双向I/O 口,具有可编程的内部上拉电阻。其输出缓冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,端口被外部电路拉低时将输出电流。在复位过程中,即使系统时钟还未起振,端口A 处于高阻状态。
端口B(PB7..PB0) 端口B 为8 位双向I/O 口,具有可编程的内部上拉电阻。其输出缓冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,端口被外部电路拉低时将输出电流。在复位过程中,即使系统时钟还未起振,端口B 处于高阻状态。
端口B 也可以用做其他不同的特殊功能.
端口C(PC7..PC0) 端口C 为8 位双向I/O 口,具有可编程的内部上拉电阻。其输出缓冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,端口被外部电路拉低时将输出电流。在复位过程中,即使系统时钟还未起振,端口C 处于高阻状态。如果JTAG接口使能,即使复位出现引脚 PC5(TDI)、 PC3(TMS)与 PC2(TCK)的上拉电阻被激活。端口C 也可以用做其他不同的特殊功能.
端口D(PD7..PD0) 端口D 为8 位双向I/O 口,具有可编程的内部上拉电阻。其输出缓冲器具有对称的驱动特性,可以输出和吸收大电流。作为输入使用时,若内部上拉电阻使能,则端口被外部电路拉低时将输出电流。在复位过程中,即使系统时钟还未起振,端口D 处于高阻状态。端口D 也可以用做其他不同的特殊功能.
硬件方面基本懂了,剩下的是程序了,以下是该死的ADC数模转换器的大致使用,不太懂
***************************************************************************************************************************************
本程序简单的示范了如何使用ATMEGA16的ADC模数转换器 普通的单端输入 差分输入及校准 基准电压的校准 查询方式 中断方式 数据格式的变换 出于简化程序考虑,各种数据没有对外输出,学习时建议使用JTAG ICE硬件仿真器
***************************************************************************************************************************************
以下是例程
****************************************************/
#include #include #include #include //管脚定义 #define in_Single 0 //PA0(ADC0) #define in_Diff_P 3 //PA3(ADC3) #define in_Diff_N 2 //PA2(ADC2) //常量定义 //单端通道,不放大 #define AD_SE_ADC0 0x00 //ADC0 #define AD_SE_ADC1 0x01 //ADC1 #define AD_SE_ADC2 0x02 //ADC2 #define AD_SE_ADC3 0x03 //ADC3 #define AD_SE_ADC4 0x04 //ADC4 #define AD_SE_ADC5 0x05 //ADC5 #define AD_SE_ADC6 0x06 //ADC6 #define AD_SE_ADC7 0x07 //ADC7 //差分通道ADC0作负端,10/200倍放大 #define AD_Diff0_0_10x 0x08 //ADC0+ ADC0-, 10倍放大,校准用 #define AD_Diff1_0_10x 0x09 //ADC1+ ADC0-, 10倍放大 #define AD_Diff0_0_200x 0x0A //ADC0+ ADC0-,200倍放大,校准用 #define AD_Diff1_0_200x 0x0B //ADC1+ ADC0-,200倍放大 //差分通道ADC2作负端,10/200倍放大 #define AD_Diff2_2_10x 0x0C //ADC2+ ADC2-, 10倍放大,校准用 #define AD_Diff3_2_10x 0x0D //ADC3+ ADC2-, 10倍放大 #define AD_Diff2_2_200x 0x0E //ADC2+ ADC2-,200倍放大,校准用 #define AD_Diff3_2_200x 0x0F //ADC3+ ADC2-,200倍放大 //差分通道ADC1作负端,不放大 #define AD_Diff0_1_1x 0x10 //ADC0+ ADC1- #define AD_Diff1_1_1x 0x11 //ADC1+ ADC1-,校准用 #define AD_Diff2_1_1x 0x12 //ADC2+ ADC1- #define AD_Diff3_1_1x 0x13 //ADC3+ ADC1- #define AD_Diff4_1_1x 0x14 //ADC4+ ADC1- #define AD_Diff5_1_1x 0x15 //ADC5+ ADC1- #define AD_Diff6_1_1x 0x16 //ADC6+ ADC1- #define AD_Diff7_1_1x 0x17 //ADC7+ ADC1- //差分通道ADC2作负端,不放大 #define AD_Diff0_2_1x 0x18 //ADC0+ ADC2- #define AD_Diff1_2_1x 0x19 //ADC1+ ADC2- #define AD_Diff2_2_1x 0x1A //ADC2+ ADC2-,校准用 #define AD_Diff3_2_1x 0x1B //ADC3+ ADC2- #define AD_Diff4_2_1x 0x1C //ADC4+ ADC2- #define AD_Diff5_2_1x 0x1D //ADC5+ ADC2- //单端通道,不放大 #define AD_SE_VBG 0x1E //VBG 内部能隙1.22V电压基准,校准用 #define AD_SE_GND 0x1F //接地 校准用 //注: //差分通道,如果使用1x或10x增益,可得到8位分辨率。如果使用200x增益,可得到7位分辨率。 //在PDIP封装下的差分输入通道器件未经测试。只保证器件在TQFP与MLF封装下正常工作。 #define Vref 2556 //mV 实测的Vref引脚电压@5.0V供电 //#define Vref 2550 //mV 实测的Vref引脚电压@3.3V供电 //全局变量 unsigned int ADC_SingleEnded; //单端输入的ADC值 int ADC_Diff; //差分输入的ADC值 volatile unsigned int ADC_INT_SE; //中断模式用的单端输入ADC值,会在中断服务程序中被修改, //须加volatile限定 volatile unsigned char ADC_OK; //ADC状态,会在中断服务程序中被修改,须加volatile限定 unsigned int LED_Volt; //变换后的电压mV int LED_Curr; //变换后的电流100uA //仿真时在watch窗口,监控这些全局变量。 unsigned int read_adc(unsigned char adc_input)//查询方式读取ADC单端通道 { ADMUX=(0xc0|adc_input); //adc_input:单端通道 0x00~0x07,0x1E,0x1F //0xc0:选择内部2.56V参考电压 ADCSRA|=(1< // while ((ADCSRA&(1< ADCSRA|=(1< } int read_adc_diff(unsigned char adc_input)//查询方式读取ADC差分通道 { unsigned int ADC_FIX; ADMUX=(0xc0|adc_input); //adc_input:差分通道 0x08~0x1D _delay_ms(1); //等待差分增益稳定>125uS ADCSRA|=(1< ADCSRA|=(1< //第一次转换结果准确率很低。 //用户最好舍弃第一次转换结果。 ADCSRA|=(1< ADCSRA|=(1< //输出结果用2的补码形式表示 //可正可负 +/-9bit -512~+511 //即M16差分通道的ADC+输入端的电压可以大于ADC-,也可以小于ADC-。 //Tiny26就不行,ADC+输入端的电压必须大于或等于ADC-,为+10bit if (ADC_FIX>=0x0200) //负数要变换,正数不用 { ADC_FIX|=0xFC00; //变换成16位无符号整数 } return (int)ADC_FIX; } SIGNAL(SIG_ADC) //ADC中断服务程序 { //硬件自动清除ADIF标志位 ADC_INT_SE=ADC; //读取结果 ADC_OK=1; } int main(void) { long temp32; ADC_SingleEnded =0; ADC_Diff=0; ADC_INT_SE=0; //上电默认DDRx=0x00,PORTx=0x00 输入,无上拉电阻 PORTB=0xFF; //不用的管脚使能内部上拉电阻。 PORTC=0xFF; PORTD=0xFF; PORTA=~((1< ADCSRA=(1< while (1) { //实测的Vref引脚电压 =2556mV ADC_SingleEnded=read_adc(AD_SE_ADC0); //查询方式读取ADC0 temp32=(long)ADC_SingleEnded*Vref; LED_Volt=(unsigned int)(temp32/1024); ADC_Diff =read_adc_diff(AD_Diff3_2_10x); ADC_Diff-=read_adc_diff(AD_Diff2_2_10x);//校准OFFSET temp32=(long)ADC_Diff*Vref; LED_Curr=(unsigned int)(temp32/(512*10)); //[单位为100uA] //查询方式读取ADC3+,ADC2- 10倍放大 max +/-255.6mV //10欧姆 1mA=10mV max +/-25.56mA //分辨率约0.5mV=50uA,显示取整为100uA单位 ADCSRA|=(1< ADC_OK=0; //软件标志清零 ADCSRA|=(1< ADCSRA&=~(1< }
上一篇:AVR单片机的IO端口介绍
下一篇:51单片机程序转AVR的方法
史海拾趣
|
用定时器1做的简单输出,友善micro2440的板子 请帮我分析下,搞了好长时间,还是出不来 流驱动:#include \"options.h\" #include #include #include #include #include #include #include #include #include \"time.h\" ...… 查看全部问答> |
|
请问一下各位 学校里学的C语言和单片机C语言(C51)有啥子不一样的?哪个好学一点. 在学校里学了C语言后感觉没有学到啥子,挺浮浅的,现在只记得一些简单的规则和语法。 不知道现在是继续学它基础打扎实点呢,还是就开始学C51,希望大家给点建 ...… 查看全部问答> |
|
在WINCE60里面把CELLCORE组件加进了NK,怎么测试这块是不是可以正常工作?有没简单的测试AP可用?怎么测试RIL组件绑定了物理通信的串口? 在WINCE60里面把CELLCORE组件加进了NK,怎么测试这块是不是可以正常工作?有没简单的测试AP可用?怎么测试RIL组件绑定了物理通信的串口?… 查看全部问答> |
|
ppc2003可以直接访问sql2000 server中的数据吗? ppc2003通过wifi跟局域网连接后,可以通过编程直接访问服务器上sql2000 server中的数据吗?有人说必须在ppc上安装sql CE,然后通过sql CE跟服务器上的sql2000交换数据?真的是这样?… 查看全部问答> |
|
2010年度吉时利测试测量技术全国巡回研讨会将从9月初开始,在成都、重庆、合肥、南京、哈尔滨、武汉、兰州举办届时吉时利资深技术专家将与您深入交流: 绿色电子革命中的光电测试/新能源测试方案 新材料的测试方案 微弱信号测量难点与应对方 ...… 查看全部问答> |
|
使用uC2.86 ADC使用DMA中断的模式,在DMA1_CH1 初始化以及 中断 都没问题,都可以进中断, 但是改成 DMA1_CH4 就再也不进中断了,为什么?? 难道 DR_ADDRESS 地址不对?? RCC,等其他设置应该都没问题请大家看下我的初始化函 ...… 查看全部问答> |
|
最近在调STM8 的I2C(不想搞模拟的I2C),结果I2C没有调通,不知道问题所在,软件是参考I2C EEPROM固件那个程序写的。初始化如下: void IIC_Init(void) { UCHAR temp; CLK_PCKENR1 |= 0x01; I2C_CR1 = 0x00; &n ...… 查看全部问答> |
|
本帖最后由 dontium 于 2015-1-23 12:51 编辑 我这两天用面包板按照vca810芯片的datasheet中的figure2 电路搭建了一个压控放大,将8脚的50欧姆电阻去掉,并在8脚加了一个vpp=30mv,f=800hz的正弦波(函数发生器产生),并在1脚直接接地。但是在Vc= ...… 查看全部问答> |
|
《TMS320C28x系列DSP》读书笔记--通用目标文件格式,段 TMS320系列DSP的目标文件各式为通用目标文件格式 COFF (Command Object File Format,简称COFF)。 采用这种目标文件各式的优点是:将指令和数据按照段的概念进行组织和存储,这使得程序的可读性大大增强,更容易编写 ...… 查看全部问答> |




