Auto-suggest helps you quickly narrow down your search results by suggesting possible matches as you type.
Showing results for Search instead for Did you mean:01-24-2012 01:13 PM
I am writing a simple program which would collect data from a triaxial accelerometer input, convert it to a frequency spectrum, and then save the time domain and frequency waveforms to a separate external file. I don't quite understand how to set the sampling rate, though. On the DAQ Assistant, I set the acquisition mode to "Continuous Samples" and the samples to read is 2k, which is the total number of data points that are collected. How do I program it collect samples for a certain length of time, 30 seconds, for instance? Would it be better to set up a trigger, such that it will continue to collect data until I tell it to stop?
I would also like to save the waveform data to a separate file which could be easily viewed by other computers that would not have Labview installed. I currently have the program set up to convert the time domain waveform to a text string and then save it to a text file or spreadsheet. This works fine, but I also would like to save the frequency waveform, which is a different data type. How do I do this or is there a better way?
My program is attached. Thanks for your help!
Message 1 of 7 (11,651 Views)01-25-2012 04:36 PM
In Continuous Samples acquisition mode the Samples to Read actually specifies the size of the memory buffer. In your program, the buffer size is set to 2k samples and you are reading at 20k. This means you need to read the entire buffer at least every 100 ms in order for previously taken data not to be overwritten. With the DAQ Assistant VI the DAQmx Acceleration Task is created, ran, and destroyed every iteration of the while loop, which drastically slows down you program. You will be much better using the DAQmx functions provided in the LabVIEW functions palette in Measurement I/O>>NI-DAQmx. A great example to get you started is in Help>>Find Examples>>Instrument Input and Output>>DAQmx>>Analog Measurements>>Acceleration>>Cont Acq Accel Samples-Int Clk-Analog Start.vi. In your case you will need three input channels and probably not the analog start trigger. Here you can use an Elapsed Time VI wired to the stop terminal to run the acquisition for any amount of time you would like.
As far as writing the frequency domain data to a file along with the waveform data, this will be a bit more tricky. I would continue to write waveform data as you are, then append the frequency data to the file afterwards. The frequency data can be appended by converting the cluster to a 2d array and writing it with the write to spreadsheet.vi.
I hope this helps!
Message 2 of 7 (11,631 Views)01-27-2012 12:53 PM
Thanks very much. Your advice was a tremendous help. One thing I'm having trouble understanding, though, is timing the loop execution rate with the sampling rate. I programmed the sample clock to collect continuous samples and I'm using a "Wait until next ms Multiple" VI to control the while loop. If I set the sampling rate to collect 1000 S/s and set the loop to execute every 100 ms, then I should get 100 samples, roughly, every second. This is what is being recorded in my external file. What I don't understand is that I have the program running for 10 seconds, which is indicated by the Elapsed Time VI. So shouldn't the total number of samples be 10x what is being recorded?
Also, I seem to be getting an error message with the FFT spectrum vi whenever I run the program more than once without changing any parameters. The error reads:
Warning 1905 occurred at SVT FFT Spectrum (Mag-Phase) (N Ch).vi:1
Sound and Vibration Toolset: VI automatically was reset because number of samples in the input signal changed.
I'm guessing the samples are saved each time the program is run and it doesn't like having to change them each additional time I run it. Is this hurting anthing? How can I fix this?
My revised program is attached. Thanks again for your help.
Message 3 of 7 (11,616 Views)01-30-2012 04:54 PM
Your program looks very good, but there is one mistake that is only allowing a small part of your data to be written to the output file. If you are collecting at a rate of 1000 S/s and your while loop is running every 100 ms, you will obtain roughly 100 samples per iteration of your while loop. This means that you will get roughly 1000 S in one second and 10,000 samples in 10 seconds. The reason you are only seeing 100 points per channel written to the output file is because the export waveform to spreadsheet file.vi is located outside of the while loop. Since LabVIEW will only take data from the while loop tunnel after it is completely done executing, you are only getting one iteration's worth of data to be output. This can be fixed easily by one of two ways:
1. Move the export waveform to spreadsheet.vi inside of the while loop so it writes data to file every iteration.
2. Right click the loop tunnel and choose replace with shift register. Drop the box to the other side of the loop, right click the input and select create constant. Then use an insert into array function to add each iteration's waveform data to this array. Then when the while loop has finished running all of the data you have acquired will be in this built array and ready to output to file.
As far as Warning 1905 goes, it looks like this probably has to do with the way the VI is doing averaging. You can run your main VI in highlight execution mode and watch the block diagram of the SVT FFT Spectrum VI to see exactly where the Warning is coming up. If you want to resolve the problem the easy way I would simply get rid of the wait VI in the while loop and set the samples to read to exactly 100. This way the read function will delay the while loop execution until it has exactly 100 samples to pull of the buffer. This should also eliminate the warning because the number of samples you are feeding in will be the same each time.