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