资源描述:
《单片机(21 并行AD转换).doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、实验报告实验课程:单片机学生姓名:邱永洪学号:6100210026专业班级:中兴101班2012年12月19日实验二十一并行A/D转换实验一、实验目的1.掌握ADC0809模/数转换芯片与单片机的连接方法及ADC0809的典型应用。2.掌握用查询方式、中断方式完成模/数转换程序的编写方法。二、实验内容利用系统提供的ADC0809接口电路,实现单片机模数转换。模拟信号为0~5V电位器分压输出,单片机控制ADC0809读取模拟信号,并在数码管上用十六进制形式显示出来。三、实验要求根据实验内容编写一个程序
2、,并在实验仪上调试和验证。四、实验说明和电路原理图1.本实验使用ADC0809模数转换器,ADC0809是8通道8位CMOS逐次逼近式A/D转换芯片,片内有模拟量通道选择开关及相应的通道锁存、译码电路,A/D转换后的数据由三态锁存器输出,由于片内没有时钟需外接时钟信号。芯片的引脚如图21-1,各引脚功能如下:IN0~IN7:八路模拟信号输入端。ADD-A、ADD-B、ADD-C:三位地址码输入端。CLOCK:外部时钟输入端。CLOCK输入频率范围在10~1280KHz,典型值为640KHz,此时A/
3、D转换时间为100us。51单片机ALE直接或分频后可与CLOCK相连。D0~D7:数字量输出端。OE:A/D转换结果输出允许控制端。当OE为高电平时,允许A/D转换结果从D0~D7端输出。ALE:地址锁存允许信号输入端。八路模拟通道地址由A、B、C输入,在ALE信号有效时将该八路地址锁存。START:启动A/D转换信号输入端。当START端输入一个正脉冲时,将进行A/D转换。EOC:A/D转换结束信号输出端。当A/D转换结束后,EOC输出高电平。Vref(+)、Vref(-):正负基准电压输入端。
4、基准正电压的典型值为+5V。2.本实验需要用到CPU模块(F3区)、电位器模块(E2区)、并行模数转换模块(D7区)、串行静态数码显示模块(B4区)。ADC0809并行模数转换电路原理参见图21-2。五、试验程序显示寄存器DBUF显示缓冲1TEMP显示缓冲2二进制八段显示码值44H读入数据个位八段显示码值45H读入数据十位八段显示码值46H0DH个位八段显示码值47H0AH十位八段显示码值40H读入数据个位41H读入数据十位42H0DH43H0AH;功能:并行A/D转换实验;接线:用导线对应连接并行
5、模数转换模块的CS_0809、EOC到CPU模块的8000、P32;;电位器模块的输出端接并行模数转换模块的IN-0;;并行模数转换模块的Vref接+5V电源;;CPU模块的P10、P11接串行静态数码显示模块DIN、CLK。;//*******************************************************************DBUFEQU30HTEMPEQU40HD0809EQU8000H;通道0地址DINBITP1.0CLKBITP1.1ORG0000HJM
6、PSTARTORG0080HSTART:MOVDBUF+3,#0AHMOVDBUF+2,#0DHMOVDPTR,#D0809MOVA,#0MOVX@DPTR,AJNBP3.2,$MOVXA,@DPTR;读入结果MOVB,ASWAPA;交换A的高低半字节ANLA,#0FH;取出数据的十位MOVDBUF+1,AINCR0MOVA,BANLA,#0FH;取出数据的个位MOVDBUF,AACALLDISP1acalldelayAJMPSTARTDISP1:;串行数码显示MOVR0,#DBUFMOVR1,#T
7、EMPMOVR2,#4DP10:MOVDPTR,#SEGTABMOVA,@R0MOVCA,@A+DPTRMOV@R1,AINCR0INCR1DJNZR2,DP10MOVR0,#TEMPMOVR1,#4DP12:MOVR2,#8MOVA,@R0DP13:RLCAMOVDIN,CCLRCLKSETBCLKDJNZR2,DP13INCR0DJNZR1,DP12RETSEGTAB:DB3FH,6,5BH,4FH,66H,6DH;0,1,2,3,4,5数码管八段显示代码表DB7DH,7,7FH,6FH,77H
8、,7CH;6,7,8,9,A,BDB58H,5EH,79H,71H,0,00H;C,D,E,F,-DELAY:MOVR4,#80HAA1:MOVR5,#0FFHAA:NOPNOPDJNZR5,AADJNZR4,AA1RETEND六、实验步骤1)系统各跳线器处在初始设置状态。用导线对应连接并行模数转换模块的CS_0809、EOC到CPU模块的8000、P32;电位器模块的输出端接并行模数转换模块的IN-0;并行模数转换模块的Vref接+5V电源;CPU模块的P10、P1