04-18-2024 08:42 PM
Hi all,
I am attempting to build a trigger input application for the external device as per the spec sheet attached...
The application I built outputs X number of square wave pulses between 0 and 3.5 V at X frequency as specified by the user control inputs... This has worked fine in the past when triggering at 50 Hz or 100 Hz...
I now need to use frequencies of 20 Hz and 80 Hz... However, at those frequencies the pulse widths are inconsistent for some pulses within each train...
It appears to have something to do with the square wave duty cycle% for the functional generator, but I cannot identify what specifically the problem is...
Would anyone have any ideas?
Thanks...
Solved! Go to Solution.
04-19-2024 01:05 AM
Hi Jack,
@jcannon wrote:
I now need to use frequencies of 20 Hz and 80 Hz... However, at those frequencies the pulse widths are inconsistent for some pulses within each train...
It appears to have something to do with the square wave duty cycle% for the functional generator, but I cannot identify what specifically the problem is...
Seems like rounding errors when you need 8% duty cylce at 12.5ms pulse interval for a waveform with a dt of 1.0ms…
04-19-2024 08:27 AM
Hi GerdW,
Thanks for your feedback... I thought a rounding error may have been the issue but wasn't sure how to fix it...
I have revised the vi by removing the square waveform generator and replacing it with a for-loop that builds an array of data to be written using 3.5 and 0 values as needed. A shift register builds an array based on the number of pulses necessary in the AO...
To remove the rounding error with the 12.5ms inter-pulse-interval, I have used a 2000Hz time base (25 data points per pulse with a width of 1ms or 2 datapoints)... In the attached vi I have plotted the data in a graph and presented it in anarray indicator... However, the graph appears to be missing the first 3.5 value data point in the array, which means that the timing of all subsequent pulses occur 0.5ms too early on the graph... But the timing of the values in the array indicator is correct...
Any idea why this might be happening? I assume the AO will write the values in the array and will be correct... But I am obviously missing something with plotting the data to the graph...
Any ideas?
04-19-2024 08:47 AM
I don't see the problem here. The first 3 values in the graph are 3.5, 3.5, 0 just like in the array. Were you just visually misinterpreting because of the absence of a preceding 0 value, such that the initial pulse would start at 3.5 rather than rising from 0?
-Kevin P
04-19-2024 08:52 AM
Ahhh!... Thanks, Kevin... Much appreciated...