- Feature Articles
- CodeSOD
- Error'd
- 
                
                    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
I saw this wtf, had a great stack of CD's and yotta yotta yotta, I landed on the moon.
Admin
That would be fine and dandy if bytes were always measured in powers of 1024, but network transmission rates, for instance (like "gigabit"), are not. I believe harddrive manufacturers also got in trouble for misrepresenting their harddrive sizes because they used kilobytes (in the SI sense) and not kibibytes (traditional kilobytes).
Now, in the few programs where I see "2.4 KiB", I actually know that it means 2.4*1024 and not 2.4*1000. All it takes is a little "i" in the symbol, and even if you choose to continue pronouncing it "kilobytes," it still helps to know which is meant.
And isn't it illegal in some jurisdictions for "kilo" to mean anything but 1000?
And what about bits instead of bytes? A kilobit is generally 1000 bits (because they are more often used in network transmission rates), while a kilobyte is 1024 bytes. That makes no sense.
I thought it was silly at first, but I have to constantly remind myself whether Windows Explorer means 1000 bytes or 1024 bytes when it says 1KB, and I know for a fact that all programs are not consistant in this regard.
</insert>
Admin
I've calculatyed this before. It's early January or February, 2038 (hence the y2k38 bug) - unless you're posting from 2011, that's not 27 years. If you are, can you please send through a few PDFs of sporting or lotto results for me?
Pax
Admin
Ok... I'm actually the programmer of this snippet. I first heard of the daily WFT about two weeks ago, so when I got an email just now telling me my code was here, I kinda freaked out :) I'm pleased to see that it's not so bad.
As for why...
a) why not? You'll note that the length of the "symbols" list doesn't affect how you get to a given formatting. It could have 1000 prefixes long and you still get to "k" in one step. The only cost is storing that list.
b) who says this is purely for addressing real data? How much data do you need to describe the location of every atom in the solar system to within 1mm? There are plenty of cryptographic examples as well.
c) yes, it amused me. I actually trolled around for a while to find the prefixes out that far. I sure didn't know them off the top of my head :)
Also, new versions allow for SI-based scaling (1000 rather than 1024).
Admin
Venkatesh, is that you?
Admin
I think there was this d00d, who was able to look 100 years into future.
He was able to create highway system that's available right now in the U.S.
Now, what about the guy who has created that piece of code that seems to be the subject of ridiculousness?
Admin
I believe that a bit does have 10 possible values, namely 0 and 1.
Fun,
Sten
Admin
A stack of CDs worth 1 Yottabyte is way larger than just four times the distance to the moon!
1 Yottabytes are 1024^8 = 1.2110^24 bytes. A CD takes about 700 MB = 7.3410^8 bytes, so 1 Yottabytes would need 1.6510^15 CDs. At about 1mm per CD, this stack is about 1.6510^12m high. The moon is about 1 light second = 310^8m away, so the stack of CDs is way higher than just four times the distance to the moon, namely about 5500 times that distance.
The distance to the sun is about 8.3 light minutes = 8.360310^8m = 1.5*10^11m, which is about a tenth of the height of the CD stack, so a stack of CDs worth 1 Yottabyte would go to the sun, and back, and there again, and back again, and there again, and back again, and there again, and back again, and there again, and back again.
Fun,
Sten
PS: I need to restore a file from CD #19327343264632. Could you please go get it for me? I'll wait...
Admin
"""In terms of Compact Discs, we'd need to build a stack high enough to reach the moon ... and back ... and there again ... and back again ... just to have a yottabyte worth of data."""
WTF?
Let's do the math:
Average distance between moon and earth is 385000km, let's assume a double layer DVD, capable of holding 2* 4.7 GB (24.38GiB). A DVD is 1.2mm thick. A yottabyte is 1024^8, so we end up with a stack of DVDs:
ceil((B1024^8) / (8.76B*1024^3)) * 0.0012m / 385000km
= 400.60 times the average distance between earth and moon surfaces.
Admin
/me too will continue to ignore the first-of-its-kind (?) event, that the actual author of the WTF'ed code appeared.
Admin
Hi Micheal,
Actually i'm the one who responsible of this entry and it's nice to hear that you pleased to see your code here ;)
OTOH, i think your code in YUM is pretty delicious.. Keep up the good work..
Ciao,
meren.
Admin
Hey there, good job writing this code, I don't have a problem with it and I fully support the use of these top-end multipliers, I would have struggled but could probably have named all of them - I've got a physics degree and although we just use 1 x 10^24 or whatever, we sometimes like to put a name on our numbers... it can be a yotta fun. :-P
Admin
OMG! The weird thing is that i know *exactly* what you are talking about. Its so funny... but man, its weird.
dZ.
Admin
Sorry man, it melted... along with the floppy stack.
dZ.
Admin
As you can see, current (32-bit) computer systems can address 0.5 vendekabytes. In only a few Moore-times, when we have 128-bit systems, we will be able to address substantially more than a googolbyte.
Admin
Welcome, Michael!
Do not be intimidated by the purile spirt of this thread. Most of us appreciate the elegance of your code and approach. Indeed, of those mocking it, most of them do it in order to be funny, and not to belittle its design.
As Alex said in his introduction, your code is not really a WTF (as a matter of fact, it is the most un-WTF-ish entry we've had in a while), but it's amusing comments are entertaining to other developers as well. Maybe Alex's well of WTF submissions is running dry...?
I hope you stick around this forum for a while. We could always use more smart people with a witty sense of humour, and I'm sure you can use the cynical amusement brought by laughing at bad code and stupid designs.
Cheers!
dZ.
Admin
On a serious note
whats the better statement
"640k (1/2 of a megabyte) ought to be enough for anybody." Bill Gates 1981
Which one do we have to pay for every day of our programming lives :)
Admin
Before you shoot me down in flames , the quote is not accurate i just googled for it and pasted it in
Admin
Ah, Vendeka Bytes... the little known cousin of Veruca Salt, and Charlie's dearest love (after chocolate, of course). Last I heard she was arrested by W.W. security when trying to break into The Factory.
dZ.
Admin
You know why it does that, right? If you install a security update to some piece of code that you're currently using (esp. part of the OS), it's not secure until you reboot. (or at least close and restart that code, but that's not always enough) Some people would install the update and just ignore the request to reboot indefinitely.
Personally, I just shove the window off-screen until the end of the day, but it's not just doing that to be annoying.
Admin
Hmms, lets see if we can simplify this code a bit:
So the last assignment reads: depth = depth - (depth - len(symbols) + 1)
Which can be simplified to: depth = len(symbols) - 1
And as symbol appears to be a constant array (from this code snippet), this would be a constant...
Admin
This may be a reaction to the versions of the UNIX 'df' command where the output formatting was messed up for values larger than a terrabyte, and so on.
Admin
Either one of 10 cases just happened:
[*] Someone missed a binary joke or
[*] I missed missed a joke about a binary joke
Admin
The terrabyte - the Earth's native byte.
Admin
Yes, the terrabyte is the word-size of the successor of Deep Thought.
dZ.
Admin
I was concerned at one point about the lack of overflow handling on a particular counter in the program I was working on (given that the software assumed that the counter values were unique within any given invocation of the program).
Then I actually spent five minutes doing the math: overflowing that counter would require running the software continuously for a few hundred thousand years (and thrashing it pretty hard for that entire time). So instead of adding overflow handling, I just put in a comment warning that the software shouldn't be run for half a million years at a time 8-|
Admin
But I was close! Just off by a couple magnitudes ... and the type of disc ;-). I corrected the post, thx for pointing that out.
Admin
I think actually that this WTF brings a serious issue up. Nobody knows what all those mega this and giga thats mean. It's all greek.
I hereby suggest that we move to a new standard in describing data storage, with the basic unit of measurement being "metres of floppy disks". Everyone knows how much you can get on a floppy, and how long a metre is.
"Dude, I just got a new computer, and it has 300MFDs (metres of floppies) of storage!"
"That's nothing. We've just set up our SAN at work, and we have a London-to-Paris worth of storage".
Ridding ourselves of the megagigayotta technobabble and embracing units of measurement that the layperson can understand is the best thing we can do for the industry.
Next up - "Calculations of the nation debt per minute" to make CPU speeds make more sense, and "how well you can make out a cow from the space station" specifications for digital cameras.
Admin
This is definitely a WTF. It's just a sort of happy, amused "WTF?" as opposed to the shocked, hair-pulling "WTF!" we're used to...
Admin
<FONT face="Courier New" size=2>1 slug = 14.59390 kg</FONT>
<FONT face="Courier New" size=2>that's one big slug.</FONT>
Admin
Quoted for truth.
Admin
Admin
"Not accurate" is one way of putting it. "Apocryphal" or "urban legend" are others.
Admin
I think you, as well as a few others missed the reasoning behind using the 'thresh' variable as opposed to hardcoding 1024. YUM isn't the only place you'll find that; I'm sure that if you looked at apt-get, you'd find it there too, as well as the Windows updater. The reasoning is to force it into the next higher measure earlier, so that you'll get .90GB as opposed to 1000MB, to use the earlier example. You have noticed that, right? Well, doing it your way, as well as was mentioned in an earlier reply(which you and about 3 others appear to be overlooking) will keep that from happening, and won't roll the measure over until it's exactly 1. So, in short, it's not a bug, and is working as intended.
As an addendum, I've said this before, as have 3-4 other folks. This code isn't a WTF in the sense that the board has come to be acquainted with. There's nothing wrong with YUM from a design standpoint, and I'd imagine the rest of YUM is similarly clean and well designed. The WTF here is that they built it all the way to yottabytes, which at this time don't really exist. In practice, a terabyte is about as large as you'll see in a single storage device, and even then, as I'm sure you know, you'll have to set up a rather large RAID array to achieve that. Even so, this isn't really a WTF in the sense of 'WTF was this moron thinking?'. To me, snippets like this that just make you go 'Huh? WTF?' and have a good laugh since there's nothing wrong; it's just something put in there to get a WTF rise and act as a little bit of a joke are good WTFs. And we could certainly use a few more of those around here.
Admin
I just started reading TheDailyWTF, and have been pretty impressed by the quality (or lack thereof) of the submissions. When I saw the first line of this, though, I went "WTF? yum has a WTF?" The rest was reassuring -- it is nice to know that the open-source software that I run does not come close to the scariness of the databases, web applications, and proprietary in-house apps out there. Maybe it's the OPEN SOURCE part of Open Source?
Admin
hehe, seems like you've never bought a new HDD. give me 1000 yottabytes and a month's time, and i'll be back wanting more space :p
Admin
and not very future-proof either - it'll keep interrupting my workflow every 1440 minutes at best! hell, what kind of number is 1440, anyway?
[image]
Admin
1440 minutes = 24 * 6 = 1 day.
Admin
a 0 rolled off the screen and under my desk.
1440 minutes = 24 * 60 = 1 day.
Admin
That must be quite a porn collection.
Admin
And anyway, 640Yb should be enough for anybody.
Admin
Dear JThelen, look again.
Let's assume number is initially a Value of 1048576 yottabytes. Now after the loop the variables have these values:
depth = 10
number = 1
so diff will become 2, which is greater than zero, hence
depth = 8
number = 1 * ( 999 ** 8 ) = 992027944069944027992001
So the final output will be:
992027944069944027992001 YB
while it should be
1048576 YB
Now, is there
[ ] no bug (neither thresh/1024 nor depth/diff)
[ ] one bug (either thresh/1024 or depth/diff)
[ ] two bugs (both, thresh/1024 and depth/diff)
cu
Admin
And if you'd read the whole post that I was referring to, I wasn't addressing that issue. Here it is, since you apparently missed it.
Now, in the regards that this individual, among others is presenting the 'apparent WTF', it's not.
W/r to what you're talking about, yes, it's likely there's a bug in what's there. The real question, IMO, is how much does it matter? The developer obviously put this in as an easter egg of sorts, and one accessible only to someone looking at the source.
Cheers.
Admin
This brings up a question that's always bothered me.
Michael wrote:
b) who says this is purely for addressing real data? How much data do you need to describe the location of every atom in the solar system to within 1mm? There are plenty of cryptographic examples as well.
So, a real-world conundrum: there are approximately 10120 possible chess games. There are approximately 10115 atoms in the universe (estimate). Even assuming one could store one chess game per atom, we're still short. Who will decide which possible chess games never get stored?
Admin
I did, and here is what you wrote
So you talk about rolling over at .9# and that's the cause for using thresh=999. And yes you are right.
Yes, it is ok to compare with thresh in the loop's condition. But in
there is no reference to the loop condition, but to the expression used to convert from wtfbytes back to yottabytes.
And in this expression it is
a) wrong to use thresh=999 instead of 1024
and
b) wrong to use depth instead of diff.
That's the bug pointed out by the other poster, but in your mission to educate everybody about why thresh=999 is correct (which nobody doubted) you missed that point.
I agree.
However, the original code produces always the same output for
1024 yottabytes
1048576 yottabytes
1073741824 yottabytes
...
1024**n yottabytes
And that's a WTF, even if it actually is an easter egg.
cu
Admin
Yep. You guys caught me. There was indeed a bug in the code. It's now fixed in CVS. Thanks. This is most certainly the strangest bug report I've ever had! Fortunately, it was actually in the code that deals with the >1000 yottabyte case, so I rather doubt it ever caused any serious trouble for anyone.
Oh, and I've thoroughly enjoyed this. I have indeed taken any criticism as playful. I figure if you emerge from here anything less than bruised, bloody, and limping, then you should take it as a compliment :)
Admin
And don't forget to change it here also:
http://linux.duke.edu/~mstenner/misc/
:D
Admin
I wonder what fix you did. I like Kannan Goundan's suggestion.
Admin
I certainly do understand the implications of not rebooting, but "No means no." I'm not going to be attacked through a security hole during the hour I leave the software unpatched, as I generally do not even use the software being patched (in this case Outlook Express).
If it were software I am actively using, I might save everything and reboot, but that's a hassle I do not normally want to deal with.
Admin
This reminds me of a funny situation that I had in my first year at the university.
I think all of you know the classical Tower of Hanoi puzzle.
If not then check this link http://www.cut-the-knot.org/recurrence/hanoi.shtml.
So a friend of mine showed me how to implement a simple program in Paskal that solves the puzzle (at these days I was not very good at programming espetially at some "exotic" concepts like recusion :) )
Anyway our major mistake was to make it "user friendly". It prompted for a number of disks before starting moving them.
So we implemented it, saw that it was running and then left. I came back in several hours and wanted to see it once again. But when I started it, it just dumped something like "Haha, what a stupid program it is - it does nothing"
I knew that the only one who could do this was my room mate (only he had a key). When I aksed him why he did this he answered me "The program was doing nothing but just looping endless. I left it looping for hours and then I stopped it."
Beeing a little surprised to hear that I had a insight and asked him how many disks he entered. The answer was devastating: "100. I wanted to see how it works with large numbers. You see - you have a bug in there - it is just looping ..."
So when I stopped laughing I explained him following;
The numbe of moves to solve the Tower of Hanoi puzzle is (2^n) - 1 Where n is the number of the disks.
So to move 100 disks we need 1267650600228229401496703205375 moves. If we had a super PC that makes 1 000 000 000 moves a second (and mine was an old 386 and was not doing 2 or 3 per second with the dumps) then we'll need about 1267650600228229401496 seconds. Which makes 21127510003803823358 minutes -> 352125166730063722 hours -> 14671881947085988 days -> 40196936841331 years which is about 8000 times more than the life of the solar system and 4000 times more than the existence of the whole universe.
Well ... he was right for one thing - the program would be really looping "forever" :).