47 lines
1.2 KiB
C
47 lines
1.2 KiB
C
#ifndef KFC_H
|
|
#define KFC_H
|
|
#include "kiss_fft.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/*
|
|
KFC -- Kiss FFT Cache
|
|
|
|
Not needing to deal with kiss_fft_alloc and a config
|
|
object may be handy for a lot of programs.
|
|
|
|
KFC uses the underlying KISS FFT functions, but caches the config object.
|
|
The first time kfc_fft or kfc_ifft for a given FFT size, the cfg
|
|
object is created for it. All subsequent calls use the cached
|
|
configuration object.
|
|
|
|
NOTE:
|
|
You should probably not use this if your program will be using a lot
|
|
of various sizes of FFTs. There is a linear search through the
|
|
cached objects. If you are only using one or two FFT sizes, this
|
|
will be negligible. Otherwise, you may want to use another method
|
|
of managing the cfg objects.
|
|
|
|
There is no automated cleanup of the cached objects. This could lead
|
|
to large memory usage in a program that uses a lot of *DIFFERENT*
|
|
sized FFTs. If you want to force all cached cfg objects to be freed,
|
|
call kfc_cleanup.
|
|
|
|
*/
|
|
|
|
/*forward complex FFT */
|
|
void kfc_fft(int nfft, const kiss_fft_cpx * fin,kiss_fft_cpx * fout);
|
|
/*reverse complex FFT */
|
|
void kfc_ifft(int nfft, const kiss_fft_cpx * fin,kiss_fft_cpx * fout);
|
|
|
|
/*free all cached objects*/
|
|
void kfc_cleanup(void);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif
|