|
|
|
![]() |
|
|||||||
|
||||||||
![]() |
| Thread Tools | Rate Thread | Display Modes |
|
#1
|
|||
|
|||
|
Operator/Bit Issue
Hi,
We are having a really unique problem that has stumped the whole programing team, all of the mentors, and the team leader. We are trying to write some code in MPLab to calculate the number of encoder ticks needed to reach six feet. We have found that fourteen encoder clicks is the same as one inch. The problem comes in when we try to multiply 72(six feet in inches) by 14(clicks in an inch). When this happens we get -16 which is 32 bits off. We are using the variable type long. Below is the code that we have written: long atemp=0; atemp=14*72;//should be 1008 printf("atemp=%ld\r\n", atemp); This code did not work and gave us a value of -16 for atemp. We also tried this: long atemp=0; atemp=72+72+72+72+72+72+72+72+72+72+72+72+72+72; printf("atemp=%ld\r\n", atemp); This also did not work and gave us a value of -16. Adding smaller numbers works fine and multiplying smaller numbers also works. We have pretty much exhausted any ideas. Thanks, Julian |
|
#2
|
||||||
|
||||||
|
Re: Operator/Bit Issue
C18 diverges from the ISO standard in that when all operands will fit in a char, it will do the math in a char. If you cast one operand to an int, it will do the math the way you want. You can also enable integer promotion in the project file.
|
|
#3
|
|||
|
|||
|
Re: Operator/Bit Issue
Or write
Code:
atemp=14L*72L; Also, i'm not sure if you can print longs... |
|
#4
|
|||
|
|||
|
Re: Operator/Bit Issue
I believe that both casting them to an int or using %ld should work.
|
|
#5
|
|||
|
|||
|
Re: Operator/Bit Issue
Quote:
|
|
#6
|
|||
|
|||
|
Re: Operator/Bit Issue
I think %ld does work in later revisions of the default code (kevins?)
Also, an alternative method of getting the math the way you want it: Code:
atemp = (long)14*(long)72; |
|
#7
|
||||
|
||||
|
Re: Operator/Bit Issue
You code is working. The problem is with the printf statement.
so you can keep your code. |
|
#8
|
|||
|
|||
|
Re: Operator/Bit Issue
Thanks to everyone for the help. Typecasting made the code work. The printf statement was fine.
Julian |
![]() |
| Thread Tools | |
| Display Modes | Rate This Thread |
|
|
Similar Threads
|
||||
| Thread | Thread Starter | Forum | Replies | Last Post |
| pic: A "Bit" of a problem. | Herodotus | Extra Discussion | 26 | 11-10-2007 01:53 |
| A bit of humor... | 114Klutz | Chit-Chat | 0 | 01-04-2006 17:34 |
| Operator Interface power ISSUE | kacz100 | Technical Discussion | 11 | 27-02-2004 13:46 |
| A bit unfair... | Martin | General Forum | 61 | 26-02-2002 07:48 |
| i am a bit miffed | Zeinin | 3D Animation and Competition | 3 | 18-01-2002 13:39 |