|
|
View previous topic :: View next topic |
Author |
Message |
mryldz
Joined: 05 Feb 2014 Posts: 1
|
PIC18F45K22 ADC Problem |
Posted: Wed Feb 05, 2014 9:29 am |
|
|
Hi everyone,
I've a small question, I only need a working code for ADC and it has to be like these type. I write these codes, but it doesn't work on circuit. So, where is the mistake in these codes given below. Maybe it is about "fuses" ?
Code: |
#include <18F45K22.h>
#device ADC=8
#fuses XT,INTRC_IO,NOWDT,PUT,BROWNOUT,NOLVP
#use delay(clock=4000000)
#define LED PIN_B2
#define LED1 PIN_B0
#define LED2 PIN_B4
unsigned long int g;
float fb;
//======================================
void main(void)
{
setup_adc(adc_clock_div_32);
setup_adc_ports(ALL_ANALOG);
enable_interrupts(INT_AD);
enable_interrupts(GLOBAL);
while(1);
{
set_adc_channel(1);
delay_ms(20);
g=read_adc();
fb=1+(0.001953125*g);
if (fb>0)
{
output_high(LED);
}
else
{
output_low(LED);
}
}
}
|
|
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19588
|
|
Posted: Wed Feb 05, 2014 10:19 am |
|
|
First, you must only enable one oscillator.
Currently you have 'XT', which says to use an external crystal, and
'INTRC_IO' which says to use the internal oscillator, and enable I/O on external oscillator pins.
Then you must _never_ enable an interrupt without a handler. You don't want INT_AD enabled. This is only used when you are using a hardware event to enable the ADC (CCP for example), which you are not doing, and enabling it without a handler will crash the code when the ADC completes.
Then you have the ADC set to only return 8 bits. (ADC=8)....
Then don't use floats. Seriously, either use ADC counts, or convert to a scaled integer. Float maths should be avoided unless it is completely necessary. It is bulky, and slow.
As written, it is always going to be >0. ADC values are always positive, and you are adding '1', so the value is going to be 1, 1.00193 etc.. Never -ve.
Then you should only select the ADC channel once, outside the loop. |
|
|
gpsmikey
Joined: 16 Nov 2010 Posts: 588 Location: Kirkland, WA
|
|
Posted: Wed Feb 05, 2014 10:20 am |
|
|
Well, without my morning coffee yet, the first thing that I see is how would "fb" ever be less than 1? You are adding some unsigned number times a positive coefficient to 1. That will always give you "1+something". Since you don't say exactly what "doesn't work on circuit" means, that is the first thing I notice. Since you are testing for "fb>0" that will always be true.
mikey _________________ mikey
-- you can't have too many gadgets or too much disk space !
old engineering saying: 1+1 = 3 for sufficiently large values of 1 or small values of 3 |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
Powered by phpBB © 2001, 2005 phpBB Group
|