FFT Filter: Difference between revisions
(add Example Flowgraph) |
(→Source Files: added outside reference) |
||
Line 40: | Line 40: | ||
; Block definition | ; Block definition | ||
: [https://github.com/gnuradio/gnuradio TODO] | : [https://github.com/gnuradio/gnuradio TODO] | ||
== Outside References == | |||
: [http://www.trondeau.com/blog/2014/2/27/to-use-or-not-to-use-fft-filters.html|To Use or Not to Use FFT Filters] | |||
http://blog.sdr.hu/grblocks/xlating-fir.html |
Revision as of 05:48, 29 November 2020
This block implements a decimating filter using the fast convolution method via an FFT. It is an alternative to the Decimating FIR Filter, useful when there is a large number of taps.
This filter is implemented by using the FFTW package to perform the required FFTs. An optional argument, nthreads, may be passed to the constructor (or set using the set_nthreads member function) to split the FFT among N number of threads. This can improve performance on very large FFTs (that is, if the number of taps used is very large) if you have enough threads/cores to support it.
For standard filters such as lowpass, highpass, bandpass, etc., the filter.firdes and filter.optfir classes provide convenient generating methods.
Parameters
(R): Run-time adjustable
- Decimation
- Decimation rate. The output stream will have this decimation applied to it. A decimation rate of 1 simply means no decimation. If decimation is set higher than 1, make sure the filter will remove energy outside of the "output region", i.e. -Fs/2 to Fs/2 where Fs is the input sample rate divided by the decimation rate.
- Taps (R)
- Taps to use in FIR filter.
- Sample Delay
- Number of additional samples to delay signal by.
- Number of Threads
- Number of threads to use for this block, i.e. to increase performance on multicore CPUs.
Example Flowgraph
This flowgraph implements a Broadcast FM stereo receiver using basic blocks.
Source Files
- C++ files
- TODO
- Header files
- TODO
- Public header files
- TODO
- Block definition
- TODO