 artkop
		
			artkop
		
		
		
		
		
		
		
		
	
			08-07-2018 07:22 AM
I use the AWG NI PXI-5412 to generate sine wave signals of certain frequency and amplitude and change these parameters “on the fly”. I use Standard Function as the Output Mode and the Property Note to set new frequency and amplitude values.
Change of parameters is always followed by 15-30 ms delays during which I assume the parameters of an old waveform are cleared from the onboard memory of the AWG and the parameters of a new one are saved.
Is it possible to calculate the upcoming delay in ms based on the frequency and amplitude of new and old signals, onboard memory size and number of cycles stored in onboard memory? I have only found information on the memory usage of Arbitrary Waveform Generation Mode in specs. Am I generally right in thinking that delays are related to memory usage?
Solved! Go to Solution.
 kirsch
		
			kirsch
		
		
		
		
		
		
		
		
	
			08-07-2018 12:53 PM
@artkopIs it possible to calculate the upcoming delay in ms based on the frequency and amplitude of new and old signals, onboard memory size and number of cycles stored in onboard memory? I have only found information on the memory usage of Arbitrary Waveform Generation Mode in specs. Am I generally right in thinking that delays are related to memory usage?
You are indeed correct. The 5412 is an Arbitrary Waveform Generator and doesn't have DDS hardware. So Function Generation is implemented on top of Arbitrary Waveform Generation functionality.
There's no good way to calculate the delay, because unfortunately the timing is not deterministic.
As a workaround, you could use Script Mode, download full cycles of the waveforms at the frequencies you need, and switch between them using a script trigger using Send Software Trigger. This gets you contiguous performance but will only work if you know the frequencies you need ahead of time.
Good luck
08-08-2018 02:31 AM
Thank you for the reply, kirsch!
If Function Generation is implemented on top of Arbitrary Waveform Generation, then, according to specs, its Onboard Memory Size is by default 8 MB and Minimum Waveform Size must be 16 Samples, right?
So am I correct that, generally speaking, in Function Generation mode, an AWG fills the memory buffer with 16 (?) samples and then keeps sending signals based on these samples. When the parameters of a waveform are changed, it clears the buffer and fills it with new samples?
May I also ask you what other factors the delay is usually determined by?
 kirsch
		
			kirsch
		
		
		
		
		
		
		
		
	
			08-08-2018 09:43 AM
The implementation of Function Generation will create waveforms of one or more cycles and also change the Sample Rate in order to "best" accomplish the requested frequency. It tries to balance frequency accuracy with waveform size, and generate at the highest Sample Rate that makes sense. I don't recall the specifics nor are they simple.
@artkop So am I correct that, generally speaking, in Function Generation mode, an AWG fills the memory buffer with 16 (?) samples and then keeps sending signals based on these samples. When the parameters of a waveform are changed, it clears the buffer and fills it with new samples?
May I also ask you what other factors the delay is usually determined by?
08-09-2018 07:19 AM
Thank you for the explanation, kirsch!
Is possible to read the automatically configured Sample Rate with some VIs?
 kirsch
		
			kirsch
		
		
		
		
		
		
		
		
	
			08-09-2018 09:13 AM
Try reading the Sample Rate attribute (use the property node assuming you're using LabVIEW). I believe that will give you the value in use but I'm not 100% sure.
08-13-2018 02:23 AM
@kirsch wrote:
As a workaround, you could use Script Mode, download full cycles of the waveforms at the frequencies you need, and switch between them using a script trigger using Send Software Trigger. This gets you contiguous performance but will only work if you know the frequencies you need ahead of time.
Good luck
Hi kirsch,
I think Script Mode is not supported on my signal generator PXI-5412; I receive an error message “NIFGEN_VAL_OUTPUT_SCRIPT not supported on this signal generator”.
Is there any other way to download waveforms into the memory of the AWG and switch between them on the fly?
 kirsch
		
			kirsch
		
		
		
		
		
		
		
		
	
			08-13-2018 09:38 AM
08-14-2018 07:27 AM - edited 08-14-2018 07:30 AM
Thank you, kirsch
I have another question.
I have been also using the code provided by Aaron O to switch between various waveforms without stopping generation and experiencing any delay with PXI-5412:
My question is, is it possible to generate arbitrary waveforms of different frequency without stopping generation and clearing the memory, like in this code?
If I am not mistaken, the frequency of the output signal in Arbitrary Waveform mode equals the sample rate divided by the number of points in Waveform Data Array received by niFgen Create Waveform (poly) VI. Therefore, in order to change the frequency of the output signal, one has to change either the sample rate or the number of points in Waveform Data Array. However, after the very first waveform is downloaded to the AWG’s memory, all the next ones have to have the integer multiple of the number of points of the very first waveform. Which means that it is impossible to overwrite the first waveform with the new one that has a different frequency "on the fly". Am I correct?