Mercurial > libavcodec.hg
comparison acelp_vectors.c @ 11647:26aabf52f578 libavcodec
Split the input/output data arguments to ff_adaptive_gain_control().
author | rbultje |
---|---|
date | Wed, 21 Apr 2010 17:43:52 +0000 |
parents | c2e19a511e26 |
children |
comparison
equal
deleted
inserted
replaced
11646:a69e24b73f3c | 11647:26aabf52f578 |
---|---|
205 for(i=0; i<length; i++) | 205 for(i=0; i<length; i++) |
206 out[i] = weight_coeff_a * in_a[i] | 206 out[i] = weight_coeff_a * in_a[i] |
207 + weight_coeff_b * in_b[i]; | 207 + weight_coeff_b * in_b[i]; |
208 } | 208 } |
209 | 209 |
210 void ff_adaptive_gain_control(float *buf_out, float speech_energ, | 210 void ff_adaptive_gain_control(float *out, const float *in, float speech_energ, |
211 int size, float alpha, float *gain_mem) | 211 int size, float alpha, float *gain_mem) |
212 { | 212 { |
213 int i; | 213 int i; |
214 float postfilter_energ = ff_dot_productf(buf_out, buf_out, size); | 214 float postfilter_energ = ff_dot_productf(in, in, size); |
215 float gain_scale_factor = 1.0; | 215 float gain_scale_factor = 1.0; |
216 float mem = *gain_mem; | 216 float mem = *gain_mem; |
217 | 217 |
218 if (postfilter_energ) | 218 if (postfilter_energ) |
219 gain_scale_factor = sqrt(speech_energ / postfilter_energ); | 219 gain_scale_factor = sqrt(speech_energ / postfilter_energ); |
220 | 220 |
221 gain_scale_factor *= 1.0 - alpha; | 221 gain_scale_factor *= 1.0 - alpha; |
222 | 222 |
223 for (i = 0; i < size; i++) { | 223 for (i = 0; i < size; i++) { |
224 mem = alpha * mem + gain_scale_factor; | 224 mem = alpha * mem + gain_scale_factor; |
225 buf_out[i] *= mem; | 225 out[i] = in[i] * mem; |
226 } | 226 } |
227 | 227 |
228 *gain_mem = mem; | 228 *gain_mem = mem; |
229 } | 229 } |
230 | 230 |