LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Xilinx FFT function: how to feed values to it one at a time?

 

I am using LV2012 FPGA with the RIO Evaluation Kit (sbRIO-9636). I have a 1d array of U16 that I want to put into the Xilinx FPGA FFT function.* It originally had a while loop around it, but when I tried to compile it told me that function was only supported inside a single cycle timed loop so I changed the while loop to an SCTL.

 

But now when I try to compile, there's a "code generation error" screen that says "You cannot include this function in a For Loop when the For Loop is inside a single-cycle Timed Loop." The purpose of the for loop is to feed the array values one at a time to the FFT function, as required. Is there an alternate way of doing this?

 

*(I realize it would be better to dynamically load the data onto the FPGA, but I'll just hardcode it for now because I want to make it as simple as possible at first just to get some graphs. I'm not concerned about optimization for now.)

 

Also, if needed here's the datasheet for Xilinx FFT: http://www.xilinx.com/support/documentation/ip_documentation/xfft_ds260.pdf

0 Kudos
Message 1 of 21
(4,470 Views)

I put the SCTL inside the for loop, looks like it's actually trying to compile, hope it works. Soooo slow though.

0 Kudos
Message 2 of 21
(4,451 Views)

Anyone know, if I offload the compilation to a remote server, do I have to keep my computer connected to the remote server the entire time?

0 Kudos
Message 3 of 21
(4,440 Views)

Hi there, you can remove the SCTL (you don't really need it unless you are acquiring data and the Array constant is meant to be replaced with an analog input).

Alejandro C. | National Instruments
0 Kudos
Message 4 of 21
(4,431 Views)

Thanks for your response, however I tried it first without the SCTL and when I tried to compile, it told me the Xilinx FFT could only be used inside an SCTL. That's why I had to put the SCTL. 

0 Kudos
Message 5 of 21
(4,428 Views)

...then consider keeping the SCTL and use the Iteration terminal to feed the index input of the Index Array VI. That way you can get rid of the for loop.

Alejandro C. | National Instruments
0 Kudos
Message 6 of 21
(4,411 Views)

Thanks, I'll keep that suggestion in mind. That code wouldn't fit on the FPGA, I assume it's because I need to store the array on the host instead, and make a shared variable for it?

 

Also, stuff that's inside a diagram disable structure doesn't affect the compilation, right? 

0 Kudos
Message 7 of 21
(4,406 Views)

The idea with FPGA programming is to have the benefit of hardware time acquisition and analysis, if this array is so big that doesn't fit on the FPGA then it would make more sense to keep everything on the RT side. In the case you are planing to transfer data here is an article that can give you a good reference.

 

Regarding the disable diagram, when LabVIEW compiles the code (before the creation of the intermediate files) the code inside is removed.

Alejandro C. | National Instruments
Message 8 of 21
(4,392 Views)

Good info, thanks

0 Kudos
Message 9 of 21
(4,386 Views)

OK, I looked at that web page and I'd like to use programmatic front panel communication so I can store the array on the host and feed the values one at a time to the FPGA vi. In that case, what should replace the array constant on the FPGA vi? The rest of the variables have FPGA I/O items, but maybe the input array is different because the source of the data is the host, not the board inputs.

I created a new shared variable and called it "FFT Input Array" that I put on the RT microprocessor vi. Is this the right configuration? (other than the read/write control, I can't select the input array yet probably because it's not on the FPGA vi yet. It's hard to tell how the configuration should be, because all the other variables are going the other way (data from FPGA to host) .

 

 

 

Also, is this the right way to set up the host vi? The FFT input array has its own event case, while the rest of the variables are in another case.

0 Kudos
Message 10 of 21
(4,342 Views)