Fix application of window in FFT
This commit is contained in:
parent
bf37ab52b3
commit
257ba4a7fb
1 changed files with 9 additions and 10 deletions
|
@ -113,15 +113,15 @@ void AudioEffectSpectrumAnalyzerInstance::process(const AudioFrame *p_src_frames
|
||||||
|
|
||||||
float *fftw = temporal_fft.ptrw();
|
float *fftw = temporal_fft.ptrw();
|
||||||
for (int i = 0; i < to_fill; i++) { //left and right buffers
|
for (int i = 0; i < to_fill; i++) { //left and right buffers
|
||||||
float window = -0.5 * Math::cos(2.0 * Math_PI * (double)i / (double)to_fill) + 0.5;
|
float window = -0.5 * Math::cos(2.0 * Math_PI * (double)temporal_fft_pos / (double)fft_size) + 0.5;
|
||||||
fftw[(i + temporal_fft_pos) * 2] = window * p_src_frames[i].l;
|
fftw[temporal_fft_pos * 2] = window * p_src_frames->l;
|
||||||
fftw[(i + temporal_fft_pos) * 2 + 1] = 0;
|
fftw[temporal_fft_pos * 2 + 1] = 0;
|
||||||
fftw[(i + temporal_fft_pos + fft_size * 2) * 2] = window * p_src_frames[i].r;
|
fftw[(temporal_fft_pos + fft_size * 2) * 2] = window * p_src_frames->r;
|
||||||
fftw[(i + temporal_fft_pos + fft_size * 2) * 2 + 1] = 0;
|
fftw[(temporal_fft_pos + fft_size * 2) * 2 + 1] = 0;
|
||||||
|
++p_src_frames;
|
||||||
|
++temporal_fft_pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
p_src_frames += to_fill;
|
|
||||||
temporal_fft_pos += to_fill;
|
|
||||||
p_frame_count -= to_fill;
|
p_frame_count -= to_fill;
|
||||||
|
|
||||||
if (temporal_fft_pos == fft_size * 2) {
|
if (temporal_fft_pos == fft_size * 2) {
|
||||||
|
@ -134,9 +134,8 @@ void AudioEffectSpectrumAnalyzerInstance::process(const AudioFrame *p_src_frames
|
||||||
|
|
||||||
for (int i = 0; i < fft_size; i++) {
|
for (int i = 0; i < fft_size; i++) {
|
||||||
//abs(vec)/fft_size normalizes each frequency
|
//abs(vec)/fft_size normalizes each frequency
|
||||||
float window = 1.0; //-.5 * Math::cos(2. * Math_PI * (double)i / (double)fft_size) + .5;
|
hw[i].l = Vector2(fftw[i * 2], fftw[i * 2 + 1]).length() / float(fft_size);
|
||||||
hw[i].l = window * Vector2(fftw[i * 2], fftw[i * 2 + 1]).length() / float(fft_size);
|
hw[i].r = Vector2(fftw[fft_size * 4 + i * 2], fftw[fft_size * 4 + i * 2 + 1]).length() / float(fft_size);
|
||||||
hw[i].r = window * Vector2(fftw[fft_size * 4 + i * 2], fftw[fft_size * 4 + i * 2 + 1]).length() / float(fft_size);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fft_pos = next; //swap
|
fft_pos = next; //swap
|
||||||
|
|
Loading…
Reference in a new issue