FastLED 3.9.15
Loading...
Searching...
No Matches

◆ generate_kernels()

struct sparse_arr * generate_kernels ( struct cq_kernel_cfg cfg)

Definition at line 103 of file cq_kernel.cpp.hpp.

103 {
104 float *freq = (float*)fl::malloc(cfg.bands * sizeof(float));
105 _generate_center_freqs(freq, cfg.bands, cfg.fmin, cfg.fmax);
106
107 kiss_fftr_cfg fft_cfg = kiss_fftr_alloc(cfg.samples, 0, nullptr, nullptr);
108 struct sparse_arr* kernels = (struct sparse_arr*)fl::malloc(cfg.bands*sizeof(struct sparse_arr));
109 kiss_fft_cpx *temp_kernel = (kiss_fft_cpx*)fl::malloc(cfg.samples*sizeof(kiss_fft_cpx));
110
111 for(int i = 0; i < cfg.bands; i++){
112 // Clears temp_kernel before calling _generate_kernel on it
113 for(int i = 0; i < cfg.samples; i++) temp_kernel[i].r = temp_kernel[i].i = 0;
114
115 _generate_kernel(temp_kernel, fft_cfg, cfg.window_type, freq[i], cfg.fmin, cfg.fs, cfg.samples);
116
117 // Counts number of elements with a complex magnitude above cfg.min_val in temp_kernel
118 int n_elems = 0;
119 for(int j = 0; j < cfg.samples; j++) if(_mag(temp_kernel[j]) > cfg.min_val) n_elems++;
120
121 // Generates sparse_arr holding n_elems sparse_arr_elem's
122 kernels[i].n_elems = n_elems;
123 kernels[i].elems = (struct sparse_arr_elem*)fl::malloc(n_elems*sizeof(struct sparse_arr_elem));
124
125 // Generates sparse_arr_elem's from complex values counted before
126 int k = 0;
127 for(int j = 0; j < cfg.samples; j++){
128 if(_mag(temp_kernel[j]) > cfg.min_val){
129 kernels[i].elems[k].val = temp_kernel[j];
130 kernels[i].elems[k].n = j;
131 k++;
132 }
133 }
134 }
135
136 fl::free(fft_cfg);
137 fl::free(temp_kernel);
138 fl::free(freq);
139
140 return kernels;
141}
void _generate_center_freqs(float freq[], int bands, float fmin, float fmax) FL_NOEXCEPT
void _generate_kernel(kiss_fft_cpx kernel[], kiss_fftr_cfg cfg, enum window_type window_type, float f, float fmin, float fs, int N) FL_NOEXCEPT
kiss_fft_scalar _mag(kiss_fft_cpx x) FL_NOEXCEPT
struct sparse_arr_elem * elems
Definition cq_kernel.h:56
kiss_fft_cpx val
Definition cq_kernel.h:52
int n_elems
Definition cq_kernel.h:55
enum window_type window_type
Definition cq_kernel.h:42
kiss_fft_scalar min_val
Definition cq_kernel.h:43
kiss_fftr_cfg kiss_fftr_alloc(int nfft, int inverse_fft, void *mem, size_t *lenmem) FL_NOEXCEPT
struct kiss_fftr_state * kiss_fftr_cfg
Definition kiss_fftr.h:26
void * malloc(size_t size)
Definition malloc.cpp.hpp:9
void free(void *ptr)

References _generate_center_freqs(), _generate_kernel(), _mag(), sparse_arr::elems, FL_NOEXCEPT, fl::free(), kiss_fftr_alloc(), fl::malloc(), sparse_arr_elem::n, sparse_arr::n_elems, and sparse_arr_elem::val.

Referenced by fl::audio::fft::Context::initNaive(), and fl::audio::fft::Context::initOctaveWise().

+ Here is the call graph for this function:
+ Here is the caller graph for this function: