11-04-2015 11:43 AM
I need to analyze all of the pulses in a fast realtime process. For some reason the Pulse Measurements vi only returns a single specified pulse measurement. This means you have to iterate through all pulses (in my case hundreds). It seems that under the hood (a dll, too bad) it must be at least doing edge detect and search for the nth pulse so it is computing alot of the information for each pulse on its way to number n. I was hoping thst perhaps someone had figured out a way to do this type of analysis optimized to return ALL pulse measurements in a waveform.
11-04-2015 12:46 PM
I think you're trying to mix two different things. Your counter is a hardware triggered counter that doesn't give you the raw digital values, it just counts up for you can can achieve much higher sample rates than the other channel types. If you want the raw data, you need to configure a digital input task and read in the digital signal that way. You will be limited by your device's top sample rate.
Cheers
--------, Unofficial Forum Rules and Guidelines ,--------
'--- >The shortest distance between two nodes is a straight wire> ---'
11-04-2015 01:33 PM
I'm sorry I was refering to the Pulse Measurements.vi from the Signal Processing Palette.
11-04-2015 02:14 PM - edited 11-04-2015 02:14 PM
Oops, I misread.
What is the size of your dataset and how many pulses will it contain?
The more pulses the longer it takes. I can run this code with 10Hz pulses, 1kHz data, 100k datapoints in ~730ms.
If you can split the signal in to parallel loops, you can speed it up quite a bit, too.
Cheers
--------, Unofficial Forum Rules and Guidelines ,--------
'--- >The shortest distance between two nodes is a straight wire> ---'
11-04-2015 03:37 PM
Thanks for your reply. I will have 32 waveforms sampled at 100kHz for 1s. Each waveform will contain 500 pulses. I would like to be able to do this in real time but I am not even close. I am looking into the wavelet peak detection as well as the edge detection vi's from the jitter toolkit and b both are an order of mangitude faster than the pulse measurement vi.
11-05-2015 09:28 AM
100k samples of 100kHz data with 500Hz pulses is a lot of data. You're not going to get through that super fast and you can't dive in to the Pulse Measurements VI to get all pulses becuase it's a library call. The best optimization I can suggest is to use parallelism for your waveforms themselves. This takes about 2300ms with your data size:
Cheers
--------, Unofficial Forum Rules and Guidelines ,--------
'--- >The shortest distance between two nodes is a straight wire> ---'
11-05-2015 09:47 AM - edited 11-05-2015 09:47 AM
Crosspost where I posted a VI that I wrote for processing analog signals looking at all transitions.
Unofficial Forum Rules and Guidelines
Get going with G! - LabVIEW Wiki.
17 Part Blog on Automotive CAN bus. - Hooovahh - LabVIEW Overlord
11-05-2015 09:59 AM
Your VI doesn't give info about each pulse, but OP could adapt your code to fit his needs faster than the Pulse Meas VI maybe. The key is the conversion for analog to digital and then iterating through that data.
Cheers
--------, Unofficial Forum Rules and Guidelines ,--------
'--- >The shortest distance between two nodes is a straight wire> ---'
07-25-2018 05:12 AM