Counter/Timer

cancel
Showing results for 
Search instead for 
Did you mean: 

DAQmx Issue

I am trying to acquire values from a NI-PCIe card 6321 recognized as "Dev1" of two load cells encapsulated into one task over ai1 and ai5 and separate encoder tasks of two encoders as attached in a project. Now in order to acquire values from encoder tasks continuously i used PFI lines of input A as external sample clock for rising edge for the corresponding encoder tasks.

Now what's happening is that whenever I run my machine and acquire these values there are places in my tabulated data where no data or garbage data seems to be coming from my load cell and encoder. When I disable the encoder tasks, load cell tasks work properly. So, what could be the possible solutions that I am able to acquire values from all of them properly. I am new to using the encoder so pardon me if question looks silly. Following is the file in which all the details are attached:

0 Kudos
Message 1 of 6
(707 Views)

means it should be a hardware clock source which can be used by all tasks? Is this what you want to say?

0 Kudos
Message 2 of 6
(656 Views)

I am open to that solution where I can provide an internal clock source which can be commonly shared among all channels.

0 Kudos
Message 3 of 6
(655 Views)

The bad news is that there are quite a few problems or likely problems in the code you posted.

 

The (relatively) good news is that many of them are kinda small and/or subtle.  I don't have time to walk through a complete rebuild but here's a start:

 

1.  You've got 3 independent sample clocks going for your 3 tasks -- one from an internal constant-rate clock, two from your variable-rate encoders.  Though this isn't *always* the wrong thing to do, it doesn't seem like what you want.  See #2.

 

2.  When you read from your tasks, you aren't specifying the # samples to read, so the default is to read "whatever amount is presently available in the task buffer".   You are very likely to get different #'s of samples from each of the tasks due to the differing sample rates.  Thus when you combine all the arrays into a single 2D array, the smaller ones will get padded with 0 values to bring them to the same length as the longest one.

    Since you accumulate this data separately up at the Main.vi level, you should combine the 3 tasks' data by bundling into a cluster.  A cluster of arrays allows each array to have a different length and no padding will be done.  (Better yet, make a typedef of the cluster to give the various data fields names and then use "Bundle By Name").

 

3.  By reading "all available samples" each iteration, DAQmx will return almost instantly, causing you to iterate at a very high rate.

Probably the only thing slowing it down is the attempt to redraw the waveform graph every iteration with your constantly-growing shift register arrays.

     Add a wait timer to your main loop.  Make it at *least* 100 msec, but I'd probably start with 500 msec.  Your brain can't interpret and react to the graph display much quicker than that anyway.

    You could also stand to change the graph into a set of charts, one for each task since they have different sample rates and deliver different size chunks of data.

 

4.  Having data arrays of different sizes will affect your file writing too.  You shouldn't combine all the data into a single "Write Delimited Spreadsheet" call.  That would just bring back the problem with zero-padding the smaller arrays.

 

 

If what you *really* want is to share a common sample clock and rate among all 3 tasks, producing equal-length arrays, there's a different set of changes that are probably simpler overall.  I'll look for a chance to post again with some hints for that different approach.

 

 

-Kevin P

ALERT! LabVIEW's subscription-only policy came to an end (finally!). Unfortunately, pricing favors the captured and committed over new adopters -- so tread carefully.
0 Kudos
Message 4 of 6
(645 Views)

Using the signal itself as a clock signal is a bad idea. You want to use a known signal as the sample clock source.

 

You can refer to Synchronized Two Counter Input Tasks with Sample Clock Sharing Using LabVIEW with DAQmx to configure both encoder counter tasks to use the sample clock from the AI task.

-------------------------------------------------------
Applications Engineer | TME Systems
https://tmesystems.net/
Message 5 of 6
(642 Views)

ZYOng's link demonstrates much of what I intended to write up later.   Note however that the upper code snippet in that link is partially flawed in that the AI task gets cleared immediately after being started and no AI data is ever read.

 

I would make the following changes:

 

1. Make sure the Sample Clock Source is set to "/Dev1/ai/SampleClock".   (You may need to substitute your DAQ device's actual alias name for "Dev1")

 

2. Bring in a DAQmx Read for the AI task inside the loop, don't let the AI task be cleared until after the loop terminates.

 

3. Specify the # samples to read per iteration in the calls to DAQmx Read and then get rid of the 100 msec Wait timer.  DAQmx will pace your loop according to the # samples you request and the sample rate you configured.   I would again suggest specifying about 0.5 sec worth of samples

 

 

-Kevin P

ALERT! LabVIEW's subscription-only policy came to an end (finally!). Unfortunately, pricing favors the captured and committed over new adopters -- so tread carefully.
Message 6 of 6
(635 Views)