LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

18 timers

Hello all,

 

I have an application in which I need multiple timers.

 

There are 18 digital inputs (may go up to 24 in future). Each digital pin can give a pulse at any moment of time. Each pulse is treated as cycle finish. I want to measure the time difference between the current pulse and the previous pulse on the same digital pin and plot it on a graph.

All the 18 pins can receive pulse at any time. Time accuracy required is around 100-200 ms.

 

Following are the things I was thinking to use:

1. Multiple timers in 1 while loop.

2. Generating a different file for different inputs, storing the time of previous pulse and then using it to subtract when the new pulse occurs.

I am not sure which one is the best way to program. Or if there is any other better way, suggestions are most welcome.

 

Also is there any way to have multiple x axis for the same graph/chart?

 

Thanks in advance.

0 Kudos
Message 1 of 9
(4,769 Views)

You don't need multiple timers, and you certainly don't want to save data to a file.

 

Create a functional global variable that stores an array of time values, 18 elements, each corresponds to an input.  When a digital input turns true, grab the time and call the FGV feeding in the channel number and the time.  The FGV will update the corresponding element of the array and return the difference between the new time and the old time.

 

Maybe it should store the previoius time value and the new time value so you can always have the difference between the last two, but also hold the last time stamp.  When it is updated, the most recent moves to the old spot, and the new time stamp goes in the new timestamp slot.

0 Kudos
Message 2 of 9
(4,751 Views)

RavensFan wrote:  When a digital input turns true, grab the time and call the FGV feeding in the channel number and the time.  The FGV will update the corresponding element of the array and return the difference between the new time and the old time.

My thought it is just pass the digital values (I assume an array of boolean) into the FGV and let it do all of the work (get curent time, go through each value and see if the value changed, update whatever time values needed, etc).  Since we are using arrays and FOR loops inside of the FGV, it is very expandable.


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 9
(4,707 Views)

@crossrulz wrote:

RavensFan wrote:  When a digital input turns true, grab the time and call the FGV feeding in the channel number and the time.  The FGV will update the corresponding element of the array and return the difference between the new time and the old time.

My thought it is just pass the digital values (I assume an array of boolean) into the FGV and let it do all of the work (get curent time, go through each value and see if the value changed, update whatever time values needed, etc).  Since we are using arrays and FOR loops inside of the FGV, it is very expandable.


That should work also.  I think the difference between yours and mine is that I was thinking more of an event driven situation,  (Hey, input #X just changed, do something) and yours would be for a polling type situation  (Let's check on all inputs at once and do something.)

0 Kudos
Message 4 of 9
(4,688 Views)

Thanks guys, I will certainly try it out.

 

Meanwhile, I will be needing 36 D I/O's for this particular timer vi to reset timers.

I was thinking of using 2 NI USB 6501. I will be accessing these 2 devices simultaneously. 

Is there any care I need to take so that the functionality of above methods don't get affected?

 

Thanks!

0 Kudos
Message 5 of 9
(4,643 Views)

Personally, I would use a 6509 (96 DIO lines!).  Then you can read everything with a single task.  Otherwise, I don't see any issues.


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 6 of 9
(4,633 Views)

Hello,

 

I tried implementing the FGV. But it seems, the value in my indicator is 1 iteration behind to that of the source.

Now I do not understand how to avoid it or if I am going wrong somewhere with the code.

 

I am attaching my code with this post.

 

Thanks

Download All
0 Kudos
Message 7 of 9
(4,578 Views)

Hi rk,

 

it seems, the value in my indicator is 1 iteration behind to that of the source.

How do you know it's exactly 1 iteration? There is NO timing in your example VI…

And yes: your consumer cannot read the latest value not at the very same time the producer is writing it into the FGV.

 

One loop writes new data as fast as possible into the FGV, the other reads as fast as possible. You don't know which one of the loops is executing currently nor the order. It might be possible both loops iterate alternately - atleast one loop will block the other because of the non-reentrant FGV!

 

What's your goal here? All your FGV does is providing a buffer for a value with NO timing or history involved: you might use notifiers for the same task.

When you need to make sure your consumer receives ALL values from producer you should use a queue instead…

Best regards,
GerdW


using LV2016/2019/2021 on Win10/11+cRIO, TestStand2016/2019
0 Kudos
Message 8 of 9
(4,566 Views)

Thank you GerdW for clarifying my doubt.

 

I will try to implement things you said.

 

Regards,

0 Kudos
Message 9 of 9
(4,544 Views)