CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

Measuring time between two events (Solved)
Goto page 1, 2  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
irmanao



Joined: 08 Apr 2015
Posts: 77

View user's profile Send private message

Measuring time between two events (Solved)
PostPosted: Tue May 01, 2018 7:13 am     Reply with quote

I wanted to test an example code for measuring time between two events for a future project, so i used this CCP code from the ccs manual.
Code:
#int_ccp1
void isr()
{
 rise=CCP_1; // CCP_1 is the time the pulse went high
 fall=CCP2; // CCP_2 is the time the pulse went low
 pulse_width=fall-rise; // pulse width
}
...
setup_ccp1(CCP_CAPTURE_RE); // Configure CCP1 to capture rise
setup_ccp2(CCP_CAPTURE_FE); // Configure CCP2 to capture fall
setup_timer_1(T1_INTERNAL); // Start timer 1


My code looks something like this (found from a different post from PCM Programmer):
Code:

#include <16f1827.h>
#FUSES NOWDT                     
#FUSES XT                         
#FUSES PUT                       
#FUSES NOPROTECT                 
#FUSES NODEBUG               
#FUSES NOLVP                 
#FUSES NOCPD                 
#use delay(internal=8000000)
#use rs232(baud=9600,xmit=PIN_B5,rcv=PIN_B2,bits=8,ERRORS)   

long rise,fall,time;

#int_ccp2
void isr()
{
   rise = CCP_1;
   fall = CCP_2;

   time = fall - rise;   
}


void main()
{
   setup_ccp1(CCP_CAPTURE_RE);    // Configure CCP1 to capture rise
   setup_ccp2(CCP_CAPTURE_FE);    // Configure CCP2 to capture fall
   setup_timer_1(T1_INTERNAL);    // Start timer 1

   enable_interrupts(INT_CCP2);   // Setup interrupt on falling edge
   enable_interrupts(GLOBAL);

   while(TRUE) {
output_high(PIN_B4);  // fed to CCP1 (pin_9)
delay_ms(10);
output_low(PIN_B4);
delay_ms(20);
output_high(PIN_A3);  // fed to CCP2 (pin_16)
delay_ms(100);
output_low(PIN_A3);
      delay_ms(1000);
      printf("%lu us \n\r", time );
   }
}


The measured time should be 130ms, but i get:
Quote:
39624 us
39624 us
39624 us
39624 us
39624 us
39624 us
39624 us
39624 us
39624 us
39624 us
39624 us
39624 us

What am i missing?
thanks


Last edited by irmanao on Thu May 03, 2018 6:58 am; edited 1 time in total
temtronic



Joined: 01 Jul 2010
Posts: 9221
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Tue May 01, 2018 7:18 am     Reply with quote

The first program you should code, compile, run is a '1HZ LED' program.
Simply toggle and LED at a 1Hz rate. Confirm it's running at the correct speed. This way you KNOW the PIC is good, clock selection is correct and then build from there.

While your code may be OK (I haven't checked) you could have a hardware issue (wrong clock speed) or a compiler bug (wrong clock speed) that won't show up if we use your code on our test PICs.

Jay
irmanao



Joined: 08 Apr 2015
Posts: 77

View user's profile Send private message

PostPosted: Tue May 01, 2018 7:20 am     Reply with quote

I am testing the output pins with an oscilloscope and it looks ok.
newguy



Joined: 24 Jun 2004
Posts: 1907

View user's profile Send private message

PostPosted: Tue May 01, 2018 7:26 am     Reply with quote

Things to consider:
- At what rate is timer 1 counting? How many microseconds per tick? Then:
- How many counts are going to constitute 130ms? Can that number fit in a "long"? What is a "long"? Why not be explicit and declare your variables as int16 or int32?
irmanao



Joined: 08 Apr 2015
Posts: 77

View user's profile Send private message

PostPosted: Tue May 01, 2018 7:46 am     Reply with quote

So, timer 1 is counting at 0.5us (8MHz/4) and it takes 260000 counts to reach 130ms so a int32 is needed. Right?

Now i get:
Quote:
4292821246 us
4292821246 us
4292821246 us


Did i connect the output pins to the wrong CCP pins? There are two CCP2 pins.
temtronic



Joined: 01 Jul 2010
Posts: 9221
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Tue May 01, 2018 10:07 am     Reply with quote

You best reread the datasheet section on timer1 . My recall is that timer 1 is a 16 bit timer, so 65535 counts max.......
irmanao



Joined: 08 Apr 2015
Posts: 77

View user's profile Send private message

PostPosted: Tue May 01, 2018 11:10 am     Reply with quote

Yeap. So if i add
Code:
SETUP_TIMER_1(T1_INTERNAL | T1_DIV_8 );
then it should be ok, no? (8/4)/8=250KHz, 4us and 32500 counts for 130ms. I still get the same output.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Tue May 01, 2018 3:46 pm     Reply with quote

Quote:
Did i connect the output pins to the wrong CCP pins?

What package are you using for your PIC ? The data sheet gives a table
of pin numbers, so we could check if your connections are correct, but
we need to know the package (DIP, SOIC, SSOP, or QFN ?).
irmanao



Joined: 08 Apr 2015
Posts: 77

View user's profile Send private message

PostPosted: Wed May 02, 2018 3:12 am     Reply with quote

It's a DIP18.
temtronic



Joined: 01 Jul 2010
Posts: 9221
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Wed May 02, 2018 5:32 am     Reply with quote

I was curious, so I downloaded the datasheet
B4 is NOT the CCP1 pin, B3 is.
Also A3 is NOT the CCP2 pin.
I looked in section 12 ( IO ports) as well as the pinout selection
While both CCP1 and CCP2 can be 'remapped' or have alternate pins the ones you chose aren't valid.
CCP1 can be B3 or B0
CCP2 can be A7 or B6
At least that's what I read in my copy of the datasheet.

perhaps others will confirm/deny what I'm saying.

jay
irmanao



Joined: 08 Apr 2015
Posts: 77

View user's profile Send private message

PostPosted: Wed May 02, 2018 6:41 am     Reply with quote

Code:
while(TRUE) {
output_high(PIN_B4);  // fed to CCP1 (pin_9)
delay_ms(10);
output_low(PIN_B4);
delay_ms(20);
output_high(PIN_A3);  // fed to CCP2 (pin_16)
delay_ms(100);
output_low(PIN_A3);
      delay_ms(1000);
      printf("%lu us \n\r", time );
   }
}


B4 is the output pin that is connected to pin_9(B3) and A3 is the output pin that is connected to pin_16(A7).
temtronic



Joined: 01 Jul 2010
Posts: 9221
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Wed May 02, 2018 6:49 am     Reply with quote

OK THAT makes more sense... I misread what you're doing...got confused (easy I'm old...)after flipping through 100 pages to figure out how configure the PIC.
pmuldoon



Joined: 26 Sep 2003
Posts: 218
Location: Northern Indiana

View user's profile Send private message

PostPosted: Wed May 02, 2018 1:05 pm     Reply with quote

I'm sure I'm missing something obvious, but what I would do is move the 1-sec delay after the printf().

Then add rise, fall and get_timer0() to the printf() and see if the numbers are making sense. You'll be reading them right after the interrupt event, if things are going as expected.

Either the timer isn't running or the interrupt isn't firing or the captures aren't happening, or I'm wrong. In any case it will become more obvious with more data.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Wed May 02, 2018 3:56 pm     Reply with quote

irmanao wrote:

B4 is the output pin that is connected to pin_9(B3) and A3 is the output pin
that is connected to pin_16(A7).

There is a problem with this. Pin B6 is the default pin for CCP2. Your
program is using pin B6. I'm sure that's a major reason why it doesn't
work. This is shown in the table on page 6 of the 16F1827 data sheet.
http://ww1.microchip.com/downloads/en/DeviceDoc/41391D.pdf

Pin A7 is the alternate pin for CCP2. To select it, you need to use this line:
Code:
setup_ccp2(CCP_CAPTURE_FE | CCP2_A7);
irmanao



Joined: 08 Apr 2015
Posts: 77

View user's profile Send private message

PostPosted: Thu May 03, 2018 3:32 am     Reply with quote

I connected the output to the default pin for CCP2 and now i get:
Quote:
29605 us
27715 us
4294932551 us
28902 us
4294933805 us
30047 us
28002 us
4294932841 us

expecting 130000us from the original code. If i disconnect the CCP2 input i get the same result but when i disconnect the CCP1 input i get this:
Quote:
ýø2321 us
2313 us
2304 us
2301 us
4294904084 us
2341 us
2327 us
2329 us
2335 us
2325 us
2314 us
2321 us
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Goto page 1, 2  Next
Page 1 of 2

 
Jump to:  
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