LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Why does indicator show uninitialized array?

Solved!
Go to solution

Here is the Main.vi for my Real-Time Model Module in DQMH. This is running on a PXIe-8861 using NI RT OS.

dakotasmith2_0-1733846314853.pngdakotasmith2_1-1733846330264.png

 

In the INIT MODEL subVI I am initializing an array that should be a length 4 and all zeros. The size of those two channels are currently both 2 which is hardcoded inside the Settings DQMH module.

dakotasmith2_2-1733846445591.png

The array indicator here always shows this after it gets initialized

dakotasmith2_3-1733846580643.png

This is the EXECUTE MODEL subVI where in the READ FROM AI subVI I'm building the array from the INIT MODEL with the data read from the AI card. Here number of rows and counter refer to iterating through another array which was populated from reading a csv and works fine. The enabled part of the diagram disabled structures are just the tunnels wired straight across.

dakotasmith2_4-1733846726910.png

Here is the READ FROM AI subVI where the first part of the array is being populated with the data read from the AI card.

dakotasmith2_5-1733846812986.png

While the EXECUTE MODEL timed loop from the Main.vi is running, the values inside the AI and Bridge Input Raw indicator seems to be correct and nonzero. 

dakotasmith2_7-1733846948933.png

After the EXECUTE MODEL timed loop finishes its execution, the same indicator now shows an uninitialized array. Why does this happen?

dakotasmith2_8-1733846994841.png

 

 

0 Kudos
Message 1 of 10
(1,387 Views)

Hi dakota,

 

Most people responding on the forum don't have the last version of LabVIEW installed (here 24.0), so please attach your VIs saved for a previous version (preferred 21.0). To do that, go to File > Save for Previous Version... > 21.0 on your main VI.

 

Just by looking at the screenshots, I would say maybe your Model Data is cleared in the "Enabled" cases of your Diagram Disable Structures (DDS):

 

raphschru_1-1733850567666.png

 

When you wrap code within a DDS, the wires are reset to their default value, so you have to manually add wires to make your data pass through.

 

Regards,

Raphaël.

0 Kudos
Message 2 of 10
(1,358 Views)

Hi Raphaël,

 

I believe I have saved them in version 21.0 like you asked. Also, for the DDS Enabled I have just wired the tunnels straight across so I don't believe they should be receiving default values.

dakotasmith2_0-1733852207780.png


As for versioning, should I save all my code in 21.0 to allow for the most compatibility for everyone on the forum?

Thanks,
Dakota

0 Kudos
Message 3 of 10
(1,345 Views)

@dakotasmith2 wrote:

As for versioning, should I save all my code in 21.0 to allow for the most compatibility for everyone on the forum?

Thanks,
Dakota


I personally recommend 2019 for the version to pick.  I am on 2021, but I know some contributing forum dwellers are still on 2020 or 2019.

 

There are very few features that were in 2021 but not 2019 (Interface classes are the only big one I can think of) so there's a very small chance that the extra two versions of backsaving will cause problems.  

Message 4 of 10
(1,338 Views)

@Kyle97330 wrote:

@dakotasmith2 wrote:

As for versioning, should I save all my code in 21.0 to allow for the most compatibility for everyone on the forum?

Thanks,
Dakota


I personally recommend 2019 for the version to pick.  I am on 2021, but I know some contributing forum dwellers are still on 2020 or 2019.

 

There are very few features that were in 2021 but not 2019 (Interface classes are the only big one I can think of) so there's a very small chance that the extra two versions of backsaving will cause problems.  


Concatenating strings through tunnels didn't become available until 2021:

paul_a_cardinale_0-1733865341998.png

0 Kudos
Message 5 of 10
(1,306 Views)
Solution
Accepted by dakotasmith2

Hi again,

 

This is because your output indicators in your subVI do not receive any value when the stop condition occurs, so they are set to the data type's default value (empty array):

 

"Normal" case:

raphschru_1-1734038113395.png

"Stopping" case:

raphschru_2-1734038192031.png

 

Note: This is generally considered a bad practice to put control/indicator terminals assigned to the connector pane inside structures, as it can impact performance and, as you've seen, impact functionality as well. So this is better to put them in the top-level diagram of your subVI instead.

 

Here's a thread I found explaining why that may be a problem for performance when input control terminals are put inside a structure:

https://forums.ni.com/t5/LabVIEW/case-structure-parameter-efficiency/td-p/382516

 

I haven't found anything concerning output indicator terminals though, but the problem is really simple to demonstrate:

 

Running:

raphschru_7-1734040350777.png

 

After stop:

raphschru_0-1734041049561.png

 

Regards,

Raphaël.

Message 6 of 10
(1,221 Views)

Hi Raphaël,

Thank you for the response and detailed explanation! I guess I was incorrectly assuming that if the indicators are in the True case then when the False case runs, that part (True case) of the code wouldn't execute and therefore would just have the same value as before. 

This program is being built for a PXIe-8861 and I can't run it locally on my dev machine to see the block diagram and probe for values so that is why I put the indicators in the case structure. How can I probe for those same values? If I were to bring those indicators outside the case structure I'd either have to wire the tunnel out to use default if unwired or some other value than it is currently. 

dakotasmith2_0-1734042840042.png

dakotasmith2_1-1734042864048.png


Or is there some other way to probe these values? I'm basically wanting to have some "print" statement of all the values that get passed to that indicator. 


Thanks,
Dakota

0 Kudos
Message 7 of 10
(1,200 Views)
@dakotasmith2 wrote:

This program is being built for a PXIe-8861 and I can't run it locally on my dev machine to see the block diagram and probe for values


In the development environment, you can deploy and run your VIs on your RT target and access the front panels and block diagrams of your subVIs for debugging while they are running on the target... unless they are reentrant, which by limitation of LabVIEW RT, are effectively not debuggable. You can still temporarily turn them non-reentrant for debugging purpose.

0 Kudos
Message 8 of 10
(1,191 Views)

In the False case, the READ FROM AI subVI is present and should run when the False case is executed. This would result in an array with data in it. In the True case, the READ FROM AI subVI is not present. So is that VI still running even though it's not shown in the True case. If so, why?

0 Kudos
Message 9 of 10
(496 Views)

I am not sure I understand your question.

 

When a top-level VI is running, all its subVIs turn in "Run Mode", in the sense that they are reserved for the running application, making them not editable.

 

But being in run mode is not the same as being called. The subVIs are only called when their parent diagram is executing (e.g. for a Case Structure, when the value provided to the case selector matches the corresponding case value), and all their inputs are available (dataflow paradigm).

0 Kudos
Message 10 of 10
(357 Views)