LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Shift Register Alternative

Solved!
Go to solution

Hello,

 

I am trying to have my program continuously store the last several minutes of data my sensor collects and run a computation to see if a certain fraction of it is over a threshold. From what I know, I could store the values in shift registers, but I am storing over a hundred thousand values and that is going to get to clunky on my block diagram and was wondering what better ways there were to store these values.

 

Thank you for your time.

0 Kudos
Message 1 of 13
(6,199 Views)
What sort of problem do you foresee? There would only be a single shift register! You need to take some of the free tutorials to get a better understanding of LabVIEW basics, especially arrays.
0 Kudos
Message 2 of 13
(6,189 Views)

I would store all of the data in a binary file.  But I would also process the data on the fly so that I would not need all of those data points in memory.  It sounds like you just need # points above a threshold and the # of points acquired.  So that would be 2 shift registers.


GCentral
There are only two ways to tell somebody thanks: Kudos and Marked Solutions
Unofficial Forum Rules and Guidelines
"Not that we are sufficient in ourselves to claim anything as coming from us, but our sufficiency is from God" - 2 Corinthians 3:5
0 Kudos
Message 3 of 13
(6,181 Views)

@Dennis_Knutson

 

When they do it in the tutorial they extend the left shift register to five elements to record the last five values, so if I have to drag the shift register out 100000+ values I'm worried it'll be way to big and clunky on the block diagram to work with. I'm also not sure how I would count out that I have the exact number of blocks other than doing it slowly and counting them out as I drag the shift register out.

0 Kudos
Message 4 of 13
(6,175 Views)

@endlessOranges wrote:

@Dennis_Knutson

 

When they do it in the tutorial they extend the left shift register to five elements to record the last five values, so if I have to drag the shift register out 100000+ values I'm worried it'll be way to big and clunky on the block diagram to work with. I'm also not sure how I would count out that I have the exact number of blocks other than doing it slowly and counting them out as I drag the shift register out.


The alternative to that would be to store an array of values in the shift register.  But that can get really slow if you are constantly building an array.

 


GCentral
There are only two ways to tell somebody thanks: Kudos and Marked Solutions
Unofficial Forum Rules and Guidelines
"Not that we are sufficient in ourselves to claim anything as coming from us, but our sufficiency is from God" - 2 Corinthians 3:5
0 Kudos
Message 5 of 13
(6,168 Views)

@crossrulz wrote:

It sounds like you just need # points above a threshold and the # of points acquired.  So that would be 2 shift registers.


I agree, all you need is two scalar shift registers for the two counts. Increment whenever new data arrives. Do you need to do anything else with the raw data?

 

A few hundred thousand points is not that much and can easily be handled by any modern computer. You have several orders of magnitude more ram!! In any case, if you need to store all data, a shift regsiter with an array of constant size is one of the most efficient data structures and, if done right, operates in-place. Do you know the final number of points before the acquisition starts? Nothing clunky about it. 😄

 

 

Message 6 of 13
(6,156 Views)

Data Queue Pt by Pt.  Would also be a good choice (Basically Christian's idea implemented well)


"Should be" isn't "Is" -Jay
Message 7 of 13
(6,147 Views)
The array size can be pre-allocated and you would use replace array element. How many data points are you acquiring at a time?
0 Kudos
Message 8 of 13
(6,139 Views)

The sensor should be taking samples at a 1 kHz frequency and I want to store the last 593287 values. I'm looking into arrays storing the values into the shift register but I'm again fairly new with programming in this and struggling to find a way that doesn't also involve manually dragging out a lot of boxes to specify each index in the array to store values into.

0 Kudos
Message 9 of 13
(6,123 Views)
Solution
Accepted by endlessOranges

@endlessOranges wrote:

The sensor should be taking samples at a 1 kHz frequency and I want to store the last 593287 values. I'm looking into arrays storing the values into the shift register but I'm again fairly new with programming in this and struggling to find a way that doesn't also involve manually dragging out a lot of boxes to specify each index in the array to store values into.


Just use the Data Queue PtByPt function.  It does all you want.


GCentral
There are only two ways to tell somebody thanks: Kudos and Marked Solutions
Unofficial Forum Rules and Guidelines
"Not that we are sufficient in ourselves to claim anything as coming from us, but our sufficiency is from God" - 2 Corinthians 3:5
Message 10 of 13
(6,106 Views)