LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

read and write data to NI USB-6216 (BNC) above 2kHz rate

Dear all,

I would like to use NI USB-6216 (BNC) to simultaneously read and write data to specific channels.For this, I created two (or more) while loops for acquisition of analogue inputs and generation of digital/analogue outputs.However, when when multiple while loops run in one vi the rate of data acquisition on the analogue input channels (and data generation on the output channels) is limited.

Initially I set the sample clock function to "Sample Mode"- Continuous, "Rate" 2000, "Samples per channel" 200. As I understand, the DAQ board should acquire and gemnerate data at the rate 2k, data transfered in a package of 200 samples. Hence, each iteration (time of the while loop) should be max 100ms to keep the rate 2000 Hz. The Specs for the NI USB-6216 (BNC) looks good - 250kS/s per channel, so I am far from the limit.

 

However , when I look at the elapsed time for every loop, it often takes longer: "analogue Input" while loop has elapsed time ~100ms, digital output while loop is slower 150-180 ms, sometimes above 200ms.

 

I tried parallel/sequential structuring of channels, delays are similar and way too large.

Also, on the right hand-side of the figure you can see how much data are delayed (space between white bars-recorded data) :

Yaro42_0-1702037407019.png

 

 

I have also attached the example vi. Does anyone have an idea of how to improve timing?

 

Thank you!

0 Kudos
Message 1 of 7
(1,538 Views)

I cannot view your VI, which is developed in LabVIEW 2017, with either LabVIEW 2019 or LabVIEW 2021 (which should be able to view it).  The Front Panel is close to 60000x1080 pixels in size (meaning it would take three nice monitors side-by-side to view the entire Front Panel!), and when I open the Block Diagram, I can't even get the Navigation Window to show me the entire screen (and I have to close LabVIEW)!

 

From the little bit that I was able to see, you seem to have two loops acquiring data, each doing 1 channel and multiple samples (I was unable to scroll and get the particulars), but let's say 1 channel x 1000 samples, done in two parallel loops.  Can't your AO do two channels?  If so, let the "hardware" do the "hard" work.

 

Bob Schor

 

P.S. -- Navigation View "unlocked" while I was writing the above.  Your block diagram is only 5 screens wide by three screens tall.  When I learned LabVIEW, I learned about LabVIEW "Style" from Peter Blume's "The LabVIEW Style Book", and now 95% of my LabVIEW code fits on a single laptop screen (admittedly larger now than when I started with LabVIEW!).  The secret is Sub-VIs, every one with a unique Icon (if only 2-3 lines of short text).

 

I've not used the 6216, but I looked at its manual and I think it is capable of 2-channel D/A output ...

 

BS

0 Kudos
Message 2 of 7
(1,507 Views)

It is still above 100ms even if I keep one analogue output while loop to run. My intial question: for 250kS/s per channel the speed I am trying to record should be far away from any limit.

By the way, I have not seen a lot of simultaneous "read ai and write ao" to DAQ example vi out there. Could anyone point out such examples?

0 Kudos
Message 3 of 7
(1,488 Views)

Hi,

 

when I open your VI then the block diagram has a size of ~4800*3000 pixels, still a bit too large IMHO…

 

You really need to cleanup that VI before we can start a good analysis!

 

  • Why are there so many sequence frames?
  • Why do you convert a nice array of waveforms into several DDT wires???
  • Why do you read "-1" samples from your AI channels? Why don't you set a reasonable number of samples? Typically we recommend 1/10 of the samplerate here…
  • Why are there so many tab containers WITHOUT a label? NEVER delete the label of frontpanel elements!!!
Best regards,
GerdW


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

Hi,

 

1. There are only 3 frames in the sequence: 1. initialize , 2. read/write data (while loops) and 3. close

 

2. It is done to work with each analogue input separately, that is plot it, extract amplitude at a specific carrier frequency, plot the result. These computations are not problematic , as this loop runs fast 5-10ms (100ms if I constrain and time it).

 

3. Why do you read "-1" samples from your AI channels: number of samples per channel specifies the number of samples to read. If you leave this input unwired or set it to -1, NI-DAQmx determines how many samples to read based on if the task acquires samples continuously or acquires a finite number of samples.

 

 

 

0 Kudos
Message 5 of 7
(1,472 Views)

Hi Yaro,

 


@Yaro42 wrote:

Hi,

 

1. There are only 3 frames in the sequence: 1. initialize , 2. read/write data (while loops) and 3. close

 

2. It is done to work with each analogue input separately, that is plot it, extract amplitude at a specific carrier frequency, plot the result. These computations are not problematic , as this loop runs fast 5-10ms (100ms if I constrain and time it).

 

3. Why do you read "-1" samples from your AI channels: number of samples per channel specifies the number of samples to read. If you leave this input unwired or set it to -1, NI-DAQmx determines how many samples to read based on if the task acquires samples continuously or acquires a finite number of samples.


  1. Usually you don't need any frames at all! When you want to implement a statemachine then you should implement a real statemachine!
  2. Usually you should NOT use DDT wires for no good reason. Why don't you use IndexArray when you want to access the elements of an array???
  3. I recommend to set a fixed number of samples, typically 1/10th of the sample rate. Did I mention that before?
Best regards,
GerdW


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

Maybe I can follow up later, but here are a few quick thoughts.   Warning -- it may be a bit of a long road ahead of you, if I'm right in guessing roughly where you're headed.

 

1. Your AI task calls DAQmx Timing to set up a 2000 Hz sample clock.  The 200 value you wire there to 'samples per channel' does not mean what you think it means.  For a Continuous Sampling task, it often doesn't mean anything at all.  (Technically, you're setting a lower limit on the buffer size, but DAQmx will be choosing something large enough to be more suitable if it thinks your # is too small).

 

2. Your AO tasks do NOT call DAQmx Timing at all, putting them in software-timed "on-demand" sampling mode.  Here are 2 of the implications:

 

  • You're *allowed* to interact with those 2 channels separately in 2 distinct simultaneous tasks.  (This would NOT be allowed if you set up hardware-based sample timing because there's only one "timing engine" available for AO.)
  •  You have no buffer for data acquisition, so you incur significant overhead with every individual sample you write.  This very drastically limits your top update rate and because timing is controlled by software, you also get a very irregular update rate.

3. Faster AO demands that you use a hardware clock for timing, at which point you must also put both AO channels into 1 common task. 

 

4. Odds are you want the AO and AI to be correlated in some manner, bringing in some further considerations to get them into hardware sync.

 

5. Once you get involved with hardware timing, you *also* get involved with buffering and latency.  Since your code shows signs of wanting to change AO outputs as a function of user inputs, well, then you'll have "another hill to climb" to start getting into detailed tradeoffs concerning update rate, buffer size, latency. 

 

Sorry it's mostly bad news, just trying to let you know from the outset that there's probably gonna be quite a bit you need to learn and that's gonna take some time...

 

 

-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 7 of 7
(1,382 Views)