LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

quotient & remainder bug

Message Edited by tbob on 02-02-2006 12:56 PM

- tbob

Inventor of the WORM Global
0 Kudos
Message 81 of 95
(2,963 Views)


@rolfk wrote:

 So the only solution would be to create yet another version where you could somehow specify the actual precision wanted, but that would be a tedious project at least,


I just did this with Q&R.  Took 5 minutes, plus 2 more minutes after JP found a bug.  I don't think it would be very difficult to create the same for other functions  In fact, I'm going to do one for equality.
- tbob

Inventor of the WORM Global
0 Kudos
Message 82 of 95
(2,953 Views)

If tst reads this thread, tst will have the Energizer Rabbit as an avatar!!

😮

 
 
the thread keeps going & going & going & going & going & going & going & going & going & going

Message Edited by JoeLabView on 02-02-2006 03:39 PM

Message 83 of 95
(2,940 Views)


@tbob wrote:


@ rolfk wrote:

 So the only solution would be to create yet another version where you could somehow specify the actual precision wanted, but that would be a tedious project at least,


I just did this with Q&R.  Took 5 minutes, plus 2 more minutes after JP found a bug.  I don't think it would be very difficult to create the same for other functions  In fact, I'm going to do one for equality.


There will be many more possible bugs lurking and many more border cases where your solution will just as much be non-intuitive in its results.
And then try to think about doing this for division, multiplication, addition, etc and also about supporting different datatypes such as singles, doubles and extendeds, with the possible complication that there might be some differences in numerical coprocessor implementations for floating point numbers (remember the Pentium bug?) , and even more complicated completely different representations of the extended floating point format for the different LabVIEW platforms.

Not something I'm going to spend any time with for sure. 😉

Rolf Kalbermatter
Rolf Kalbermatter
My Blog
Message 84 of 95
(2,943 Views)


There will be many more possible bugs lurking and many more border cases where your solution will just as much be non-intuitive in its results.

I think the only general applicable approach will be to simply round the numbers to a certain number of digits. That will also work with quantization errors that have been introduced earlier. Something that the other more elaborate tricks with multiplicating etc can't handle...    Such a rounding approach would be extremely easy to implement.  That's only a few minutes work.

I'm sure that NI can find a reasonable default number for the rounding.  I'm not a mathematician, but I suspect that the error propagation behaves a bit asymptotically.  If that's indeed the case, then you could find a reasonable estimate for the number of digits to remove, so that you're always safe.  I wouldn't be surprised if removing for example the last 4 digits works sufficiently for almost all cases.

You could also do some reasoning from the hardware point of view.  Most DAQ cards are 'only' 16bit.  That means 65000 steps, or some 5 orders of magnitude.  Only a handfull of cards are 24 bits, thus 16 miljoen steps. That's some 7 orders of magnitude.  So you accuracy of your input is limited to some 8 digits.   So you might well argue that setting the default rouding at 9 digits is sufficient.  

I could also very well imagine that you could set a user-definied default accuracy for a complete vi. 

This whole thing wouldn't really be that difficult for the user.  Allready, he/she also has to make a choice for using SGL, DBL or EXT.  This accuracy choice is something closely related to it. 


And then try to think about doing this for division, multiplication, addition, etc and also about supporting different datatypes such as singles, doubles and extendeds, with the possible complication that there might be some differences in numerical coprocessor implementations for floating point numbers (remember the Pentium bug?) , and even more complicated completely different representations of the extended floating point format for the different LabVIEW platforms.

Didn't you read my reply at all??   I thought I explained quite thoroughly....

The only vi's that need rounding, are the ones doing a comparison between two real numbers.
The results of all other operations should absolutely not be rounded.    

The number of vi's that would need a change, or an alternative is thus very small. 

0 Kudos
Message 85 of 95
(2,903 Views)


Changing the current math nodes is anyhow no option as that would break compatibility in way more ways than you would want to think about.

I don't think it would break any compatibility.   

As it is now, the 'QR' and 'equal?' give meaningless results when used on reals. Because of that, nobody uses them. (or should use them...)  So there is no compatibility to break in those vi's.   

The other comparison vi's are used often, but only in situations where the quantization errors don't influence the results in a problematic way, because the input/output is expected to be quite inaccurate anyway.  In those cases, removing the quantization errors plus maybe some extra digits won't influence compatibility either. 

These are the only vi's that are influenced.  Please tell me where any compatibility issue would arise... 

BTW.... in Labview 8 there's a whole lot of vi's that have been changed in their behaviour, causing possible compatibility problem.  No reason why the reals comparison vi's can't be changed as well.

Message 86 of 95
(2,902 Views)
Anthony,

your solution of an accurate Q&R could become handy for trig functions. If you calculate sin(2*Pi) (use the numerical constant 2Pi from the palette) the result is -2.44921E-16 instead of zero. The error goes worse for higher multipes of 2Pi. If you could calculate accurately the remainder of a number modulo 2Pi, then it would fix these inaccuracies. How would you implement that?


LabVIEW, C'est LabVIEW

Message 87 of 95
(2,866 Views)
Jean-Pierre,
 
You're right, it makes a very big difference using the accurate Q&R.   
 
Like you said, the error increases for higher multiples of 2PI. 
At 0x 2PI, you get the answer zero:  0E+0. 
At 1x 2PI, you get a result in the order of 1E-16  
At 10x 2PI, you're allready into 1E-15
At 200x2PI, you're reached 1E-13...    
 
I then put my Q&R routine with 2PI in front of the sin, and wired the remainder to the sin.  If you do that with the accurate Q&R, then you always get 0E+0.   So that certainly makes a big difference. 
 
However, I would have expected that the old Q&R would work very well too!
The inaccuracy should be one multiple at most. And thus the answer should always stay in the order of 1E-16.    However, it doesn't! 
 
There's something really strange with the old Q&R before the sin.   For some multiples, it gives the answer 0E+0.    But for others, it is almost just as bad as doing nothing!   It's also getting into the 1E-13 range!  
 
I don't understand how that's possible....   Apparantly the remainder is calculated in a different way than what the description suggests.
 
 
I've attached a program to demonstrate. It gives 3 columns, with different multiples, so you can easily compare.   First only the sin(N*2PI), then the old Q&R, then my accurate Q&R.   Narrow colums show N.
 
My Q&R routine is very simple.  I convert x/y to SGL, before using the floor operation. The remainder is then calculated as usual.  
 
Seems that we've found another case scenario where this accurate Q&R could be usefull. 
Download All
0 Kudos
Message 88 of 95
(2,844 Views)

Hi Molly,

its an old thread but I just ran into the same problem.

 

Jim

0 Kudos
Message 89 of 95
(835 Views)

xband wrote:

its an old thread but I just ran into the same problem.


It would help if you could be more specific in the problem description (What you expect to happen, what actually happens).

 

Running your VI with the default control values under LabVIEW 2012 does not show anything unusual.

 

What do you see? (Sorry, I no longer have LabVIEW 2009)

0 Kudos
Message 90 of 95
(827 Views)