LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Perform operation based in DBL input value

Solved!
Go to solution

Hello,

 

I am trying to perform specific operations based on a DBL input.  In my case, if the input is between 701.0125 and 710.0675, I would do Test A.  If Test is between 710.0625 and 720.9875, I would perform Test B.  If however, the input is either 701.0125, 710.0675 or 720.9875, I would do a test based on those specific values.

 

I was attempting this, but it is getting convoluted:

hiNI_0-1628107007515.png

 

Is there an easier method to accomplish this task as the Array ranges grow?

Message 1 of 6
(3,289 Views)

Somehow or another, Threshold 1D Array is going to be your saving grace with something like this. The addition of 'if the value is exactly one of those numbers, then I need to do something different' only makes it a little bit more challenging. This is what I came up with after a couple minutes of thinking about it...

 

If you aren't already familiar with Threshold 1D Array, start playing around with it and you'll be on your way to a much cleaner solution.

Spoiler
FireFistRedhawk_0-1628111136312.png
Redhawk
Test Engineer at Moog Inc.

Saying "Thanks that fixed it" or "Thanks that answers my question" and not giving a Kudo or Marked Solution, is like telling your waiter they did a great job and not leaving a tip. Please, tip your waiters.

Message 2 of 6
(3,276 Views)
Solution
Accepted by hiNI

Yes, create a sorted array of limits and use threshold array to convert it into an index.

 

Have a look at this old example.

 

 

(here we use the resulting integer to index into an array of colors, but you can use it for anything else. If you only have one input value, get rid of the FOR loop, of course).

Message 3 of 6
(3,250 Views)

I would be extremely careful trying to check for exact equality of a floating point value - for your 701.0125, 710.0675 or 720.9875 values, it is very unlikely that any calculated or measured value would precisely equal the constant value in your code.

 

If you need to match the values to within a certain number of decimal places, either use a range for these as well or convert them into strings first and then match those

 

I would look at either of these for a more thorough explanation

 

This one is fairly straightforward 

https://www.phys.uconn.edu/~rozman/Courses/P2200_15F/downloads/floating-point-guide-2015-10-15.pdf

 

This goes into a lot of gory details

https://docs.oracle.com/cd/E19957-01/806-3568/ncg_goldberg.html

 

The TLDR is that binary numbers round differently to decimal ones, so what looks like a short number of decimals can be an arbitrarily long binary number, longer that even extended precision floats can represent accurately

 

One final thing, is there an overlap in the ranges of your test A and test B cases - so that 710.0600 would fall into both?

 

Cheers
Brett

Senior Software Development Engineer
Certified LabVIEW Architect and LabVIEW Champion
https://theLonelyAnt.com
https://GDevConANZ.org.au


Message 4 of 6
(3,195 Views)

@Brett_Percy wrote:

I would be extremely careful trying to check for exact equality of a floating point value - for your 701.0125, 710.0675 or 720.9875 values, it is very unlikely that any calculated or measured value would precisely equal the constant value in your code.

 

If you need to match the values to within a certain number of decimal places, either use a range for these as well or convert them into strings first and then match those

 

I would look at either of these for a more thorough explanation

 

This one is fairly straightforward 

https://www.phys.uconn.edu/~rozman/Courses/P2200_15F/downloads/floating-point-guide-2015-10-15.pdf

 

This goes into a lot of gory details

https://docs.oracle.com/cd/E19957-01/806-3568/ncg_goldberg.html

 

The TLDR is that binary numbers round differently to decimal ones, so what looks like a short number of decimals can be an arbitrarily long binary number, longer that even extended precision floats can represent accurately

 

One final thing, is there an overlap in the ranges of your test A and test B cases - so that 710.0600 would fall into both?

 

Cheers
Brett


To compare floating point numbers to x places, I multiply both numbers by 10^x and round both to the nearest integer, then do the compare.  (This also works for rounding to places left of the decimal place as well.  Just use negative values for x.)

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.
Message 5 of 6
(3,179 Views)

I have not checked in detail, but it is likely that these values are derived from a fixed-point or raw integer based on a limited amount of bits. It might be possible to do the comparisons on the raw value instead. Of course the question arises about the presence of noise and such. The data would need to be very clean to accurately measure 7 decimal digits accurately and I still believe that the data is quantized to a limited set of steps.

0 Kudos
Message 6 of 6
(3,152 Views)