- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- Secret Horror
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
In my experience, reverse engineering/refactoring tools tend to produce:
<cat walked over my keyboard>@smoosh%xxx1 <cat walked over my keyboard>@smoosh%xxx2 <cat walked over my keyboard>@smoosh%xxx3 <cat walked over my keyboard>@smoosh%xxx4
and so on. (I'm being kind: they're normally not that consistent.)
Show me a reflection tool that consistently renames integers as in the OP, and I will be deeply impressed. (And depressed at the same time. Who would feel the need for such a tool?)
Otherwise:
You're kidding, right?
Admin
Nice catch.
For the record, in mathematical usage this kind of ambiguity would be a problem but for intonation when verbalized and shared familiarity with the problem domain.
Admin
"Yarr.. noe theuy didn'ut. Theuy joust oused ye Engliush speulling, has oppoused tou ye Ameurican Engliush speulling.
"(Oi liuve hin Englaund. Ouwe speeke Engliush. Theure his noe souch thiung has "Britiush Engliush" - thaut would bee loike "European Freunch". Hit his ye outher variaunts whiuch should bee nuamed differauntly.)"
-Harrouwe.
Admin
I was using integer powers in a simple benchmark program. I'd loop for 10^1, then 10^2, then 10^3, until the loop took more than 1 second to complete. It gave a pretty reliable indicator of the speed of a given language. IIRC C overflowed the 32-bit loop counter (10^10), and some languages were as bad as 10^5.
It was originally: for(i=0;i<pow(10,j);i++) Optimized to: (with a truely stupid speed increase) for(i=pow(10,j);i>0;i--) But as it turned out, the pow function was slow enough to impact the results, even when only run once. Replaced it with a simple int^int version that just multiplied x times in a loop, which turned out to be faster, even at x^10. Eventually I figured that I could just multiply the max value by 10 each loop outside of the timer, eradicating pow altogether. I was young...
I also had a few problems getting a sensible result from VC++, because it was optimizing the loop out entirely, and just doing i=pow(10,j) (on the original, before hand optimizing it). "0s for 10^10, what?" No other compiler for any language I tried did that one.
But yeah, my point was that pow is slower than 10 integer multiplies in a row, and sqrt is as bad.
Admin
You guys are aware that America is the only English speaking nation that DROPPED the u's right...?
Your friendly neighbours to the north kept them, same with the Aussies.
:P
Admin
Oh come on. It's not like Phil's from York, surely..
Admin
-Harrow.
Admin
I think you missed his point: Our theorized tool is NOT "renaming integers". The tool is guessing the name of a constant based on the constant's known value, which in this case happens to be an integer. That is because the information of what the constant was called for human usage has been discarded.
As for cats walking on keyboards, I've seen Java, by notable example, decompile quite nicely.
Captcha: Zim eats... Waffles!
Admin
"SQRT_3_OVER_2" doesn't document any purpose at all...no different than "#define FOUR 4". If you have a number like that it probably has a real puropse. Sure, it's better than hardcoding the literal constant itself -- but not by much.
Admin
It's actually incorrect how he named those variables as well...
5422 is Five thousand four hundred twenty two. NOT Five thousand four hundred and twenty two
Admin
And by "decompile" I assume you mean "decompose." Not just quite nicely, but quite quickly.
Nice captcha, BTW.
Admin
Uh... U's were not dropped from the language. They were added. When (what is now) the US was still under British rule, there were no extra U's in words like "hono[u]r". The U's were added later (middle of the 19th century if I remember correctly), which is why places like Canada and Australia use that spelling (the British Monarch is still their head of state).
Admin
You win the Internet. ROFL, seriously.
Admin
“Added” is a nice euphemism. It’s documented that during the War of 1812, a Canadian commando force stole all the u’s from the US in a brilliant raid on the National Vowel Repository in Philadelphia. The ill-gotten u’s were redistributed around the British Empire where they stuck them wherever they could. Until the rich Gatlinburg u deposits were discovered in the mountains of Tennessee, Americans military leaders were unable to order flanking assaults or counter-attacks.
Letter imperialism is an ugly page in history. Look at all those Eastern European countries which still feel the effects of a desperate vowel shortage in their words, thanks to Napoleon’s collecting vowels as “war prizes” for the French language while on his way to Moscow.
--Rank
Admin
I'd just like to point out while he was being cleeeevar, he messed up, should read
private static final int ONETHOUSANDANDTWENTYFOUR = 1000.24; private static final int TWOTHOUSANDANDFOURTYEIGHT = 2000.48;
-- and captcha didn't catch me
Admin
They also make funny faces when they speak, cf. http://www.youtube.com/watch?v=yafc_jSv2Wg&mode=related&search=
:)
Admin
err... that was supposed to be a link to this Russell Peters sketch on Youtube.
http://www.youtube.com/watch?v=yafc_jSv2Wg
Admin
Something wrong with your vowels?
http://www.angelfire.com/ok5/pearly/htmls/onion-vowels.html
Admin
I disagree that all power functions are incredibly taxing on most systems. This is a numerical analysis issue.
Fortran compilers optimized base raised to the pow (base**pow) well. For an integer pow variable, it created a loop: R = 1 DO I = 1,POW R = RBASE ENDDO A real pow variable needed logaritms: R = EXP(POWLOG(BASE)).
Furthermore, SQRT(N) can use the Newton-Raphson method solving for X in X2 - N = 0. This converges rapidly. Because X2 is a parabola, there are no alternate roots to converge, like X**3 and higher powers.
Admin
Oh. My. God.
Admin
I'm not sure where you're getting this. While it's not entirely true that American spelling dropped the U's, it's a lot more close to the truth than claiming that the UK, etc. added them. Noah Webster is singlehandedly responsible for quite a bit of the spelling differences between UK and American English.
http://en.wikipedia.org/wiki/American_and_British_English_spelling_differences
Admin
ONETHOUSANDANDTWENTYFOUR is not 1000.24.
Actually, the unnecessary "AND" doesn't create any ambiguity in the above example. However, the "AND" should be left out. It creates ambiguity when you say "three hundred and twelve thousandsth." That expression is not .312 but rather 300.012 because the "and" acts as a decimal point.
And by the way, is it okay to declare an INT as a number with two decimals places?
Admin
Admin
Well, aside from the already noted fact that you probably actually want sqrt(3.0)/2.0, that's not the solution you want in any floating point program in which you really care about accuracy because the compiler runtime (ie the sqrt performed at compile-time to produce the constant) may not calculate it to the same precision as the program runtime (ie the sqrt performed when the compiled program executes).
This can easily happen on a normal compiler due to optimizing factors, and is almost guaranteed to happen in cross-compiling, since the host FP system won't be the same as the target FP system.
And it's rather inconvenient if you end up with a resultant program where
Admin
Admin
That's a big improvement! Let's push that idea more forward!
The romanians were used to round numbers like X, L, M, so did the arabians 10, 100, 1000 and so do we hackabes: 0x200 0x400.
Let's use the romanian M as if it where a binary k, alias 1024. For clarity we prefix it with a b (binary):
private constant static int bL = 128; private constant static int bLL= 256; private constant static int bD = 512; private constant static int bM = 1024; private constant static int bMM= 2048;
isn't that pretty?
Of course we could observe the needless roman way.
private constant static int 2P7 = 128; private constant static int 2P8 = 256; private constant static int 2P9 = 512; private constant static int 2P10= 1024; private constant static int 2P11= 2048;
Hm. 7, 8, 9 is not very geeky. 8 is 2P3, so 2P8 could be written as 2P2P3. 7 is 2P2 + 2P1 + 2P0 128 could be reduced to 2P_2P2p2P1p2P0.
Admin
Yep. It is sin(pi/3) (or cos(pi/6)) and frequently appears in elementary trigonometry.
Admin
Actually, he probably is. How else would he have come to the conclusion that the square root of 3/2 (definitely greater than 1) is equal to 0.612... (definitely less than 1). The mind boggles (at least he got sqrt(3)/2 correct).
sqrt(3/2) = 1.22474487139158904909864203735..., which is twice what Cloak reported. He was obviously thinking of SQRT_3_OVER_2_OVER_2...
Admin
Shouldn't that then be private constant static int bC = 128; and not private constant static int bL = 128;
C is the roman number for hundreds where as L is 50
Admin
Obviously the intent here was "1000 & 24" etc.
Admin
Another popular version:
Admin
absolutely! My fault. Mea culpy!
Admin
Not do mention the Americans dropping the 'r' in Arse !
Admin
First of all, the "Romanian empire" died in a hail of bullets with Nicolae Ceaucescu. I believe you are thinking of the "Romulan empire." God knows what their numeric system was: degenerate Klingon, perhaps?
I do so like "For clarity we prefix it with a b (binary)." Very clear. Hungarian notation on Romanian obfuscation. Here comes the next Balkan war ...
And, "private constant static int 2P7 = 128?"
I don't know where this comes from, needless and Roman as it might be, but AFAIK it won't compile in Java. Or in any other sensible language. (Did I just accuse Java of being sensible?) What, exactly, is the point?
All of which is beaten by "C is the roman number for hundreds where as L is 50."
It's difficult to know which is the more cretinous: pointing out the bleeding obvious in a context that requires no explanation, or attempting to analyse a meaningless post and picking nits in it.
Oh, hang on a minute ... What am I doing here?
Well, that's WTF for you. Incidentally, O Thieu Choi's post was both wise and witty. As usual, everything else has rapidly disappeared around the S-bend.
Admin
hello cargo cult!
Admin
No evidence of any copyright violation there; it's potential TRADEMARK infringement. However even if thedailywtf was registered as a trademark, he now uses worsethanfailure in full, so I don't think there's a case.
Admin
Wha? Klingons use base 10, same as us. This was supposedly brought about to better understand scientific work of other planets; they originally used base 3 (not 13).
What's "Klingonian" anyway?
Admin
"Ase"? Gives polymerase a whole new meaning ... (As in "We are dyslexic of Borg, prepare to have your ass laminated.)
Admin
Admin
Admin
The magazine itself is, as per usual with UK "tech" glossies featuring desirable women in bondage clothes on the front, predictably worthless.
Admin
Admin
Actually there is a European French, which is distinct from the French spoken in Canada.
Regarding the original post, this is just a classic example of someone not "getting it" - they were told to use constants for numerals, so they did it, without really understanding why.
I really don't mind The Captchas on this site much - at least I can read them, unlike some sites!
Admin
You may want to check your math... I am to lazy to calculate this now - but its just wrong.
Admin
so now with quotes...
Admin
Surely not as common as simple scalars:
How often is support for multiple simultaneous error conditions required?
Admin
With respect to SQRT_3_OVER_2, a better name might be SIN60.
However, my own rule of thumb about taking pains to speed program execution is that if it takes me longer to type figure it out and type it out than it will take for execution in the lifetime of the program, I don't bother. That would include just about all homework assignments. And I trust my compiler to resolve constants.
Admin
Reflector tries it best by naming local variables to the parameters from the first method they use.
Like if I have a method
public void PrintNumber(int number);
And I decompile some code:
public void DoStuff() { int number = 5; PrintNumber(number); }
Which works most of the time but sometimes it gives a pretty funny result.
Admin
While in C++ (e.g.) there is a small chance that sqrt is overloaded as something like "int sqrt(int)", at least the 2.0 is redundant. If sqrt(3.0), for some strange reason, returns an integer, then all is lost anyhow.
Yes, but calculating sqrt(x) as exp(log(x) / 2) is inefficient* and since sqrt is used very often, it is almost always special-cased to use a more efficient algorithm, e.g. the one mentioned by Andrew.
*) for x > 0, obviously
Using enormous tables that clog up your RAM and hard disk? What was the square root of 179257833209697 again? Seriously, for some small range of integers that might possibly make sense.
Admin
I am so doing this for all numeric values in my next project...