 
    
    
    
    What is the probability of Igor provinding a wrong result?
For instance, I wrote an example "for" loop at the bottom of this post:
Of course, the output of this function should always print "true" but is there a possibility that Igor would ever return "false". For instance, a logic gate failure for instance? If so, what is the frequency that Igor would provide a wrong output.
variable i=0 For(i=0;i<inf;i+=1) if(i==i) print "true" else print "false" endif endfor end

 
I guess it can be safely said that it is pretty impossible to encounter a "false" when your run the above code (which requires that you get a corruption exactly in the comparison part at the execution time), unless Igor has some bug when running such a loop forever.
July 21, 2015 at 08:45 pm - Permalink
And in this case, such bugs are most likely to be caused by misunderstanding of how floating-point arithmetic works. For instance, i will never actually reach inf, ever. It will simply stop increasing after a (very long) while. That's because the limited resolution of a double-precision floating-point number will result in a situation where i will be so large that adding 1 doesn't change the value- the least significant bit of the mantissa will be larger than 1.
If you suspect that a gamma ray has twiddled one of your bits, causing a failure, just run the code three times. Such an event will happen twice with such vanishingly small probability that you will not see it happen twice.
John Weeks
WaveMetrics, Inc.
support@wavemetrics.com
July 22, 2015 at 09:09 am - Permalink
It would be so convenient to always blame my non-working code on a stray alpha/gamma ray instead on my poorly written code :)
However, assuming I am not exposed to any increased exposure to radiation beyond background and the only shielding is what comes available on my commonly manufactured laptop, what would be the frequency of Igor failing with just basic arithmetic operations. Like, should I expect 1 error in calculations over 1E20 operations?
July 22, 2015 at 11:29 am - Permalink
If I were an experimentalist I'd recommend that you try it -- run an infinite loop with a proper counter and have it record the error. Please report back to us after you have recorded a sufficient number of events for meaningful statistical analysis.
As I am not an experimentalist I'd suggest that one should always assume that any answer returned by a computer has a finite probability of being wrong. If you are a fan of statistics you can try to model the various sources of possible errors but I think you will find that the probability that an error is due to anything but some programmer (you, programmer who wrote the software you use, the people who wrote the OS or the people who wrote the code burned into your CPU) is orders of magnitude greater than due to a cosmic ray affecting your calculation.
A.G.
July 22, 2015 at 01:59 pm - Permalink
An infinite loop is currently running and I plan to keep it running overnight. If it is still running in the morning, I may put my laptop near my smoke detector to speed up this process.
Thanks for your suggestion,
July 22, 2015 at 08:14 pm - Permalink
Try the tool from
http://www.memtest86.com/
It does basically the same: writing something defined to memory, read it back and compare it to what it should be (like your routine). It also provides information about errors AND, as a big benefit, you checked your memory!
From my time working in a (small) computer shop I can tell you some expected results. If a memory bar is broken, it will usually report errors within one minute. A standard QA test included running memtest over night for each new PC (I would say between 500 and 1000 pieces). There was not a single computer failing this test, if it made it through the first 10 minutes.
Long story short: From personal experience, I will not expect an error within 20000 hours of testing.
HJ
July 23, 2015 at 03:27 am - Permalink
July 24, 2015 at 11:01 am - Permalink
HJ
July 30, 2015 at 02:45 am - Permalink