06-28-2023 02:05 PM
Hello,
I am working on repurposing an older project we use and came across a FIFO stream with a bunch of FXPs built into an array. Is there a scheme for the data type coercion in this case? It seems like it is just coercing the array type to the largest data type (FXP 64,45 in this case) and that holds true when you remove the larger variables, but remove the second largest (64,25) and the output data type remains the same while coercing the rest of the data.
Is it better practice to just coerce them manually prior to the array?
The initial project was made in LabVIEW 2014, the new one is 2023.
Thanks for any insight you can provide.
Solved! Go to Solution.
06-29-2023 01:22 PM
Hi PD,
@PDbnl wrote:
a bunch of FXPs built into an array. Is there a scheme for the data type coercion in this case? It seems like it is just coercing the array type to the largest data type (FXP 64,45 in this case) and that holds true when you remove the larger variables, but remove the second largest (64,25) and the output data type remains the same while coercing the rest of the data.
The general rule will be to coerce to the largest FXP datatype so you don't lose any data…
@PDbnl wrote:
Is it better practice to just coerce them manually prior to the array?
The better practice is to define a suitable (FXP) datatype right from the beginning (aka when creating those "variables") instead of any explicit/implicit coercion later on!
(On FPGA you might use memory items/blocks instead of a lot local variables…)
06-29-2023 02:19 PM
Hi PD,
one small correction/idea to my last message:
The coercion might use a FXP datatype that is able to hold ALL/MOST data of the source FXP values. (Example: FXP6.4 and FXP7.3 might coerce to FXP8.4.)
You can easily test that with a simple VI…
06-30-2023 07:12 AM
That makes a lot of sense actually, it explains why the data type remained at 64.25 after I removed the 64.25 variable. Thanks for the insight!