Commit 23cd7b25 authored by Ron Wright's avatar Ron Wright Committed by Jean-Baptiste Kempf

glspectrum: use FFT Windowing

Signed-off-by: default avatarJean-Baptiste Kempf <jb@videolan.org>
parent cf024724
...@@ -17,4 +17,5 @@ visualization_LTLIBRARIES += libvisual_plugin.la ...@@ -17,4 +17,5 @@ visualization_LTLIBRARIES += libvisual_plugin.la
SOURCES_vsxu = vsxu.cpp cyclic_buffer.h SOURCES_vsxu = vsxu.cpp cyclic_buffer.h
SOURCES_glspectrum = glspectrum.c visual/fft.c visual/fft.h SOURCES_glspectrum = glspectrum.c visual/fft.c visual/fft.h \
visual/window.c visual/window.h visual/window_presets.h
...@@ -40,6 +40,7 @@ ...@@ -40,6 +40,7 @@
#include <math.h> #include <math.h>
#include "visual/fft.h" #include "visual/fft.h"
#include "visual/window.h"
/***************************************************************************** /*****************************************************************************
...@@ -94,6 +95,9 @@ struct filter_sys_t ...@@ -94,6 +95,9 @@ struct filter_sys_t
/* Window size */ /* Window size */
int i_width; int i_width;
int i_height; int i_height;
/* FFT window parameters */
window_param wind_param;
}; };
...@@ -135,6 +139,9 @@ static int Open(vlc_object_t * p_this) ...@@ -135,6 +139,9 @@ static int Open(vlc_object_t * p_this)
p_sys->f_rotationAngle = 0; p_sys->f_rotationAngle = 0;
p_sys->f_rotationIncrement = ROTATION_INCREMENT; p_sys->f_rotationIncrement = ROTATION_INCREMENT;
/* Fetch the FFT window parameters */
window_get_param( VLC_OBJECT( p_filter ), &p_sys->wind_param );
/* Create the FIFO for the audio data. */ /* Create the FIFO for the audio data. */
p_sys->fifo = block_FifoNew(); p_sys->fifo = block_FifoNew();
if (p_sys->fifo == NULL) if (p_sys->fifo == NULL)
...@@ -425,6 +432,7 @@ static void *Thread( void *p_data ) ...@@ -425,6 +432,7 @@ static void *Thread( void *p_data )
36,47,62,82,107,141,184,255}; 36,47,62,82,107,141,184,255};
fft_state *p_state = NULL; /* internal FFT data */ fft_state *p_state = NULL; /* internal FFT data */
DEFINE_WIND_CONTEXT(wind_ctx); /* internal window data */
unsigned i, j; unsigned i, j;
float p_output[FFT_BUFFER_SIZE]; /* Raw FFT Result */ float p_output[FFT_BUFFER_SIZE]; /* Raw FFT Result */
...@@ -471,6 +479,11 @@ static void *Thread( void *p_data ) ...@@ -471,6 +479,11 @@ static void *Thread( void *p_data )
msg_Err(p_filter,"unable to initialize FFT transform"); msg_Err(p_filter,"unable to initialize FFT transform");
goto release; goto release;
} }
if (!window_init(FFT_BUFFER_SIZE, &p_sys->wind_param, &wind_ctx))
{
msg_Err(p_filter,"unable to initialize FFT window");
goto release;
}
p_buffs = p_s16_buff; p_buffs = p_s16_buff;
for (i = 0 ; i < FFT_BUFFER_SIZE; i++) for (i = 0 ; i < FFT_BUFFER_SIZE; i++)
{ {
...@@ -481,6 +494,7 @@ static void *Thread( void *p_data ) ...@@ -481,6 +494,7 @@ static void *Thread( void *p_data )
if (p_buffs >= &p_s16_buff[block->i_nb_samples * p_sys->i_channels]) if (p_buffs >= &p_s16_buff[block->i_nb_samples * p_sys->i_channels])
p_buffs = p_s16_buff; p_buffs = p_s16_buff;
} }
window_scale_in_place (p_buffer1, &wind_ctx);
fft_perform (p_buffer1, p_output, p_state); fft_perform (p_buffer1, p_output, p_state);
for (i = 0; i< FFT_BUFFER_SIZE; ++i) for (i = 0; i< FFT_BUFFER_SIZE; ++i)
...@@ -532,6 +546,7 @@ static void *Thread( void *p_data ) ...@@ -532,6 +546,7 @@ static void *Thread( void *p_data )
} }
release: release:
window_close(&wind_ctx);
fft_close(p_state); fft_close(p_state);
block_Release(block); block_Release(block);
vlc_restorecancel(canc); vlc_restorecancel(canc);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment