19#define M_PI 3.1415926535897932384626433832795
26 float m = log(fmax/fmin);
27 for(
int i = 0; i < bands; i++) freq[i] = fmin*exp(m*i/(bands-1));
32 for(
int i = 0; i < N; i++){
36 window[i] = a0-(1-a0)*cos(2*
M_PI*i/(N-1));
43 for(
int i = 0; i < N; i++){
45 window[i] =
SAMP_MAX*exp(-0.5*pow((i-N/2.0)/(sigma*N/2.0), 2));
47 window[i] = exp(-0.5*pow((i-N/2.0)/(sigma*N/2.0), 2));
54 float factor = f/fmin;
55 int N_window = N/factor;
68 for(
int i = 0; i < N; i++) time_K[i] *= cos(2*
M_PI*(f/fs)*(i-N/2));
72 for(
int i = 0; i < N; i++){
73 kernel[i].
r *= factor;
74 kernel[i].
i *= factor;
77 for(
int i = 0; i < N; i++) time_K[i] /= N_window;
85 return sqrt(
x.r*
x.r+
x.i*
x.i);
89 float *freq = (
float*)malloc(cfg.
bands *
sizeof(
float));
96 for(
int i = 0; i < cfg.
bands; i++){
98 for(
int i = 0; i < cfg.
samples; i++) temp_kernel[i].r = temp_kernel[i].i = 0;
112 for(
int j = 0; j < cfg.
samples; j++){
114 kernels[i].
elems[k].
val = temp_kernel[j];
115 kernels[i].
elems[k].
n = j;
130 for(
int i = 0; i < cfg.
bands; i++){
134 free(old_ptr[i].
elems);
141 for(
int i = 0; i < cfg.
bands; i++){
142 for(
int j = 0; j < kernels[i].
n_elems; j++){
151 for(
int i = 0; i < cfg.
bands; i++) free(kernels[i].
elems);
void _generate_guassian(kiss_fft_scalar window[], int N)
void _generate_hamming(kiss_fft_scalar window[], int N)
kiss_fft_scalar _mag(kiss_fft_cpx x)
void free_kernels(struct sparse_arr *kernels, struct cq_kernel_cfg cfg)
void _generate_kernel(kiss_fft_cpx kernel[], kiss_fftr_cfg cfg, enum window_type window_type, float f, float fmin, float fs, int N)
void apply_kernels(kiss_fft_cpx fft[], kiss_fft_cpx cq[], struct sparse_arr kernels[], struct cq_kernel_cfg cfg)
struct sparse_arr * generate_kernels(struct cq_kernel_cfg cfg)
void _generate_center_freqs(float freq[], int bands, float fmin, float fmax)
struct sparse_arr * reallocate_kernels(struct sparse_arr *old_ptr, struct cq_kernel_cfg cfg)
struct sparse_arr_elem * elems
enum window_type window_type
void kiss_fftr(kiss_fftr_cfg st, const kiss_fft_scalar *timedata, kiss_fft_cpx *freqdata)
kiss_fftr_cfg kiss_fftr_alloc(int nfft, int inverse_fft, void *mem, size_t *lenmem)
struct kiss_fftr_state * kiss_fftr_cfg