LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Pt By Pt VI's memory

Hi there, I have a problem using Pt By Pt Vi's, I think I know the reason, but I'm looking for confirmation or even better a solution to the problem.

I need to do equal analysis on multiple sensor signals. The upper two branches take the signal from the DAQmx VI and analyse each signal individually.

That works fine 🙂

 

With the "for loop" below it doesn't work 😞

I think it has to do with memory used by the PtByPt vi's.

Each instance of those VI's has it's own memory allocated so that they don't interfere with each other, right?

Since using the "for loop" I have only 2 instances of the PtByPt vi's; data from multiple sensors get messed up 😞

 

In my application the number of sensors chanes all the time. It's always a multiple of three but today it may be 1 time 3 sensors, 3 analysis are needed; tommrow it's maybe 3 times 3 sensors, 9 analysis are needed.

 

I was thinking using loops and array to handle the varying number of sensors but the Pt By Pt vi's makes this impossible 😞

 

What's the best way to handle this?

 

Regards

Alain

0 Kudos
Message 1 of 11
(3,370 Views)

Hi Alain,

 

as you (correctly) noticed those PtByPt-VIs use their internal memory (usually a shift register) to hold previous values. When calling such a VI in a (FOR) loop with data of several sensors your results get messed up...

 

To avoid this:

- Separate the signals as you did in the upper part of your VI block diagram. This is not the best way when it comes to scalability and flexibility (as you already noted)...

- Make your own version of that function to handle "vectors" (aka 1D arrays) of data correctly. That way you have the same functionality as the PtByPt-VI and still the flexibility of using an array of sensors!

Best regards,
GerdW


using LV2016/2019/2021 on Win10/11+cRIO, TestStand2016/2019
0 Kudos
Message 2 of 11
(3,366 Views)

Most of your memory problems are not due to the ptbypt VIs, but your use of shift registers. Since they are uninitialized, they retain all old data between runs, and they will grow without any upper limit until you run out of memory. You can remove all these shift registers and simply use a chart for display. Set the history lenght to a useful size.

 

As for the ptbypt VIs, I agree with Gerd to write a version that handles 2D data directly (The code of the ptbypt VIs is visible, so it is easy to make your own sratting with the existing code). Alternatively, you could use a parallel FOR loop with N instances.

0 Kudos
Message 3 of 11
(3,357 Views)

Thanks for the answers !

I'm not quite sure what function I have to make my own: the both PtByPt vi's or ... ...?

 

The shift registers aren't initialized because this is just a test VI. But even after initializing them same behaviour as before 😞

 

 

What about reentrant VI's?

I made a sub VI with the 3 NI vi's (AC/DC estimator and derivative), made my new vi reentrant in the hope that for each loop a new instance with own memory would be created but that didn't fix the problem either. Option "Preallocate clone for each instance" selected. Did I forgot something ?!?

 

Download All
0 Kudos
Message 4 of 11
(3,350 Views)

Hi Alain,

 

using a reentrant VI in a loop doesn't create a new memory space for each call of that VI per iteration! It's still the very same instance of that VI!

Best regards,
GerdW


using LV2016/2019/2021 on Win10/11+cRIO, TestStand2016/2019
Message 5 of 11
(3,347 Views)

That is clear 🙂

 

Can you elaborate on the function I have to write because it's not clear to me how I should make something better that what NI did.

I'm not the LV expert here, NI should be 🙂

 

0 Kudos
Message 6 of 11
(3,344 Views)

Hi Alain,

 

while NI is the LV expert they still can't provide each and every function for any task someone might ask for...

 

They already have introduced PtByPt functions, where you can look at the BD to examine their programming schemes.

When you need the same function for a 1D array of values instead of a scalar value you can copy their BD and adapt it in any way you need.

That task is called "programming"! 🙂

Best regards,
GerdW


using LV2016/2019/2021 on Win10/11+cRIO, TestStand2016/2019
0 Kudos
Message 7 of 11
(3,326 Views)

Alain,

 

Recently I found a niffty way of making these things more scalable that I think will work for you.

 

In LabVIEW 2009, NI introduced the ability to parallelize For Loops.  This was intended to be a performance boost, but it also allows us to scale parallel operations easily.  For example, I was recently testing this feature out and using it to open 20 dialog boxes (or however many I chose) at the same time with just one subVI and a parallelized For Loop.  Because all of the loop iterations ran in parallel, all 20 were opened at the same time and the loop did not exit until all 20 were closed.

 

For your code, I believe this behavior will cause different instances to be created in memory, just as if you'd laid out multiple subVIs on the BD.

 

To use this feature you need to do 2 things. 1) right-click on the For Loop and select Configure Iteration Parallelism...  In that window, make sure to enable up to 64 (the max) parallel iterations to give you the maximum scalability.

 

Loop_parallel_config.png 

 

The get the size of your waveform array and wire the output to the P terminal of your for loop.

 

parallel.png

LabVIEW will use the minimum of the number in the configuration window and the number wired to the P terminal.

 

I'm not certain this will work for you, but it should be easy to try!

Chris
Certified LabVIEW Architect
Certified TestStand Architect
0 Kudos
Message 8 of 11
(3,293 Views)

@PackersFan wrote:

Recently I found a niffty way of making these things more scalable that I think will work for you.


That's why I wrote "Alternatively, you could use a parallel FOR loop with N instances" above. 🙂


@PackersFan wrote:

...  In that window, make sure to enable up to 64 (the max) parallel iterations to give you the maximum scalability.

 


The max can actually be raised with an INI enty if needed.

 

0 Kudos
Message 9 of 11
(3,287 Views)

That's what I get for skimming posts! Smiley Frustrated

 

Nice tidbit about the INI token.  That was the one limitation of this technique that worried me. Whoo!  Smiley Very Happy

Chris
Certified LabVIEW Architect
Certified TestStand Architect
0 Kudos
Message 10 of 11
(3,285 Views)