LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Shift Register Not Working Properly

Solved!
Go to solution

Hello,

 

I am trying to ONLY keep numbers between specific boundaries from an array, in this example the 1D array is 300 long but in reality it is going to be around 100K data. I am doing something wrong and can't seem to figure it out. I would appreciate any kind of help, I am attaching my VI and the initial pic for easy understanding.

ex1.1.PNG

 

Cheers,

Diural 

Download All
0 Kudos
Message 1 of 14
(4,353 Views)
Solution
Accepted by Diural

Put probes in these places, turn on "highlight execution" and give the loop a few spins. I have a feeling that the probes will not contain the data that you believe they should.

LLindenbauer_0-1654166437396.png

 

It seems like you are trying to build a filter. I would recommend using a conditional indexing tunnel:

LLindenbauer_1-1654166731549.png

 

Message 2 of 14
(4,336 Views)

After the first true the shift register holds what value?

one possible solution?

select from array.png

 

and I'm shure altenbach will come up with a much smarter solution 😉 😄

 

EDIT: If you rigth click on the in range and coerce.vi , you can choose the bounderies to be included or not ... seems your code wanted to exclude them ...

Greetings from Germany
Henrik

LV since v3.1

“ground” is a convenient fantasy

'˙˙˙˙uıɐƃɐ lɐıp puɐ °06 ǝuoɥd ɹnoʎ uɹnʇ ǝsɐǝld 'ʎɹɐuıƃɐɯı sı pǝlɐıp ǝʌɐɥ noʎ ɹǝqɯnu ǝɥʇ'


Message 3 of 14
(4,334 Views)

@Henrik_Volkers wrote:

After the first true the shift register holds what value?

one possible solution?

select from array.png

 

and I'm shure altenbach will come up with a much smarter solution 😉 😄

 

EDIT: If you rigth click on the in range and coerce.vi , you can choose the bounderies to be included or not ... seems your code wanted to exclude them ...


Altenbach probably won't chime in since no complex numbers would be involved.  

 

UNLESS: he benchmarks migrating the In Range and Coerce in front of the for loop and / or enables loop parallelism to gain an extra warp speed factor.


"Should be" isn't "Is" -Jay
Message 4 of 14
(4,310 Views)

Thank you LLindenbauer and Henrik for the insight. I have done it thanks to you guys.

 

Cheers,

Diural

Message 5 of 14
(4,272 Views)

@JÞB wrote:
Altenbach probably won't chime in since no complex numbers would be involved.  

 


I often do range checks from the position of two cursors, so upper and lower limits can change places depending on use (I call them "limit A" and "Limit B" instead of upper/lower limit). This will make it more universal. Of course sometimes you do want an empty array as result if the upper <lower so handling need to be decided and documented, of course)

 

I am not sure if the range check can take advantage of SSE instructions, but if it does, taking it out of the loop might be a performance advantage (at the cost of having to allocate a boolean array, so things need to tested in detail 🙂 )

 

altenbach_0-1654182857142.png

 

 


I will chime in explaining some of the glaring mistakes and over-complications in the original VI. It is good to learn about proper use of shift registers and autoindexing, even if a particular problem does not even need them.

 

  • A shift register is one of the oldest and most well tested item in the LabVIEW toolbox. You can assume that it is always working properly and that the problem is elsewhere.
  • "Index array" wired to [i] is exactly the same as autoindexing. Once we do, we no longer need to measure the size and wire N, because in this case, the loop will know how many iterations are needed to process all elements (Care must be take if there are several autoindexing inputs, because the smallest will win).
  • There is no reason to index out the exact same element twice in a row. Once is enough!
  • Building an array from one element will give you a size=1 array and you are just replacing whatever is in the shift register with that tiny array. If you want to keep the earlier elements, you need to use "built array" to append as follows. Note that we start with an empty array. It is incorrect for this problem to initialize the shift register with the input array because after the first "in range" condition, you are indexing out an element that does not exist because there is only one element. (Here's what we often did before the conditional output tunnel was invented, see picture. Note that if the arrays gets large, more efficient methods are possible)
  •  altenbach_1-1654183459394.png
  • remember to "save for previous" to get a richer response. Many don't have LabVIEW 2021 yet.

 

 

 

 

0 Kudos
Message 6 of 14
(4,238 Views)

@JÞB wrote:

@Henrik_Volkers wrote:

After the first true the shift register holds what value?

one possible solution?

select from array.png

 

and I'm shure altenbach will come up with a much smarter solution 😉 😄

 

EDIT: If you rigth click on the in range and coerce.vi , you can choose the bounderies to be included or not ... seems your code wanted to exclude them ...


Altenbach probably won't chime in since no complex numbers would be involved.  

 

UNLESS: he benchmarks migrating the In Range and Coerce in front of the for loop and / or enables loop parallelism to gain an extra warp speed factor.


AND it fits on a postage stamp.

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 7 of 14
(4,220 Views)

@billko wrote:

@JÞB wrote:

@Henrik_Volkers wrote:

After the first true the shift register holds what value?

one possible solution?

select from array.png

 

and I'm shure altenbach will come up with a much smarter solution 😉 😄

 

EDIT: If you rigth click on the in range and coerce.vi , you can choose the bounderies to be included or not ... seems your code wanted to exclude them ...


Altenbach probably won't chime in since no complex numbers would be involved.  

 

UNLESS: he benchmarks migrating the In Range and Coerce in front of the for loop and / or enables loop parallelism to gain an extra warp speed factor.


AND it fits on a postage stamp.


And a benchmark is attached along with the test vis backsaved to 2019

 

Items seen on my Windows 10 laptop running on an Intel CORE i3 in the original 2021 CE (Now you understand why I prefer to post by phone)

  • Conditional terminal memory reallocation swamped the original results so, I selected limits and signal generation parameters to yield a sparse data size out and help differentiate the migration of the IR&C inside and outside of the For loop.  
  • The test vi "IRC inside.vi" completes faster than "IRC Outside.vi" by an observable factor.
  • Enabling and disabling loop parallelism does not have an observable effect with the conditional tunnel forcing the reordering of the array.

I imagine that a super optimized approach could be tailored if there are "things" known about the data set that cannot be known in a general solution.  For normal day to day use the amount of optimization effort would be unlikely to be beneficial.  


"Should be" isn't "Is" -Jay
Download All
0 Kudos
Message 8 of 14
(4,211 Views)

@JÞB wrote:
Enabling and disabling loop parallelism does not have an observable effect with the conditional tunnel forcing the reordering of the array.

Both codes speed up significantly when I disable parallelization on my PC.

 

Your "inside" solution truly falls apart if the ranges include all data (lower=-inf (or -20k), upper=inf (or 20k)), where it goes up to a few seconds (!!!!) on my PC. (This might be a compiler optimization problem!?)

 

OTOH, if we do a classic explicit solution (below), it is several orders of magnitude faster (~60ms) in that same case (i.e. all data retained).

 

Even for other limits (e.g. 100-200), this is faster (100ms vs 150ms). Same if the range is zero and the output empty (limit1 =limi2),  (90ms vs 140ms).

 

altenbach_1-1654194216986.png

 

I am sure things can be further optimized.

 

Tested in LabVIEW 2020SP1. YMMV of course!

 

 

 

0 Kudos
Message 9 of 14
(4,202 Views)

@altenbach wrote:

@JÞB wrote:
Enabling and disabling loop parallelism does not have an observable effect with the conditional tunnel forcing the reordering of the array.

Both codes speed up significantly when I disable parallelization on my PC.

That does not surprise me although I wouldn't dare guess if it is a better optimization in 2021 or if your machine simply outperforms this old clunker.    

 

Your "inside" solution truly falls apart if the ranges include all data (lower=-inf (or -20k), upper=inf (or 20k)), where it goes up to a few seconds (!!!!) on my PC. (This might be a compiler optimization problem!?)

A known issue with large arrays and conditional terminals requiring reallocation of the output buffer as the array grows.  The explicit solution provided in your reply would operate in place.

 

OTOH, if we do a classic explicit solution (below), it is several orders of magnitude faster (~60ms) in that same case (i.e. all data retained).

 

Even for other limits (e.g. 100-200), this is faster (100ms vs 150ms). Same if the range is zero and the output empty (limit1 =limi2),  (90ms vs 140ms).

 

altenbach_1-1654194216986.png

 

I am sure things can be further optimized.

Again, if anything is known about the data .... But, your finding here is suggestive of an alternate approach to the conditional tunnel implementation as currently released.  it certainly would be possible to pre-allocate an output array of size N, operate in place on that array with a hidden "FBN initialized to size N/Case and trim" on the conditional tunnel at the cost of some memory increase in sparse conditions. while the current implementation is "Case/Build Array with some advanced reallocation chunking" as I recall from conversations elsewhere after the original release wasn't performing super well.

 

Tested in LabVIEW 2020SP1. YMMV of course!

 

 

 


 


"Should be" isn't "Is" -Jay
0 Kudos
Message 10 of 14
(4,188 Views)