LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

error in Pi value

Solved!
Go to solution

I don't believe the number-to-digits code in LabVIEW can handle extended precision, and so the numeric displays are double precision, even for EXT.  The actual binary value may be the correct one.

0 Kudos
Message 11 of 22
(2,697 Views)

@Mancho00 wrote:

@billko wrote:

*Sigh* Pi to two decimal places is good enough to insert a probe into orbit around Jupiter.


Yes, but you may prefer more precision if they put a probe in Uranus.Smiley Wink


Yikes!!!  LOL!

Bill
CLD
(Mid-Level minion.)
My support system ensures that I don't look totally incompetent.
Proud to say that I've progressed beyond knowing just enough to be dangerous. I now know enough to know that I have no clue about anything at all.
Humble author of the CLAD Nugget.
0 Kudos
Message 12 of 22
(2,685 Views)

Wow, you guys are good!  The explanations are right on the money.  If you look at the binary representation of Pi as a Float (I'm going to use Hex) you get

400921FB54442D18 and that's all.  Do the same, but say that Pi is Extended and get

4000921FB54442D1846A000000000000.  Extended gives you an extra 4 bits in the exponent (hence the extra "0" in the beginning) and 12 (only!) extra bits in the mantissa (46A), which is probably enough to "round" the representation of that last decimal digit from 1 to 2.

 

Bob Schor

0 Kudos
Message 13 of 22
(2,682 Views)

What's stopping you from creating a constant with extended precision in your VI with the value out to whatever level of precision that extended gives you?  Nothing says you need to use NI's pi constant.

 

What are you doing that the 16th or 17th significant digit mattters?

0 Kudos
Message 14 of 22
(2,672 Views)

@eximo wrote:

 

This causes issues believe it or not when solving some equations, it took us awhile to find it.

 


Don't go on a witch hunt here. I am sure the problem here is elsewhere. Can you explain the equations you are trying to solve? I am sure rounding errors due to minor changes in ordering of operations are more severe. Even if something looks identical in symbolic math you can get quite different results by just doing the same operations in a slightly different order, especially for long, iterative procedures.

 

If you require significantly more digits (and who doesn't), you need to write your own tools or implement something like GMP. (As another example, here's a simple way to calculate all 35660 digits of 10000! (factorial))

 

NI does not bake their own Pi(e), I am sure these are binary identical to the standard values used anywhere else. You get 15 decimal digits as promised for DBL and at least 15 as promised to EXT (see the context help). The values are rounded to the nearest binary value based on the number of bits in the mantissa, which has very little to do with the decimal representation (e.g. 0.1 cannot be represented in a finite number of bits).

 

I am still interested in your math problem!

 

 

Message 15 of 22
(2,657 Views)

@Mancho00 wrote:

LabVIEW help for pi constant says 3.1415926535897932.  If it can't be represented properly at double precision, NI shouldn't be storing it as such.  I'd call that a bug.


Pi can never be represented "properly" unless you have an infinite amount of bits (or digits). The constants are rounded to the nearest available binary value for all representations and that is sufficient. All other floating point values in your operations have the exact same limitations, so don't point the finger at pi.

0 Kudos
Message 16 of 22
(2,656 Views)

@altenbach wrote:

@Mancho00 wrote:

LabVIEW help for pi constant says 3.1415926535897932.  If it can't be represented properly at double precision, NI shouldn't be storing it as such.  I'd call that a bug.


Pi can never be represented "properly" unless you have an infinite amount of bits (or digits). The constants are rounded to the nearest available binary value for all representations and that is sufficient. All other floating point values in your operations have the exact same limitations, so don't point the finger at pi.


Don't be disingenuous.  I think it's pretty obvious I was't talking about infinite precision.  I was noting that the value of the pi constant, represented at the default double precision, does not equal to what the LabVIEW help states.  This is, of course, before I knew that the representation can be changed.

Edit: Of course, I have no idea why someone would need that kind of precision, but whatever.

0 Kudos
Message 17 of 22
(2,626 Views)

If you right click on the Pi constant,you can set it's representation.  Setting it to 6 digit precision (single precision) it still expresses Pi as a highly precise number in an indicator set to 16 digits.

3.1415927410125732 vs 
3.1415926535897932

Is this expected behavior?  If it's precision is only to 6 points, why is it expressing numbers after the 7th decimal at all?

According to the math for obtaining decimal points, it would take 31 bits to obtain a precision of 0.0000000004656612 (10 decimal points)

and 42 bits to obtain 16 4.4408920e-16.  LabVIEW's ability to display the values thus depends on how the 64 bits are being split up.  LabVIEW as great as it is, I feel like it should be indicating what numbers are BS and what numbers are significant since we programmers have gotten so far away from significunds and bit depth in the numbers. 

I suppose it's not a bug, but just the architecture of the computer being exposed.

-Regards

eximo
_______________________________________________
UofL Bioengineering M.S.
Neuronetrix

"I had rather be right than be president" -Henry Clay
0 Kudos
Message 18 of 22
(2,616 Views)

@eximo wrote:

Is this expected behavior?  If it's precision is only to 6 points, why is it expressing numbers after the 7th decimal at all?


Again the difference is between binary and decimal. It is not "expressing" anything and if you would expect that all decimal digits past the stated resolution are zero you are wrong. The extra digits are random in decimal representation. What you seeing is the decimal formatted value that exactly corresponds to the binary representation. If you would increment or decrement the mantissa by one bit, you'll get a value that is further away from the right PI value, again with seemingly random (but exactly predictable digits) past the valid resolution. It is your responsibility to pick a format that only displays valid digits if it bothers you cosmetically.

 


@eximo wrote:


According to the math for obtaining decimal points, it would take 31 bits to obtain a precision of 0.0000000004656612 (10 decimal points)

 


Also please don't confuse "precision" with digits past the decimal point. This value only has 7 significant digits, and that's all that matters. The bits for the exponent define the scaling. (see also)

 

 

0 Kudos
Message 19 of 22
(2,610 Views)
Solution
Accepted by topic author eximo

@eximo wrote:

I suppose it's not a bug, but just the architecture of the computer being exposed.


It a side effect of binary representation, independent of any computer. You would get the same result doing the same calculations with paper&pencil 😄

 

Using the following code, you can see that the SGL value of Pi is closest to the much more precise DBL value compared to it's immediate binary (SGL) neighbors and that's the best possible approximation.

 

PiParty.png

 

(You can get a similar result comparing DBL with EXT, and casting to U64. Now the quantization steps are on the order of ~5E-16)

 

 

Message 20 of 22
(2,593 Views)