模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx

上传人:b****2 文档编号:1525183 上传时间:2023-04-30 格式:DOCX 页数:15 大小:258.76KB
下载 相关 举报
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第1页
第1页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第2页
第2页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第3页
第3页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第4页
第4页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第5页
第5页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第6页
第6页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第7页
第7页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第8页
第8页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第9页
第9页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第10页
第10页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第11页
第11页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第12页
第12页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第13页
第13页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第14页
第14页 / 共15页
模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx_第15页
第15页 / 共15页
亲,该文档总共15页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx

《模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx(15页珍藏版)》请在冰点文库上搜索。

模数转换器ADC0809应用原理范本模板Word文档下载推荐.docx

2.ADC0809应用说明

(1).ADC0809内部带有输出锁存器,可以与AT89S51单片机直接相连。

(2).初始化时,使ST和OE信号全为低电平。

(3).送要转换的哪一通道的地址到A,B,C端口上。

(4).在ST端给出一个至少有100ns宽的正脉冲信号。

(5).是否转换完毕,我们根据EOC信号来判断。

(6).当EOC变为高电平时,这时给OE为高电平,转换的数据就输出给单片机了.

3.实验任务

如下图所示,从ADC0809的通道IN3输入0-5V之间的模拟量,通过ADC0809转换成数字量在数码管上以十进制形成显示出来。

ADC0809的VREF接+5V电压。

4.电路原理图

5。

程序设计:

(1).进行A/D转换时,采用查询EOC的标志信号来检测A/D转换是否完毕,若完毕则把数据通过P0端口读入,经过数据处理之后在数码管上显示。

(2).进行A/D转换之前,要启动转换的方法:

ABC=110选择第三通道

ST=0,ST=1,ST=0产生启动转换的正脉冲信号.

(3).关于0809的计算:

ad0809是根据逐位逼近的方法产生数据的。

参考电压为0-5V的话。

以0809八位255的转换精度每一位的电压值为(5—0)/255≈0.0196V

设输入电压为X则:

X—27*0。

0196〉=0则AD7=1否则AD7=0。

X—26*0.0196〉=0则AD6=1否则AD6=0。

X—20*0.0196〉=0则AD0=1否则AD0=0。

(27指2的7次方。

26————---20同理)

若参考电压为0—1V

(1—0)/255≈0。

0039V精度自然高了.。

可测量范围小了. 

1)汇编源程序:

CHEQU30H

DPCNTEQU31H

DPBUFEQU33H

GDATAEQU32H

STBITP3。

OEBITP3.1

EOCBITP3。

2

ORG00H

LJMPSTART

ORG0BH

LJMPT0X

ORG30H

START:

MOVCH,#0BCH

MOVDPCNT,#00H

MOVR1,#DPCNT

MOVR7,#5

MOVA,#10

MOVR0,#DPBUF

LOP:

MOV@R0,A

INCR0

DJNZR7,LOP

MOV@R0,#00H

MOV@R0,#00H

MOVTMOD,#01H

MOVTH0,#(65536-4000)/256

MOVTL0,#(65536-4000)MOD256

SETBTR0

SETBET0

SETBEA

WT:

CLRST

SETBST

CLRST

WAIT:

JNBEOC,WAIT

SETBOE

MOVGDATA,P0

CLROE

MOVA,GDATA

MOVB,#100

DIVAB

MOV33H,A

MOVA,B

MOVB,#10

MOV34H,A

MOV35H,B

SJMPWT

T0X:

NOP

MOVTH0,#(65536-4000)/256

MOVTL0,#(65536—4000)MOD256

MOVDPTR,#DPCD

MOVA,DPCNT

ADDA,#DPBUF

MOVR0,A

MOVA,@R0

MOVCA,@A+DPTR

MOVP1,A

MOVDPTR,#DPBT

MOVA,DPCNT

MOVCA,@A+DPTR

MOVP2,A

INCDPCNT

CJNEA,#8,NEXT

NEXT:

RETI

DPCD:

DB3FH,06H,5BH,4FH,66H

DB6DH,7DH,07H,7FH,6FH,00H

DPBT:

DB0FEH,0FDH,0FBH,0F7H

DB0EFH,0DFH,0BFH,07FH

END

2)C语言源程序

#include

unsignedcharcodedispbitcode[]={0xfe,0xfd,0xfb,0xf7,

 0xef,0xdf,0xbf,0x7f};

unsignedcharcodedispcode[]={0x3f,0x06,0x5b,0x4f,0x66,

0x6d,0x7d,0x07,0x7f,0x6f,0x00};

unsignedchardispbuf[8]={10,10,10,10,10,0,0,0};

unsignedchardispcount;

sbitST="

P3”^0;

sbitOE="

P3"

^1;

sbitEOC="

P3”^2;

unsignedcharchannel=”0xbc”;

//IN3

unsignedchargetdata;

voidmain(void)

{

TMOD=0x01;

TH0=(65536—4000)/256;

TL0=(65536—4000)%256;

TR0=1;

ET0=1;

EA=1;

P3=channel;

while

(1)

ST=0;

ST=1;

ST=0;

while(EOC==0);

OE=1;

getdata=P0;

OE=0;

dispbuf[2]=getdata/100;

getdata=getdata%10;

dispbuf[1]=getdata/10;

dispbuf[0]=getdata%10;

}

voidt0(void)interrupt1using0

P1=dispcode[dispbuf[dispcount]];

P2=dispbitcode[dispcount];

dispcount++;

if(dispcount==8)

dispcount=0;

3)FPGA实现的程序:

(verilog)

moduleAD0809(clk,//脉宽(至少100ns)

rst_n,

EOC,//约100us后EOC变为高电平转换结束

START,//启动信号,上升沿有效(至少100ns)

OE,//高电平打开三态缓冲器输出转换数据

ALE,//高电平有效,选择信道口

ADDA,//因为ADDB,ADDC都接地了,这里只有ADDA为变量

DATA,////转换数据

DATA_R);

outputSTART,OE,ALE,ADDA;

inputEOC,clk,rst_n;

input[7:

0]DATA;

output[7:

0]DATA_R;

regSTART,OE,ALE,ADDA;

reg[7:

reg[4:

0]CS,NS;

parameterIDLE=5'

'

b00001,START_H=5’'

b00010,START_L=5'

’b00100,

CHECK_END=5'

’b01000,GET_DATA=5'

b10000;

always@(*)

case(CS)

IDLE:

NS=START_H;

START_H:

NS=START_L;

START_L:

NS=CHECK_END;

CHECK_END:

if(EOC)

NS=GET_DATA;

else

GET_DATA:

NS=IDLE;

default:

endcase

always@(posedgeclk)

if(!

rst_n)

CS〈=IDLE;

else

CS〈=NS;

always@(posedgeclk)

case(NS)

begin

OE<

=0;

START<

ALE〈=0;

ADDA〈=1;

end

=0;

=1;

//产生启动信号

ALE〈=1;

//选择信道口IN0

START_L:

OE〈=0;

ALE<

=1;

//启动信号脉宽要足够长,在启动的时候ALE要一直有效

CHECK_END:

START〈=0;

ALE〈=0;

OE〈=1;

//高电平打开三态缓冲器输出转换数据

DATA_R<

=DATA;

//提取转换数据

end

default:

OE〈=0;

START〈=0;

ADDA<

endcase

endmodule

4)FPGA实现的程序:

(VHDL)

LIBRARYIEEE;

USEIEEE.STD_LOGIC_1164.ALL;

USEIEEE。

STD_LOGIC_UNSIGNED。

ALL;

ENTITYAD0809IS

PORT(D:

INSTD_LOGIC_VECTOR(7DOWNTO0);

CLK,EOC:

INSTD_LOGIC;

CLOCK:

INSTD_LOGIC;

ALE,START,OE,LOCK0:

OUTSTD_LOGIC;

DOUT:

OUTSTD_LOGIC_VECTOR(6DOWNTO0);

SEL:

OUTSTD_LOGIC_VECTOR(2DOWNTO0));

ENDAD0809;

ARCHITECTUREbehavOFAD0809IS

TYPEstatesIS(st0,st1,st2,st3,st4);

SIGNALcurrent_state,next_state:

states:

=st0;

SIGNALREGL:

STD_LOGIC_VECTOR(7DOWNTO0);

SIGNALLOCK:

STD_LOGIC;

SIGNALCNT1:

STD_LOGIC_VECTOR(0DOWNTO0);

SIGNALA:

INTEGERRANGE0TO1;

SIGNALLOWDATA:

STD_LOGIC_VECTOR(3DOWNTO0);

SIGNALHIGHDATA:

SIGNALLOWLED7S:

STD_LOGIC_VECTOR(6DOWNTO0);

SIGNALHIGHLED7S:

STD_LOGIC_VECTOR(6DOWNTO0);

BEGIN

LOCK0〈=LOCK;

PROCESS(REGL)

BEGIN 

LOWDATA<

=REGL(3DOWNTO0);

HIGHDATA<

=REGL(7DOWNTO4);

CASELOWDATAIS

WHEN”0000”=〉LOWLED7S〈=”0111111”;

WHEN"

0001”=〉LOWLED7S<

="

0000110"

0010"

=>

LOWLED7S〈="

1011011”;

WHEN”0011”=〉LOWLED7S<

1001111”;

0100”=〉LOWLED7S〈="

1100110”;

0101"

=〉LOWLED7S<

1101101"

;

WHEN”0110"

1111101"

WHEN”0111”=〉LOWLED7S〈=”0000111”;

1000"

1111111”;

1001"

1101111"

1010”=>

LOWLED7S〈=”1110111”;

WHEN”1011”=>

1111100"

1100”=>

LOWLED7S<

0111001"

1101”=〉LOWLED7S〈="

1011110"

1110”=>

LOWLED7S〈=”1111001”;

1111"

LOWLED7S〈=”1110001"

WHENOTHERS=〉Null;

ENDCASE;

CASEHIGHDATAIS

WHEN”0000”=>

HIGHLED7S〈=”0111111”;

0001”=>

HIGHLED7S〈="

0000110”;

WHEN”0010"

=〉HIGHLED7S<

=”1011011”;

0011”=〉HIGHLED7S<

=”1001111"

0100"

HIGHLED7S<

1100110"

WHEN”0101"

HIGHLED7S〈=”1101101”;

0110"

=”1111101”;

WHEN”0111"

0000111"

=〉HIGHLED7S〈=”1111111”;

WHEN”1001"

=”1101111”;

WHEN”1010"

=”1110111"

1011"

1111100”;

1100"

=”0111001”;

1101”=>

WHEN”1110"

=”1111001”;

WHEN”1111”=>

1110001”;

WHENOTHERS=>

Null;

ENDCASE;

ENDPROCESS;

PROCESS(CLOCK)

IFCLOCK'

EVENTANDCLOCK='

1'

THENCNT1〈=CNT1+1;

ENDIF;

PROCESS(CNT1)

CASECNT1IS

WHEN”0”=〉SEL〈="

111"

A〈=0;

1”=>

SEL<

110”;

A<

NULL;

ENDPROCESS;

PROCESS(A)

CASEAIS

WHEN0=〉DOUT〈=LOWLED7S;

WHEN1=>

DOUT<

=HIGHLED7S;

NULL;

COM:

PROCESS(current_state,EOC) 

CASEcurrent_stateIS

WHENst0=>

ALE<

=’0’;

START〈='

0’;

LOCK<

=’1’;

OE〈=’0’;

next_state<

=st1;

WHENst1=〉ALE<

='

1’;

1’;

OE〈='

0'

=st2;

WHENst2=〉ALE〈='

0’;

START〈=’1'

LOCK〈='

OE<

IF(EOC=’1’)THENnext_state<

=st3;

ELSEnext_state〈=st2;

ENDIF;

WHENst3=〉ALE<

=’0'

START〈=’0'

next_state〈=st4;

WHENst4=〉ALE〈=’0'

START<

WHENOTHERS=>

next_state〈=st0;

ENDPROCESSCOM;

REG:

PROCESS(CLK)

IF(CLK’EVENTANDCLK='

)THENcurrent_state〈=next_state;

ENDIF;

ENDPROCESSREG;

LATCH1:

PROCESS(LOCK) 

IFLOCK=’1'

ANDLOCK’EVENTTHENREGL〈=D;

ENDPROCESSLATCH1;

ENDbehav;

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 解决方案 > 解决方案

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2