LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

do numerical indicators display extended precision floats correctly?

I'm using windows XP sp2 on a new computer with a new intel processor, nothing weird. I'm displaying an extended precision floating point number using a numeric indicator that is set to display an extended data type with thirty digits of precision. I expect to see at least 19 or 20 significant digits out of my extended precision float, but the numeric indicator only ever displays 17 significant digits before going to a trail of zeros. Does the display routine that converts the float to a display string use double precision or what?

global variables make robots angry


Message 1 of 26
(6,547 Views)
The number of decimal digits for the EXT data type varies from 15 to 20 depending on platform. This is documented in the LabVIEW Help. For Windows, it's about 16. At least on mine, anyway.
0 Kudos
Message 2 of 26
(6,536 Views)
I looked it up and I'm under the impression (perhaps mistaken) that I should have about twenty significant digits of accuracy on the extended type, yet only 17 are displayed. So my question is this: is the numeric indicator capable of fully resolving an extended precision on an intel/windows platform or is the display conversion being made using double precision, thus limiting the number of significant digits actually displayed to less than the number of significant digits of accuracy stored within the extended precision variable?


Message Edited by Root Canal on 06-06-2008 05:16 PM

global variables make robots angry


0 Kudos
Message 3 of 26
(6,533 Views)
You could look at the binary value of the ext and parse it manually to see what's inside the value.
Are you absolutly positive you have 20 signifacant digits?
How do you get the number?

Ton
Free Code Capture Tool! Version 2.1.3 with comments, web-upload, back-save and snippets!
Nederlandse LabVIEW user groep www.lvug.nl
My LabVIEW Ideas

LabVIEW, programming like it should be!
0 Kudos
Message 4 of 26
(6,509 Views)
This example may help to convey what I'm confused about (I hope).
 


Message Edited by Root Canal on 06-09-2008 01:36 PM

global variables make robots angry


Message 5 of 26
(6,480 Views)
I think you are confusing yourself with the limitations of binary representation of decimal numbers. As Ton suggested earlier looking at the binary is the only way to really tell what is happening.

Create two controls (EXT type) with as many digits of display as you wish. On the diagram divide one by the other and then display the quotient. Now look at the results of dividing 1 by 3 or 5.

1/3 => 0.333333333333333314829616256247...

1./5 => 0.200000000000000011102230246252...

Neither of these values can be represented exactly in binary floating point. They are infinitely repeating fractions in binary, just as 1/3 is in decimal.

Lynn
Message 6 of 26
(6,466 Views)

Yes, I understand what you are saying and you are completely correct. The problem I have is not that I expect a mathematically perfect representation of a number, but rather that LabVIEW calculates and produces an 80-bit extended precision number on my computer and then appears to convert it to a 64-bit representation of that number before displaying it!

 

If you convert the extended precision value into an unflattened string in order to attempt to access the binary representation of the data, you’ll find that it is represented by 80-bits. This is a 64-bit fraction plus a 15-bit exponent plus one bit for the sign. Delightfully, the flatten to string function appears to scramble the bits into “noncontiguous” pieces, so about all I can tell for certain is that we have, as expected, an 80-bit extended precision number in memory. The documentation for the other number-to-Boolean array and bit manipulation functions I looked at (even the exponent-mantissa function) all claim to only be able to handle a maximum input of a 64-bit number (double precision float max) -correct me if I’m wrong on this one, because I’d really like to be able to see the contiguous binary representation of 80-bit extended floats.

 

It turns out though that what you said about not being able to tell whether we have twenty digits of precision without bit fiddling is not true at all. If you look at the program I wrote, you can prove with simple addition and subtraction that beyond the shadow of a doubt the extended numbers are being stored and calculated with twenty digits of precision on my computer yet being displayed with less precision.


As you can plainly see in the previous example I sent:

A =          0.1111111111
B =         0.00000000001111111111
A+B=C= 0.11111111111111111111

 

We know that
C-A=B

 

The actual answer we get is
C-A=0.00000000001111111110887672


Instead of the unattainable ideal of
C-A=0.00000000001111111111

 

The first nineteen digits of the calculated answer are exactly correct. The remainder of the actual answer is equal to 88.7672% of the remainder of the perfect answer, so we effectively have 19.887672 digits of accuracy.

 

That all sounds well and good until you realize that no individual number displayed on the front panel seems to be displayed with more than 16-17 significant digits of accuracy.

 

As you see below, the number displayed for the value of A+B was definitely not as close to being the right answer as the number LabVIEW stores internally in memory.

 

A+B=0.11111111111111111111 (the mathematically ideal result)
A+B=0.111111111111111105     (what LabVIEW displays as its result)

 

We know darned well that if the final answer of A+B-A was accurate to twenty digits, then the intermediate step of A-B did not have a huge error in the seventeenth or eighteenth digit! The value being displayed by LabVIEW is not close to being the value in the LabVIEW variable because if it were then the result of the subtract operation would be drastically different!

 

0.11111111111111110500       (this is what LabVIEW shows as A+B)  
0.11111111110000000000       (this is what we entered and what LabVIEW shows for A)
0.00000000001111110500    (this is the best we can expect for A+B-A)


0.00000000001111111110887672 this is what LabVIEW manages to calculate.

 

The final number LabVIEW calculates magically has extra accuracy conjured back into it somehow! It’s more than 1000 times more accurate than a perfect calculation using the corrupted value of A+B that the display shows us – the three extra digits give us three orders of magnitude better resolution than should be possible unless LabVIEW is displaying a less accurate version of A+B than is actually being used!

 

This would be like making a huge mistake at the beginning of a math problem, and then making a huge mistake at the end and having them cancel each other out. Except imagine getting that lucky on every answer on every question. No matter what numbers I plug into my LabVIEW program, the intermediate step of A+B has only about 16-17 digits of accuracy, but miraculously the final step of A+B-A will have 19-20 digits of accuracy. The final box at the bottom of the program shows why.

 

If you convert the numbers to double and use doubles to calculate the final answer, you only get 16-17 digits of accuracy. That’s no surprise because 16 digits of accuracy is about as good as you’re gonna do with a 64-bit floating point representation. So it’s no wonder all the extended numbers I display appear to only have the same accuracy as a 64-bit representation because the display routine is using double precision numbers, not extended precision.

 

This is not cool at all. The indicator is labeled as being able to accept an extended precision number and it allows the user to crank out a ridiculous number of significant digits. There is no little red dot on the input wire telling me, ‘hey, I’m converting to a less accurate representation here, ok!’ Instead, the icon shows me ‘EXT’ for ‘Hey, I’m set to extended precision!’

 

The irony is that the documentation for the addition function indicates that it converts input to double. It obviously can handle extended.

I’ve included a modified version of the vi for you to tinker with. Enter some different numbers on the front panel and see what I mean.

Regardless of all this jazz, if someone knows the real scoop on the original question, please end our suffering: Can LabVIEW display extended floating point numbers properly, or is it converting to double precision somewhere before numerals get written to the front panel indicator?



Message Edited by Root Canal on 06-09-2008 07:16 PM

global variables make robots angry


Message 7 of 26
(6,437 Views)
Hi Rootcanal,

I currently don't have the time to dive into this.
If I were you I would call my local NI office, get support to look at this thread.
Don't be satisfied until you get an offical answer. Please post this answer here.

Good luck,

Ton
Free Code Capture Tool! Version 2.1.3 with comments, web-upload, back-save and snippets!
Nederlandse LabVIEW user groep www.lvug.nl
My LabVIEW Ideas

LabVIEW, programming like it should be!
0 Kudos
Message 8 of 26
(6,417 Views)
It looks as if though an official resolution to this matter may be slow in coming. A week after submitting a support request, I received this cryptic message sent from the secret, hallowed corridors of the subterranean Labview development complex:
 
"Thank you for your feedback. In response to your recent forum post, we have already escalated this to the LabVIEW developers to determine if this is an error in LabVIEW, or simply a lack of documentation on the topic.

When I receive more information, I will let you know what we figure out and what course of action we decide to take."

If there really is a precision problem here, I don't imagine that this minor issue is liable to affect anyone other than myself adversely. However, if you are reading this post in order to find out whether or not there is something fishy with displaying extended precision numbers, the best I can do for you is to relay the tentative guess of a support engineer. He told me over the phone that it looked like the numeric indicator can not display more precision than can be held within a double precision 64-bit numeric value, but that he wasn't really sure.

I will post the official determination promptly upon its imminent arrival, assuming that they have email in hell. Cheers.


global variables make robots angry


Message 9 of 26
(6,311 Views)
Thanks for keeping us informed. I'd be curious to find out if there really is a limitation with the indicators.
0 Kudos
Message 10 of 26
(6,300 Views)