LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Dynamically decimate data from synchronized modules

Dear NI community,

let me, please, ask about the following.

 

I'd like to acquire data at FPGA from NI 9237 and 9234 modules. I'd like to have it synchronize by master clock from 9234 module. But, I'd like to acquire data with separate sampling rates. For example, NI 9234 with 51.2 kS/s, and at the same time NI 9237 with 3.2 kS/s.

FPGA acq.PNG
If I'll place it into one while loop, as in community examples (see attached screenshot), then I need to run them at the highest sample rate (or not?), and then decimate data. Please, are there some examples of how to dynamically decimate data? Because sampling rates could be any from the allowed selectable range... I've found Decimate function at FPGA pallete, but it should have fixed configuration, not on-the-fly...
Where would be more effient to have decimation - at FPGA side, or at cRIO side?


Or, then it is better for each module implement separate while loop?

 

Thanks a lot in advance,

Sincerely, kosist90.

0 Kudos
Message 1 of 2
(2,156 Views)

Hello,

 

One way I can think of doing that is index of loop and then divide by a number and when that equals 0 take the data at that point. 

 

Parul M.

Applications Engineer

National Instruments

0 Kudos
Message 2 of 2
(2,108 Views)