AD0832是8位逐次逼近模數轉換器,可支持兩個單端輸入通道和一個差分輸入通道。是8位逐次逼近模數轉換器,可支持兩個單端輸入通道和一個差分輸入通道。
當ADC0832未工作時其CS輸入端應為高電平,此時芯片禁用,當要進行A/D轉換時,
須先將CS使能端置于低電平并且保持低電平直到轉換完全結束。此時芯片開始轉換工作,同時由處理器向芯片時鐘輸入端CLK輸入時鐘脈沖,DO/DI端則使用DI端輸入通道功能選擇的數據信號。在第1個時鐘脈沖的下沉之前DI端必須是高電平,表示啟始信號。在第2、3個脈沖下沉之前DI端應輸入2位數據用于選擇通道功能,
當此2位數據為“1”、“0”時,只對CH0進行單通道轉換。
當2位數據為“1”、“1”時,只對CH1進行單通道轉換。
當2位數據為“0”、“0”時,將CH0作為正輸入端IN+,CH1作為負輸入端IN-進行輸入。
當2位數據為“0”、“1”時,將CH0作為負輸入端IN-,CH1作為正輸入端IN+進行輸入。
在完成輸入啟動位、通道選擇之后,就可以開始讀出數據,轉換得到的數據會被送出二次,一次高位在前傳送,一次低位在前傳送,連續送出。在程序讀取二個數據后,我們可以加上檢驗來看看數據是否被正確讀取。
由于ADC0832是8位分辨率,返回的數值在0~255之間,對應模擬數值為0~5V,因此每一檔對應的電壓值約為0.0196V。大家可以在通道輸入端引入模擬信號(0~5V)進行測試,比如可以在通道腳和地之間接入電池來測試電池電壓值。為使兩位數碼管顯示電壓值大小,在寫程序是可將對應比值改位0.196,同理,如果想要顯示精度更高,可用三位或四位顯示,那么響應的改一下比值為1.96或19.6,當然,需要注意你所得數據的大小是否超出數據類型的大小。
時序圖
基于ADC0834的AD轉換
/*----------------------------------------------------------
功能介紹:
-----------------------------------------------------------*/
#include 《reg52.h》 #include 《stdio.h》
#include 《math.h》
#define uchar unsigned char
#define uint unsigned int
#define ucode unsigned code
/*--------------------------------------------
包含函數
---------------------------------------------*/
void DISP(void); //數碼管顯示函數
void key(void);//矩陣鍵盤函數
void _nop_(void);
void ad_buf(); //模擬量轉化為數字函數
uchar ADC0834(uchar tds); //AD轉換函數
/*-------------------------------------------
參數定義
-------------------------------------------*/
uchar bdata ekey1; //鍵前沿提取
uchar bdata ekey2;
uchar data key2;
uchar data key1;
uchar bdata lastkey1;
uchar bdata lastkey2;
uchar disp_a;//數碼管顯示指針
sbit cs0=P2^0;
sbit cs1=P2^1;
sbit cs2=P2^2;
sbit cs3=P2^3;
sbit cs4=P2^4;
sbit esw0=ekey2^6; //獨立按鍵鍵沿標志
sbit esw1=ekey2^7; //
sbit ek0=ekey1^0; //矩陣按鍵鍵沿標志
sbit ek1=ekey1^1;
sbit ek2=ekey1^2;
sbit ek3=ekey1^3;
sbit ek4=ekey1^4;
sbit ek5=ekey1^5;
sbit ek6=ekey1^6;
sbit ek7=ekey1^7;
sbit ek8=ekey2^0;
sbit ek9=ekey2^1;
sbit row0=P2^5;
sbit row1=P2^6;
sbit row2=P2^7;
sbit sw0=P1^6;
sbit sw1=P1^7;
sbit do_0834=P1^0;//0834 DI
sbit cs_0834=P1^1; //0834 片選
sbit di_0834=P1^2; //0834 DI
sbit clk_0834=P1^3; // 0834 時鐘
sbit dian=P0^7; // 小數點
uchar buf0; // 顯示緩沖單元個位
uchar buf1; // 十
uchar buf2; // 百
uchar buf3; //千
uchar buf4;
uchar code led[]={0x0C0,0x0F9,0x0A4,0x0B0,0x99,0x92,0x82,0x0F8,0x80,0x90};
uchar msta=0;
uchar tds;//通道選擇
uint adbuf;
bit t1s;//一秒標志位
bit light; //小數點亮標志位
uchar ktime;
/*-------------------------------------------
主函數
-------------------------------------------*/
void main()
{ uchar f1s=0;
uchar i;
TMOD=0x01;
TH0=0xec;
TL0=0x78;
TR0=1;
while(1)
{
while(!TF0); //5ms?
TF0=0;
TH0=0x0ec;
TL0=0x78;
++f1s;
if(f1s==200)
{t1s=1;
f1s=0;}
key();
DISP();
switch(msta)
{ //待機模塊 顯示“0000”
case 0:if(esw0){msta=1;tds=0xd0;}//SW1按下跳到模塊1 選擇單端模式 AD一次
if(esw1){msta=1;tds=0x80;}//SW2按下跳到模塊1 選擇差分模式 AD一次
if(ek0){msta=2;tds=0xd0;}// ek0按下跳到模塊2 選擇單端模式 十次AD取平均
if(ek1){msta=2;tds=0x80;}//ek1按下跳到 模塊2 選擇差分模式 十次AD取平均
if(ek2){msta=3;tds=0xd0;}// ek2按下跳到模塊3 選擇單端模式 一秒AD一次
if(ek3){msta=3;tds=0x80;}// ek3按下跳到模塊3 選擇差分模式 一秒AD一次
buf4=0,buf3=0,buf2=0,buf1=0;
buf0=0;
break;
case 1:if(esw0){msta=1;tds=0xd0;} //只AD一次
if(esw1){msta=1;tds=0x80;}
light=1;//小數點亮
adbuf=ADC0834(tds);
ad_buf(); break;
case 2:if(ek0){msta=2;tds=0xd0;} //AD十次取平均
if(ek1){msta=2;tds=0x80;}
light=1;
for(i=0;i《10;i++)
{adbuf=adbuf+ADC0834(tds);}
adbuf=adbuf/11;
ad_buf();
break;
case 3:if(ek2){msta=3;tds=0xd0;} //一秒AD一次
if(ek3){msta=3;tds=0x80;}
light=1;
if(t1s)
{t1s=0;
adbuf=ADC0834(tds);
ad_buf();}
break;
default:break;
}
}
}
/*-----------------------------------------------
數碼管顯示
------------------------------------------------*/
void DISP()
{ P0=0xff;
P2=0xff;
switch(disp_a)
{ case 0: cs0=0; // 點亮第0位數碼管
P0=led[buf0];
disp_a=1;
break;
case 1: cs1=0; // 點亮第1位數碼管
P0=led[buf1];
disp_a=2;
break;
case 2: cs2=0; // 點亮第2位數碼管
P0=led[buf2];
disp_a=3;
break;
case 3: cs3=0; // 點亮第3位數碼管
P0=led[buf3];
if(light)
dian=0; //小數點亮
disp_a=4;
break;
case 4: cs4=0; // 點亮流水燈
P0=buf4;
disp_a=0;
break;
default:break;
}
}
/*-------------------------------------------------------
矩陣鍵盤及獨立按鍵子程序
------------------------------------------------------------*/
void key()
{uchar kbuf;
P2=0x0ff;//關數碼管
row0=0; //掃描K0~3
_nop_(); //延時
_nop_();
kbuf=P2;
kbuf=(kbuf&0x0f)^0x0f;
//K0~3鍵位保留 求反轉正邏輯
lastkey1=kbuf; // 新的鍵狀態暫存R6
P2=0x0ff;
row1=0; //掃描K4~7
_nop_();
_nop_();
kbuf=P2;
kbuf=(kbuf&0x0f)^0x0f;
lastkey1=(kbuf《《4)+lastkey1;
P2=0x0ff;
row2=0;//掃描K8~K11
_nop_();
_nop_();
kbuf=P2;
kbuf=(kbuf&0x0f)^0x0f;
lastkey2=kbuf;
P2=0x0ff;
P1=P1|0x0c0;
kbuf=P1;
kbuf=(kbuf&0x0c0)^0x0c0;
lastkey2=kbuf+lastkey2;
if((lastkey2!=key2)||(lastkey1!=key1))//鍵狀態變化則轉移
{if(ktime--!=0)
{lastkey1=key1;
lastkey2=key2;}
}
else
ktime=0x04;
ekey1=(key1^lastkey1)&lastkey1;
key1=lastkey1;
ekey2=(key2^lastkey2)&lastkey2;
key2=lastkey2; }
/************************************************************
AD轉換
************************************************************/
uchar ADC0834(uchar tds)
{
uchar i,adbuf=0; cs_0834=0; for(i=0;i《5;i++)
{
clk_0834=0;
di_0834=0;
if(tds&0x80)
di_0834=1;
clk_0834=1;
tds《《=1;
}
do_0834=1;
for(i=0;i《8;i++)
{
clk_0834=0;
clk_0834=1;
adbuf=(adbuf《《1)|do_0834;
}
cs_0834=1;
return(adbuf);
}
/*****************************************************************
模擬量轉化為數字并送顯
******************************************************************/
void ad_buf()
{
buf4=adbuf%51*10%51*10%51*10/51;//
流水燈
buf3=adbuf/51; //個位
buf2=adbuf%51*10/51;//十分位
buf1=adbuf%51*10%51*10/51;//百分位
buf0=adbuf%51*10%51*10%51*10/51;// 千分位
}
評論
查看更多