新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > AVR 模數(shù)(AD)轉(zhuǎn)換范例程序

AVR 模數(shù)(AD)轉(zhuǎn)換范例程序

作者: 時(shí)間:2011-11-08 來(lái)源:網(wǎng)絡(luò) 收藏

1. 開發(fā)語(yǔ)言

本范例使用 Win/GCC 20050214 版本開發(fā)

2. 范例描述

本程序簡(jiǎn)單的示范了如何使用ATMEGA16的ADC器 普通的單端輸入 差分輸入及校準(zhǔn) 基準(zhǔn)電壓的校準(zhǔn) 查詢方式 中斷方式 數(shù)據(jù)格式的變換 出于簡(jiǎn)化程序考慮,各種數(shù)據(jù)沒(méi)有對(duì)外輸出,學(xué)習(xí)時(shí)建議使用JTAG ICE硬件仿真器


3. 電路圖設(shè)計(jì) :

為簡(jiǎn)化線路設(shè)計(jì),使用了本網(wǎng)站的ATmega16功能小板。

在范例中 選用內(nèi)部2.56V電壓基準(zhǔn)作Vref ,差分通道 10倍放大
則 單端電壓測(cè)量范圍 02.56V, 分辨率2.5mV
差分電壓測(cè)量范圍 +/- 256mV 分辨率0.5mV
電流分辨率 = 50uA@10歐姆 電流采樣電阻
電流分辨率 =500uA@ 1歐姆 電流采樣電阻
程序中需要把實(shí)測(cè)的基準(zhǔn)電壓代入 常量Vref中,以獲得更準(zhǔn)確地結(jié)果
我手中的樣片實(shí)測(cè)為 2.556V@Vcc=5.0V
2.550V@Vcc=3.3V
本電路僅供參考,沒(méi)有考慮抗干擾方面的要求

.

4. 代碼設(shè)計(jì)與說(shuō)明 :

/***************************************************** ADC()使用范例 ******* ******* 策劃、整理與測(cè)試: 阿莫(armok) ***
**** 代碼設(shè)計(jì): HJJour ******* 編譯器:WIN20050214 ******* www.OurAVR.com 2005.8.31 ****************************************************/#include avr/io.h>#include avr/delay.h>#include avr/signal.h>#include avr/interrupt.h>/*宏INTERRUPT 的用法與SIGNAL 類似,區(qū)別在于 SIGNAL 執(zhí)行時(shí)全局中斷觸發(fā)位被清除、其他中斷被禁止 INTERRUPT 執(zhí)行時(shí)全局中斷觸發(fā)位被置位、其他中斷可嵌套執(zhí)另外avr-libc 提供兩個(gè)API 函數(shù)用于置位和清零全局中斷觸發(fā)位,它們是經(jīng)常用到的。分別是:void sei(void) 和void cli(void) 由interrupt.h定義 */
//管腳定義
#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作負(fù)端,10/200倍放大
#define AD_Diff0_0_10x 0x08 //ADC0+ ADC0-, 10倍放大,校準(zhǔn)用
#define AD_Diff1_0_10x 0x09 //ADC1+ ADC0-, 10倍放大
#define AD_Diff0_0_200x 0x0A //ADC0+ ADC0-,200倍放大,校準(zhǔn)用
#define AD_Diff1_0_200x 0x0B //ADC1+ ADC0-,200倍放大

//差分通道ADC2作負(fù)端,10/200倍放大
#define AD_Diff2_2_10x 0x0C //ADC2+ ADC2-, 10倍放大,校準(zhǔn)用
#define AD_Diff3_2_10x 0x0D //ADC3+ ADC2-, 10倍放大
#define AD_Diff2_2_200x 0x0E //ADC2+ ADC2-,200倍放大,校準(zhǔn)用
#define AD_Diff3_2_200x 0x0F //ADC3+ ADC2-,200倍放大

//差分通道ADC1作負(fù)端,不放大
#define AD_Diff0_1_1x 0x10 //ADC0+ ADC1-
#define AD_Diff1_1_1x 0x11 //ADC1+ ADC1-,校準(zhǔn)用
#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作負(fù)端,不放大
#define AD_Diff0_2_1x 0x18 //ADC0+ ADC2-
#define AD_Diff1_2_1x 0x19 //ADC1+ ADC2-
#define AD_Diff2_2_1x 0x1A //ADC2+ ADC2-,校準(zhǔn)用
#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 內(nèi)部能隙1.22V電壓基準(zhǔn),校準(zhǔn)用
#define AD_SE_GND 0x1F //接地 校準(zhǔn)用

//注:
//差分通道,如果使用1x或10x增益,可得到8位分辨率。如果使用200x增益,可得到7位分辨率。
//在PDIP封裝下的差分輸入通道器件未經(jīng)測(cè)試。只保證器件在TQFP與MLF封裝下正常工作。

#define Vref 2556 //mV 實(shí)測(cè)的Vref引腳電壓@5.0V供電
//#define Vref 2550 //mV 實(shí)測(cè)的Vref引腳電壓@3.3V供電

//全局變量
unsigned int ADC_SingleEnded; //單端輸入的ADC值
int ADC_Diff; //差分輸入的ADC值
volatile unsigned int ADC_INT_SE; //中斷模式用的單端輸入ADC值,會(huì)在中斷服務(wù)程序中被修改,
//須加volatile限定
volatile unsigned char ADC_OK; //ADC狀態(tài),會(huì)在中斷服務(wù)程序中被修改,須加volatile限定
unsigned int LED_Volt; //變換后的電壓mV
int LED_Curr; //變換



關(guān)鍵詞: AVR 模數(shù)轉(zhuǎn)換

評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉