#define GST_CAT_DEFAULT equalizer_debug
-enum
-{
- ARG_BAND_WIDTH = 1
-};
-
static void gst_iir_equalizer_child_proxy_interface_init (gpointer g_iface,
gpointer iface_data);
static void gst_iir_equalizer_finalize (GObject * object);
-static void gst_iir_equalizer_set_property (GObject * object,
- guint prop_id, const GValue * value, GParamSpec * pspec);
-static void gst_iir_equalizer_get_property (GObject * object,
- guint prop_id, GValue * value, GParamSpec * pspec);
static gboolean gst_iir_equalizer_setup (GstAudioFilter * filter,
GstRingBufferSpec * fmt);
" rate=(int)[1000,MAX]," \
" channels=(int)[1,MAX]; " \
"audio/x-raw-float," \
- " width=(int)32," \
+ " width=(int) { 32, 64 } ," \
" endianness=(int)BYTE_ORDER," \
" rate=(int)[1000,MAX]," \
" channels=(int)[1,MAX]"
enum
{
ARG_GAIN = 1,
- ARG_FREQ
+ ARG_FREQ,
+ ARG_BAND_WIDTH
};
typedef struct _GstIirEqualizerBandClass GstIirEqualizerBandClass;
/* center frequency and gain */
gdouble freq;
gdouble gain;
+ gdouble width;
/* second order iir filter */
gdouble alpha; /* IIR coefficients for outputs */
}
break;
}
+ case ARG_BAND_WIDTH:{
+ gdouble width;
+
+ width = g_value_get_double (value);
+ GST_DEBUG_OBJECT (band, "width = %lf -> %lf", band->width, width);
+ if (width != band->width) {
+ GstIirEqualizer *equ =
+ GST_IIR_EQUALIZER (gst_object_get_parent (GST_OBJECT (band)));
+
+ band->width = width;
+ if (GST_AUDIO_FILTER (equ)->format.rate) {
+ setup_filter (equ, band);
+ }
+ gst_object_unref (equ);
+ GST_DEBUG_OBJECT (band, "changed width = %lf ", band->width);
+ }
+ }
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
case ARG_FREQ:
g_value_set_double (value, band->freq);
break;
+ case ARG_BAND_WIDTH:
+ g_value_set_double (value, band->width);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
g_param_spec_double ("freq", "freq",
"center frequency of the band",
0.0, 100000.0, 0.0, G_PARAM_READABLE));
+
+ g_object_class_install_property (gobject_class, ARG_BAND_WIDTH,
+ g_param_spec_double ("band-width", "band-width",
+ "band width calculated as distance between bands * this value", 0.1,
+ 10.0, 1.0, G_PARAM_READWRITE | GST_PARAM_CONTROLLABLE));
+}
+
+static void
+gst_iir_equalizer_band_init (GstIirEqualizerBand * band,
+ GstIirEqualizerBandClass * klass)
+{
+ band->freq = 0.0;
+ band->gain = 0.0;
+ band->width = 1.0;
}
static GType
NULL,
sizeof (GstIirEqualizerBand),
0,
- NULL,
+ (GInstanceInitFunc) gst_iir_equalizer_band_init,
};
type =
g_type_register_static (GST_TYPE_OBJECT, "GstIirEqualizerBand",
GstBaseTransformClass *btrans_class = (GstBaseTransformClass *) klass;
GObjectClass *gobject_class = (GObjectClass *) klass;
- gobject_class->set_property = gst_iir_equalizer_set_property;
- gobject_class->get_property = gst_iir_equalizer_get_property;
gobject_class->finalize = gst_iir_equalizer_finalize;
- /* FIXME: move to GstIirEqualizerBand to make a full parametric eq */
- g_object_class_install_property (gobject_class, ARG_BAND_WIDTH,
- g_param_spec_double ("band-width", "band-width",
- "band width calculated as distance between bands * this value", 0.1,
- 10.0, 1.0, G_PARAM_READWRITE | G_PARAM_CONSTRUCT));
-
audio_filter_class->setup = gst_iir_equalizer_setup;
btrans_class->transform_ip = gst_iir_equalizer_transform_ip;
}
gdouble gain = arg_to_scale (band->gain);
gdouble frequency = band->freq / GST_AUDIO_FILTER (equ)->format.rate;
gdouble q = pow (HIGHEST_FREQ / LOWEST_FREQ,
- 1.0 / (equ->freq_band_count - 1)) * equ->band_width;
+ 1.0 / (equ->freq_band_count - 1)) * band->width;
+
gdouble theta = frequency * 2 * M_PI;
band->beta = (q - theta / 2) / (2 * q + theta);
}
}
-static void
-gst_iir_equalizer_set_property (GObject * object, guint prop_id,
- const GValue * value, GParamSpec * pspec)
-{
- GstIirEqualizer *equ = GST_IIR_EQUALIZER (object);
-
- g_mutex_lock (((GstBaseTransform *) (equ))->transform_lock);
- //GST_BASE_TRANSFORM_LOCK (equ);
- GST_OBJECT_LOCK (equ);
- switch (prop_id) {
- case ARG_BAND_WIDTH:
- if (g_value_get_double (value) != equ->band_width) {
- equ->band_width = g_value_get_double (value);
- if (GST_AUDIO_FILTER (equ)->format.rate) {
- guint i;
-
- for (i = 0; i < equ->freq_band_count; i++) {
- setup_filter (equ, equ->bands[i]);
- }
- }
- }
- break;
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
- break;
- }
- GST_OBJECT_UNLOCK (equ);
- GST_BASE_TRANSFORM_UNLOCK (equ);
-}
-
-static void
-gst_iir_equalizer_get_property (GObject * object, guint prop_id,
- GValue * value, GParamSpec * pspec)
-{
- GstIirEqualizer *equ = GST_IIR_EQUALIZER (object);
-
- GST_BASE_TRANSFORM_LOCK (equ);
- GST_OBJECT_LOCK (equ);
- switch (prop_id) {
- case ARG_BAND_WIDTH:
- g_value_set_double (value, equ->band_width);
- break;
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
- break;
- }
- GST_OBJECT_UNLOCK (equ);
- GST_BASE_TRANSFORM_UNLOCK (equ);
-}
-
/* start of code that is type specific */
#define CREATE_OPTIMIZED_FUNCTIONS(TYPE,BIG_TYPE,MIN_VAL,MAX_VAL) \
CREATE_OPTIMIZED_FUNCTIONS (gint16, gint, -32768, 32767);
CREATE_OPTIMIZED_FUNCTIONS (gfloat, gfloat, -1.0, 1.0);
+CREATE_OPTIMIZED_FUNCTIONS (gdouble, gdouble, -1.0, 1.0);
static GstFlowReturn
gst_iir_equalizer_transform_ip (GstBaseTransform * btrans, GstBuffer * buf)
{
GstIirEqualizer *equ = GST_IIR_EQUALIZER (audio);
- switch (fmt->width) {
- case 16:
- equ->history_size = history_size_gint16;
- equ->process = gst_iir_equ_process_gint16;
+ switch (fmt->type) {
+ case GST_BUFTYPE_LINEAR:
+ switch (fmt->width) {
+ case 16:
+ equ->history_size = history_size_gint16;
+ equ->process = gst_iir_equ_process_gint16;
+ break;
+ default:
+ return FALSE;
+ }
break;
- case 32:
- equ->history_size = history_size_gfloat;
- equ->process = gst_iir_equ_process_gfloat;
+ case GST_BUFTYPE_FLOAT:
+ switch (fmt->width) {
+ case 32:
+ equ->history_size = history_size_gfloat;
+ equ->process = gst_iir_equ_process_gfloat;
+ break;
+ case 64:
+ equ->history_size = history_size_gdouble;
+ equ->process = gst_iir_equ_process_gdouble;
+ break;
+ default:
+ return FALSE;
+ }
break;
default:
return FALSE;
}
+
gst_iir_equalizer_compute_frequencies (equ, equ->freq_band_count);
return TRUE;
}