603059 发表于 2009-12-18 16:42:02

12f675 AD到底几位?

12f675 用7805供电,基准选用内部Vdd,数据手册上说它的内部AD为10位 ,但是我AD接5v后读出的数接近512(0x1ff)相当于9位了,不知道这是怎么回事?

headwolf_83 发表于 2009-12-18 17:40:20

八成是哪里设置有问题。

millwood0 发表于 2009-12-19 01:08:18

the datasheet has the most definitive answer on that.

603059 发表于 2009-12-21 14:04:51

这是我的 程序
//引用头文件
#include<pic.h>

static bit AD_DONE @((unsigned)&ADCON0*8)+1;



//符号变量替换
#defineu8   unsigned char
#defineu16unsigned int
#define   LED2GPIO5
#define   LED1GPIO2
#define   KEY0GPIO1
#define   KEY1GPIO0
#define   KEY2GPIO3



void init(void)
{
CMCON=0X07;//比较器关闭
ANSEL=0X38;//设GP0,1,2,3,5都为数字IO口 GP4为AD
OPTION=0X07;//GPIO上拉 预分频1:256设置
TRISIO=0x1b;//GP口设为
WPU=0xFF;
TMR0=200;//定时初值TMR0设置:(预分频数)256*TMR0+256=50000毫秒
INTCON=0XA0;//所有中断允许;
T0IE=0;//T0中断允许位;
T0IF=0;
}
void delay2s()
{
        u8 i,j;       
for(i=0;i<250;i++)
                        for(j=0;j<250;j++);
   for(i=0;i<254;i++)
                        for(j=0;j<254;j++);
}
void delay()
{
        u8 i;       

   for(i=0;i<254;i++);
}


u16 ADC()
{
        u8 i=250;
    u16 ADH,ADL,AD_value;
    ADCON0   =0x8d;         
    AD_DONE   =   1;
    while(AD_DONE);
        ADCON0   =   0x8c;
    ADH=ADRESH;
        ADL=ADRESL;
   AD_value=(ADH*256)+ADL;
    return AD_value;
}
      
void main(void)
{
long int AD_value;


init();//初始化


while(1)   //任务结束,等待......
{

               
                AD_value=ADC();



                 if( AD_value>380)
                  LED2=1;
                else LED2=0;
}
}

ly499463215 发表于 2009-12-21 16:49:51

或许是采样时间不够吧

603059 发表于 2009-12-21 17:54:38

恩 有可能 我试试

portx 发表于 2009-12-22 20:43:33

你没有配置ADFM AD格式对齐位
http://cache.amobbs.com/bbs_upload782111/files_23/ourdev_517609.JPG
(原文件名:ADFM.JPG)


默认格式ADFM位为0即左对齐格式,当你将结果*256时相当于左移8位 当然结果是512即二进制的0b1000000000

以下代码是我在16F877A芯片的配置代码
unsigned int ADBUF;

ADC_INIT(void)
{
ADCON0=0x40;
ADCON1=0xCE;
ADFM=1;
ADON=1;
ADIF=0;
//ADIE=1;        //若启动ADC中断模式则将此位置1
////////////////////////ADC模块初始化结束
PEIE=1;
GIE=1;
}

void interrupt ADC_INIT(void)
{
        if((ADIF)&(ADIE))
        {
        ADIF=0;
        ADBUF=ADRESH;
        ADBUF<<=8;
        ADBUF+= ADRESL;
        ADGO=1;
        }

}

main()
SYS_INIT();
ADC_INIT();
ADGO=1;//启动AD
{
while(1)
{
///````````````
}

}

ville 发表于 2009-12-29 22:43:19

真有这么回事?回头我也得看看。

millwood0 发表于 2009-12-30 09:10:02

"我客户也碰到过此情况,客户说很多单片机说的是十位,但实际只有九位。目前公司还在分析中。"

why would anyone buy anything from someone who cannot read the datasheet?

603059 发表于 2010-3-3 17:17:21

AD是10位 以前的程序有问题 用下面的程序AD就正常了

#include<pic.h>
//12F675
//*****************

__CONFIG(UNPROTECT&INTIO & WDTDIS & PWRTEN & MCLRDIS & BOREN);


#defineu8   unsigned char
#defineu16unsigned int

#define   LED2GPIO5
#define   LED1GPIO2
#define   KEY0GPIO1
#define   KEY1GPIO0
#define   KEY2GPIO3
//*****************
//*****************

//主函数***************************************************


void delay2s()
{
        u8 i,j;       
for(i=0;i<250;i++)
                        for(j=0;j<250;j++);
   for(i=0;i<254;i++)
                        for(j=0;j<254;j++);
}

void main()
{

ADCON0   =0x8d;      
CMCON=0X07;//比较器关闭
ANSEL=0X38;//设GP0,1,2,3,5都为数字IO口 GP4为AD
OPTION=0X07;//GPIO上拉 预分频1:256设置
TRISIO=0x1b;//GP口设为
WPU=0xFF;
TMR0=200;//定时初值TMR0设置:(预分频数)256*TMR0+256=50000毫秒
ok=0;                        //清除AD转换完成标志位
T0IF=0;                //清除TMR0中断标志位
//GIE=1;                        //使能全局中断
T0IE=1;                //全能TMR0中断
   LED2=1;
delay2s();
   LED1=1;
delay2s();
while(1){

GODONE=1;                //使能AD转换
while(GODONE==1);        //等候AD转换完成
   if(((ADRESH*256)+ADRESL)>512)
{
   LED2=0;
   LED1=0;
}
else {
LED2=1;
   LED1=1;
}
}
}

329508414@qq.co 发表于 2013-2-28 09:05:38

603059 发表于 2010-3-3 17:17 static/image/common/back.gif
AD是10位 以前的程序有问题 用下面的程序AD就正常了

#include


你的AD转换有什么应用了,你把转换结果用在什么地方了?

fl6026 发表于 2013-12-30 22:26:08

GP4为AD???

yklstudent 发表于 2013-12-30 23:15:27

ADCON0   =   0x8c;
感觉这句有什么用
页: [1]
查看完整版本: 12f675 AD到底几位?