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

code efficiency question

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



Joined: 16 Sep 2005
Posts: 138
Location: The Netherlands

View user's profile Send private message Send e-mail Visit poster's website MSN Messenger

code efficiency question
PostPosted: Fri Sep 16, 2005 3:23 am     Reply with quote

Hello,

I just started coding on a pic16f877a and I am not experienced with coding on such devices. So I am looking to many resources and that is what I did on the next occasion.

I had to write 10 databits, one after another, to an external bus. I all examples I saw there were bitwise shifting operations, but I didn't like them because they were not readable enough for me (yes, I didn't understand exactly when I first saw them, but I do now). So I decided to give it another approach.
I wrote the next code for it:
Code:

//write 10 databits
for(i = 512; i >= 1; i = i / 2)
{
   SPI_writebit(i == (data & i));
}

A few days later I came across the bit_test() method and that made me questioning my code. My question therefor is:
What do you think is the best (most efficient) code?
1: code with bitwise shifting operations
2: my code
3: code using the bit_test() method
4: anything else?
asmallri



Joined: 12 Aug 2004
Posts: 1636
Location: Perth, Australia

View user's profile Send private message Send e-mail Visit poster's website

PostPosted: Fri Sep 16, 2005 4:50 am     Reply with quote

//write 10 databits
for(i = 0b1000000000; i; i >= 1)
SPI_writebit (data & i);
_________________
Regards, Andrew

http://www.brushelectronics.com/software
Home of Ethernet, SD card and Encrypted Serial Bootloaders for PICs!!
Foppie



Joined: 16 Sep 2005
Posts: 138
Location: The Netherlands

View user's profile Send private message Send e-mail Visit poster's website MSN Messenger

PostPosted: Fri Sep 16, 2005 5:03 am     Reply with quote

asmallri wrote:
for(i = 0b1000000000; i; i >= 1)

This looks very interesting, but how does the forloop work exactly? I can not see it decreasing in any way (or must >>= be used instead of >=?). And when does the loop stop?

It is in either case something I haven't thought off so thanks!
Ttelmah
Guest







PostPosted: Fri Sep 16, 2005 5:47 am     Reply with quote

Yes. >>= is needed instead of >=. Posters here are human, and will make typing errors. I do it all the time, when posting a short example.
The nice thing about this, is that you are reducing the amount of maths involved in the whole loop, performing just one operation (the shift), and stopping when the bit shifts out the end of the mask.

Best Wishes
Foppie



Joined: 16 Sep 2005
Posts: 138
Location: The Netherlands

View user's profile Send private message Send e-mail Visit poster's website MSN Messenger

PostPosted: Fri Sep 16, 2005 6:03 am     Reply with quote

now I see it, thank you both!
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