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

Problem with signal of tsop1738 in 18f4550

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
mash14



Joined: 16 Oct 2012
Posts: 2

View user's profile Send private message

Problem with signal of tsop1738 in 18f4550
PostPosted: Tue Oct 16, 2012 10:21 pm     Reply with quote

Hi all,

My problem is simple, I have a TSOP1738 sensor connected to RBO to detect the 33 NEC protocol flanks.

My problem is that it is only possible to detect between 12 and 18 bits of the protocol without knowing about the rest.

data:
My pic 18F4550 is designed to work with the internal clock to 8MHz, this will be the main issue?. ie not mind fast enough to detect all interrupts on time and perform program instructions.

Any reference is welcome since I have three years of experience with microcontrollers and I had never seen this.

Thank you very much.


nec protocol....
http://wiki.altium.com/download/attachments/8749270/NECMessageFrame.png?version=1&modificationDate=1228300890343

(and yes, I use a translator my little experience speaking English sorry )
Ttelmah



Joined: 11 Mar 2010
Posts: 19591

View user's profile Send private message

PostPosted: Wed Oct 17, 2012 2:42 am     Reply with quote

8MHz, is plenty fast enough to handle this protocol.

However you probably need to be changing your approach to how you do it.

I's suggest you use a hardware timer.
In the interrupt, you just want to record the _times_ when the edges happen do nothing more complex than this.
Realistically 'ideal' to use the CCP for this, rather than RB0.
Your diagram on the protocol, could well be misleading you, since it only applies to a device with an address of '0'.
The way the protocol works, you will see a rising edge, followed 13.5mSec latter by the next rising edge. This signals the 'start'. I'd reset the timer when this is seen. Rising edges then come at gaps of either 1.125mSec, or 2.25mSec for either a 0, or a 1. A total of 32bits of data, followed by another 0 to mark the end.

If you setup the hardware timer (say timer1, if using the CCP) to use the peripheral clock/4. So Fosc/16.
Then simply record the time when each rising edge is seen. Do one bit of maths. If the delta from the last record is >20000 reset the timer, and set the index to the recording array back to zero.
In the main, wait for the index to reach 32. At this point you have the times recorded for all the edges. _If_ the timer1 interrupt triggers, then you have missed a packet (will happen if you get to 31% after the last bit should have been seen).

Then decode. Two parts to this. Simply go through the first 32 entries of the array of times, to create four bytes. If the delta<900 store a '0', if greater, a '1'. Then invert the second and fourth bytes of the result, and compare these with the first and second bytes. If they don't match there was an error. If they match, you have the data received.

I'd suspect you are trying to do the decode inside the interrupt. If so, time would be very tight indeed, especially when testing for the inverted bytes.

Best Wishes
mash14



Joined: 16 Oct 2012
Posts: 2

View user's profile Send private message

PostPosted: Wed Oct 17, 2012 1:11 pm     Reply with quote

Thank you very much, you gave me a very good idea.

and tried to do just this, but with the difference that just try to detect and decode 32 bits.

Ttelmah wrote:


I'd suspect you are trying to do the decode inside the interrupt. If so, time would be very tight indeed, especially when testing for the inverted bytes.

Best Wishes


I turned a page and looked where an example, in which I base using timer interrupt and 1 with the difference that uses a 20MHz crystal.
http://picmania.garcia-cuervo.net/experimentos_ir.php

I'll take your suggestions and will try to see what happens, thank you very much.
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
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