|
|
|
![]() |
|
|||||||
|
||||||||
![]() |
|
|
Thread Tools |
Rating:
|
Display Modes |
|
|
|
#1
|
||||
|
||||
|
Stupidest Programming Mistakes
Alright everyone, let's have a collection of this seasons dumb programming mistakes, it'll be educational, and fun, and maybe I won't make as many dumb mistakes after seeing all the ones possible!
My gyro code was broken because I always checked to see if the output was greater than zero, and if so, set it to zero.....no wonder the robot always spun to the right... ![]() Code:
if(GyroSample > 0)
GyroSample = 0;
|
|
#2
|
||||
|
||||
|
Re: Stupidest Programming Mistakes
No specific code snippets, but there's been plenty of times where I've tried to compile and gotten 10 or more syntax errors... only to realize I'd left out semicolins on every single line I had added that needed them.
I did, on the other hand, sit there for hours today trying to find out why digital_io_01 wasn't working... Only to realize that I wanted rc_dig_in01 Last edited by ForgottenSalad : 05-02-2006 at 02:27. |
|
#3
|
|||
|
|||
|
Re: Stupidest Programming Mistakes
last year somebody deleted +127 at the end of our speed scaling code. it shot backward rather quickly.
|
|
#4
|
|||
|
|||
|
Re: Stupidest Programming Mistakes
Quote:
|
|
#5
|
|||||
|
|||||
|
Re: Stupidest Programming Mistakes
Quote:
![]() One of the most aggravating things I have run across to date is actually an IFI stupid mistake from 2005. They threw in a while loop, looping 20,000 times, every time new data came in from the camera. This caused the code to take practically forever to execute, but somehow didn't trigger the BLROD. Commenting out the while loop fixed the problem without damaging camera communication; I wonder why it was in there in the first place? ![]() Last edited by Eldarion : 05-02-2006 at 02:38. |
|
#6
|
|||
|
|||
|
Re: Stupidest Programming Mistakes
|
|
#7
|
||||
|
||||
|
Re: Stupidest Programming Mistakes
This is easily the worst mistake made this year.
Code:
Else (current_state == enabled && last_state == disabled) |
|
#8
|
|||||
|
|||||
|
Re: Stupidest Programming Mistakes
Last night, tried to get my drive code lookup table to compile. Turns out that I did everything right...except NAME THE STUPID THING!!!
Thanks to Alan Anderson for catching it. |
|
#9
|
||||
|
||||
|
Re: Stupidest Programming Mistakes
Quote:
Gosh that is funny. When programming in java I've gotten so lost in Code:
public static final volatile private blah Code:
public static final theta; Good thread. Paul Dennis |
|
#10
|
||||
|
||||
|
Re: Stupidest Programming Mistakes
Quote:
![]() |
|
#11
|
||||
|
||||
|
Re: Stupidest Programming Mistakes
if(joyin - pwmout > rate)
pwmout = pwmout + rate; joyin - pwmout could be negative but they were all unsigned variables so it never looked at nagatives. So for example it would still execute when (-10 > 5) Took 2 hours to realize that! |
|
#12
|
|||||
|
|||||
|
Re: Stupidest Programming Mistakes
I won't mention the hundreds times I've forgotten a semicolon, I'm sure that's all too common.
So I'll mention the time I was debugging a version of code and wondering why the printf's weren't working. Turns out I was downloading the old (buggy) version of the code ![]() |
|
#13
|
|||
|
|||
|
Re: Stupidest Programming Mistakes
Working on code for a few days working through all the bugs. Then when it coms time to use it a few weeks later I have lost the code and have forgotten how I fixed all the problems I came across. So I had to redo the code and attempt to remeber how I dealt with each error.
Also assuming that ints were 32 bit caused me some pain. Oh and almost every day when I download code to the robot I download from the wrong project and realize it a few mins later when the printfs are all wrong. |
|
#14
|
|||||
|
|||||
|
Re: Stupidest Programming Mistakes
One of the things that keeps tripping us up is that the MPLAB compiler does not follow standard C data type promotion rules.
For example, given the statement below, standard C would promote both data types to integer, then multiply. The MPLAB compiler, however, multiplies a and b as unsigned chars and then sticks the result in the integer value, resulting in an overflow where you least expect it! Code:
unsigned char a = 127: unsigned char b = 127; int result; result = (a * b); |
|
#15
|
||||
|
||||
|
Re: Stupidest Programming Mistakes
We've had QUITE a few:
to convert angle radians to degrees: int tiltdeg = tiltrad*( (int)3.14 / 180 ); hmmm, no wonder why we kept getting "0" as a tile angle... and oh yeah, it shoulda been 180/3.14 to begin with... In trying to comment stuff out with "/* */", we realize that we comment out other stuff already commented out using the same method, and whenever it reached that comment's "*/" it would end, causing a bunch of syntax errors throughout the rest of the uncommented code, and we couldnt figure out for the life of us why it was reading that code... and dont know what we were thinking here: if(TILT_SERVO > Tilt_Servo_Max) TILT_SERVO = Tilt_Servo_Max - Tilt_Servo_Min + Step_Size; um, I think we were trying to have the camera search in the last area it saw the light if it immediately loses it too high...but um.. Tilt_Servo_Min = 0 and Step_Size is greater than 0... |
![]() |
| Thread Tools | |
| Display Modes | Rate This Thread |
|
|
Similar Threads
|
||||
| Thread | Thread Starter | Forum | Replies | Last Post |
| Programming Vex w/ MPLab | dababyjebus | FIRST Tech Challenge | 27 | 25-04-2008 09:11 |
| Programming - Getting Started | Mark McLeod | Programming | 80 | 16-04-2008 23:37 |
| VEX programming | Gene F | Programming | 14 | 08-08-2006 22:21 |
| Suggestion for Delphi Programming Posts | Chris Hibner | CD Forum Support | 1 | 27-07-2005 10:02 |
| Robot Programming Education | phrontist | Programming | 11 | 03-05-2004 07:32 |