51单片机: A/D 模数转换实验
51单片机: A/D 模数转换实验
一、实验内容
利用实验台上的0809做A/D转换实验,实验台上的W1电位器提供模拟量输入。编制程序,将模拟量转换成数字量。(要求模拟量由0809的IN2采集)
二、仿真图

三、代码
C语言实现:
#include
#include
#define AD XBYTE[0XFF22] //定义AD0808的地址 Y4(20) Y1(01) Y7(31)
#define PA XBYTE[0XFF28] //定义8255A中PA段的地址
#define PB XBYTE[0XFF29] //定义8255A中PB段的地址
#define PC XBYTE[0XFF2a] //纯属方便定义,没用到
#define COM8255 XBYTE[0XFF2B] //定义8255A的控制字 Y5(FF2B) Y3(FF1B) Y7(FF3B)#define uint unsigned int
#define uchar unsigned charfloat x=0;uchar count=0;
uchar xdata *ad=&AD;//定义指针指向AD8080的地址
//uchar table[]={0xC0,0xF9,0xA4,0xB0,
// 0x99,0x92,0x82,0xF8,
// 0x80,0x90,0x88,0x83,
// 0xC6,0xA1,0x86,0x8E}; //数码管共阳极的显示编码
uchar table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};//数码管共阴极的显示编码void delayMS(unsigned int ms)//延时函数
{unsigned char i,j;for(i=ms;i>0;i--)for(j=60;j>0;j--);
}
void main()
{IT0=1; //设置外部中断为边沿触发EX0=1; //打开外部中断EA=1; //打开总中断*ad=0x01; // AD0808数值进行初始化COM8255=0x89;//10000000 //8255A数值进行初始化,设置端口为输出delayMS(100); //进行适当的延时while(1){PB=0X00;PA=0xff;//进行消影PB=0X80;PA=~table[count%16]; //选定最后一位数码管(段选),进行显示delayMS(1); //进行延时,但延时时间不宜过长PB=0X00;PA=0xff ; //进行消影PB=0X40;PA=~table[count/16];delayMS(1);//选定倒数第二位数码管(段选),进行显示}
}void ad0() interrupt 0//进入外部中断,此处为了通过脉冲方便进行AD0808的采样
{count=*ad; //此处count的值应为采集到的数据,范围应在0~255// x=x*0.9+count*0.1; //此处程序完成了低通滤波的功能,在实际演示中,由于种种限制,数字会有较大变化,不利于人的观察// count=(uchar)x; //再将处理好的值赋给count,此时的数字显示趋于稳定*ad=0x01; //清除采集到的数据当下,一个脉冲到来时重新采集
}
汇编实现:
AD EQU 0FFE2H ;1111 1111 11/10 0(138)/010(通道数)COM8255 EQU 0FFEBH ;键盘显示单元的8255控制口1111 1111 11/10 1/010PA EQU 0FFECH ;字形控制口 1111 1111/11/10 1/0?/00(00指向PA) p184PB EQU 0FFEDH ;字位/键扫控制口 1111 1111/ 11/10 1/0?/01(01指向PB)ORG 0000HLJMP STARTORG 0030H
START: MOV SP, #60HMOV DPTR,#AD ;MOVX @DPTR,A ;0809的通道0采样MOV DPTR,#COM8255 ;片选 MOV A,#89H ;P186 命令字:选择工作方式,A,B口输出 1/000 1/00/1 (A,B:方式0)MOV DPTR,#0FFEBH ;控制寄存器送入DPTR,8255才工作 0111 1111/ 11/10 1/0?/11// MOVX @DPTR,A ;方式寄存器送入控制寄存器 MOVX @DPTR,A ;累加器送外部RAM,8255初始化MOV R7,#100 ;保证转换结束,EOC=1CALL DELAY ;MOV DPTR,#AD ;L1: JB P3.2,L1MOVX A,@DPTR ;读取AD转换数据
while1:MOV B,A;此处略有不同,先把数据拆分,不然下边麻烦SWAP A ;累加器高四位与低四位互换ANL A,#0FH ;进位内容与直接地址内容相与,取高4位ANL B,#0FH ;进位内容与直接地址内容相与,取低4位MOV R4,A ; R4存高位相当于/16MOV R5,B ; R5存低位相当于%16MOV DPTR,#ADMOVX @DPTR,A ;开始下次AD转换MOV R3,#64h ;???
for:;第一个数码管显示MOV DPTR,#PB ;进行消影,先位选MOV A,#00H ;全选 MOVX @DPTR,A ;输出MOV DPTR,#PA ;再段选MOV A,#0FFH ;全选 MOVX @DPTR,A ;输出MOV DPTR,#PBMOV A,#80H //1000 0000,选中第一位MOVX @DPTR,A //第一位输出MOV DPTR,#LEDMAP //指向表头MOV A,R5 // R5存低位相当于%16 MOVC A,@A+DPTR ;变位寻址MOV DPTR,#PA ;选定的数送入RAMMOVX @DPTR,A ;再输出MOV R7,#1CALL DELAY ;第二个数码管显示MOV DPTR,#PB //进行消影MOV A,#00H // MOVX @DPTR,A //MOV DPTR,#PA ;MOV A,#0FFH ; MOVX @DPTR,A ;MOV DPTR,#PBMOV A,#40H //0100 0000,选中第二位MOVX @DPTR,AMOV DPTR,#LEDMAPMOV A,R4 ;R4存高位相当于/16MOVC A,@A+DPTR;MOV DPTR,#PA MOVX @DPTR,AMOV R7,#1 ;CALL DELAYDJNZ R3,forMOV DPTR,#ADL2:JB P3.2,L2 MOVX A,@DPTR ;读取AD转换数据JMP while1DELAY: MOV R6,#135DJNZ R6,$DJNZ R7,DELAY;RET
LEDMAP: DB 0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H ;字形表DB 80H,90H,88H,83H,0C6H,0A1H,86H,8EH,0FFHEND
资源下载点这里
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
