 ocyj
		
			ocyj
		
		
		
		
		
		
		
		
	
			09-05-2017 04:13 AM - edited 09-05-2017 04:23 AM
Hello forum 
I have a setup where I use a NI USB-6218 to generate a low frequency sine-signal that is fed to a system of external transducers and then sampled on the same DAQ for further analysis. The general idea of the procedure is presented in the attached VI snippet.VI snippet
As you can see the size of the generated buffer and number of samples to be sampled is quite large. The AO.DataXferMech and AI.DataXferMech are both USB bulk in my actual application. The signals looks very good though and the results are looking promising so far!
Some questions I have:
I'm very grateful for your responses!
Best regards,
Oscar
EDIT: I messed up with the "attached VI snippet" 
Solved! Go to Solution.
09-06-2017 10:21 AM
Hi ocyj,
Could you confirm why you are using the "DataXferMech" functionality? DAQmx will handle the data transfer from LV to HW automatically.
The Data Transfer Mechanism has limited values depending on the hardware and sample mode. For example Programmed I/O is the only value supported when the Sample Mode is Hardware Timed Single Point and typically used in Software-timed (on-demand) operations.
09-12-2017 01:55 AM
Hello NIRebecca, thank you for your reply!
I only use the "DataXferMech" to read its value (to see what DAQmx happen to choose).
My concern in that the buffer size (the array of generated sample points) is many times larger than the on-board buffer, so I assume that a continuous stream of data to the physical device must take place?
It is crucial for my application that any glitches in the output signal (which is a simple sine-signal) are detected. So my main question should maybe be formulated as is there a fail-safe way to pick up if DAQmx has not been able to keep up with the data transfer?
/ocyj
 GerdW
		
			GerdW
		
		
		 
		
		
		
		
		
	
			09-12-2017 02:12 AM - edited 09-12-2017 02:12 AM
Hi ocyj,
It is crucial for my application that any glitches in the output signal (which is a simple sine-signal) are detected. So my main question should maybe be formulated as …
The main question here is: why did you choose an USB device then in the first place?
When such things are "crucial" you always can choose other devices and other bus systems (PCIe, PXI)…
09-12-2017 02:37 AM
Thank you for reply GerdW!
Are those bus systems typically not more expensive to acquire than the USB-base line? It's my understanding that one would still use the DAQmx interfaces when programming I/O-operations in LabVIEW. Are there specific functionality that makes detecting glitches easier with those systems, that are not available for USB-devices?
Like I said, the most crucial thing is detecting any problems in data transfer, so that any acquired data can be disregarded.
 GerdW
		
			GerdW
		
		
		 
		
		
		
		
		
	
			09-12-2017 02:50 AM
Hi ocyj,
Like I said, the most crucial thing is detecting any problems in data transfer, so that any acquired data can be disregarded.
No, you were asking something different:
It is crucial for my application that any glitches in the output signal (which is a simple sine-signal) are detected.
What exactly do you want to detect: "glitches" in a signal or problems with data transfer?
So my main question should maybe be formulated as is there a fail-safe way to pick up if DAQmx has not been able to keep up with the data transfer?
When there is a problem within the DAQmx driver you will get an error message…
Are those bus systems typically not more expensive to acquire than the USB-base line?
Often those PCI(e)/PXI devices are more expensive. (I forgot to mention the RIO line in my first post.)
But then those devices offer (sometimes) more possibilities than USB devices.
Conclusion: you should select your DAQ hardware according to your measurement requirements…
Are there specific functionality that makes detecting glitches easier with those systems, that are not available for USB-devices?
Again: which "glitches" do you want to detect?
09-12-2017 03:49 AM
Hi again GerdW, thanks for replying. I can see your point!
Naturally it would be preferable to detect any type of glitches, but to keep it practical, the most important factor to monitor for here are are discrepancies within the time domain (within the hardware's specified tolerance naturally), occurrences of types of buffer under/overflow etc. (Quantization errors and such will be tolerable as the 16-bit resolution of the USB-daq device is considered good enough).
You mentioned that the DAQmx driver will report error messages when problems occur, is there any approach that is considered good practice to check for specific errors as a mean to detect occurrences of buffer over/underflow (whenever the daq has not been able to "keep up" with the buffer array's samples so to speak!).
 GerdW
		
			GerdW
		
		
		 
		
		
		
		
		
	
			09-12-2017 04:16 AM - edited 09-12-2017 04:17 AM
Hi ocyj,
you can look up error numbers in the DAQmx help - or by playing with the error cluster (right-click to explain errors/warnings)…
This would be the easiest way to handle specific errors:
(The ClearErrors function in recent LabVIEW versions uses a very similar approach.)
 Kevin_Price
		
			Kevin_Price
		
		
		
		
		
		
		
		
	
			09-12-2017 11:26 AM
It can be hard to anticipate *all* the specific error #'s that *might* occur in the future. Just be forewarned that using an approach that depends on a specific match, it'll be hard to be confident that you've got all the right error conditions covered.
That said, you can at least recognize some easily-induced ones and provide some help text for those foreseeable errors. For example, you can probably induce underflow errors on your continuous AO task by defining an extra-small buffer. To force DAQmx to have a suspiciously small buffer, you'll need to set it up with a DAQmx Timing property node. (The regular DAQmx Timing.vi will calculate its own idea of a reasonable sized buffer based on your sample rate when you specify Continuous Sampling.)
Your AI task is Finite so it might be harder to induce errors. I'd set it up with the fastest possible sample rate, many seconds worth of buffer to fill, and then I'd do software-timed AO updates as fast as I could in a loop -- to keep the driver busy managing bi-directional bus traffic, and hopefully interrupting AI data transfer.
-Kevin P
09-15-2017 02:17 AM
Hi Kevin! Thank you very much for your valuable feedback! I will try your approaches to see when/how the system breaksdown.