FYI, the compiler tells you what line it found the error. It is not always 100% accurate - the error may be nearby. In this case though, I'd expect that it nailed it.
The IDE added these lines to the front of your code:
#include "WProgram.h"
long double key_adcbit1(int gas_after);
long double key_adcbit2(int gas_after);
That is the "standard" include of WProgram.h and then it added in function prototypes for your two functions. Hence the error line number was 3 out. Well, actually 5 by my reckoning but sometimes compilers take a line or two to notice something has gone wrong.
You may notice down the bottom LH corner of your editing window a number? That is the current line number the cursor is on. So scroll around until that matches the line number in the error message, and then look around.
It would be helpful if there was a "goto line" menu item in the IDE (hint hint).
I'd also like to point something else out - you likely couldn't find the mistake either because you didn't know what the error meant, or more likely, you had been working on it so long with so many numbers, and you went "cross-eyed" and just didn't see it.
My first question is - what are all of those numbers?
Those numbers are called, in programming, "magic numbers" - in that, you have put the values into your code, but they aren't defined anywhere as to what the values mean.
It would be better to declare them as constants or defines (with clearly worded names), in the body of the code, then use the names in the code so you could easily see what the logic is supposed to be.
For instance, suppose I have the following function:
double feet_to_inches(int feet) {
double inches = feet / 12; // note 12 is a "magic number" - what does it mean?
return inches;
}
Also note that by putting things in the body of the code in a central spot (ie, at the top) - you can easily make one change that will cascade throughout your code - makes maintenance much easier.
/actually - note that the above code should be considered "pseudo" - in that I am not sure if it compiles or runs right; its meant to convey a concept, nothing more...
I notice you have duplicates (in this example 11073). So if you ever decide to change 11073 to 11075 you have to remember to changes two places, and if you forget you get insidious "gaps" (eg. if you change only one place then the number 11074 might never be considered).
If also doesn't make sense to test:
gas_after >= 8073 && gas_after <= 11073
and then
gas_after >= 11073 && gas_after <= 13073
Both compare "equal" for 11073. So is it in the first group or the second group? It should be:
gas_after >= 8073 && gas_after <= 11073
and:
gas_after > 11073 && gas_after <= 13073
Note the change of >= 11073 in the second line to > 11073. Now it is clear that 11073 is in the first group. Still, better to move those numbers to the top of the sketch like cr0sh said.
...
:)
/actually - note that the above code should be considered "pseudo" - in that I am not sure if it compiles or runs right; its meant to convey a concept, nothing more...
[pedantry]
OK, it's pseudo code. But I can't help myself -- to get inches from feet it's traditional to multiply rather than divide...
[/pedantry]