33 int i, flags1, flags2, block_align;
41 "too many channels: got %i, need %i or fewer\n",
54 "bitrate too low: got %i, need 24000 or higher\n",
110 const float *win = s->
windows[window_index];
112 float n = 2.0 * 32768.0 / window_len;
129 float v, *q, max_scale, *q_end;
137 v = pow(10, *exp_param++ *(1.0 / 16.0));
138 max_scale =
FFMAX(max_scale, v);
157 last_exp = *exp_param++;
158 av_assert0(last_exp - 10 >= 0 && last_exp - 10 < 32);
164 int exp = *exp_param++;
165 int code = exp - last_exp + 60;
178 int v, bsize, ch, coef_nb_bits, parse_exponents;
181 static const int fixed_exp[25] = {
209 mdct_norm = 1.0 / (float) n4;
211 mdct_norm *= sqrt(n4);
227 float *coefs, *exponents,
mult;
232 mult = pow(10, total_gain * 0.05) / s->
max_exponent[ch];
234 coefs = src_coefs[ch];
240 for (i = 0; i <
n; i++) {
241 double t = *coefs++ / (exponents[i] *
mult);
242 if (t < -32768 || t > 32767)
245 coefs1[i] =
lrint(t);
261 for (v = total_gain - 1; v >= 127; v -= 127)
272 for (i = 0; i <
n; i++) {
285 if (parse_exponents) {
305 eptr = ptr + nb_coefs[ch];
308 for (; ptr < eptr; ptr++) {
311 int abs_level =
FFABS(level);
313 if (abs_level <= s->
coef_vlcs[tindex]->max_level)
314 if (run < s->
coef_vlcs[tindex]->levels[abs_level - 1])
315 code = run + s->
int_table[tindex][abs_level - 1];
322 if (1 << coef_nb_bits <= abs_level)
363 int i, total_gain,
ret, error;
375 a = s->
coefs[0][i] * 0.5;
376 b = s->
coefs[1][i] * 0.5;
386 for (i = 64; i; i >>= 1) {
393 while(total_gain <= 128 && error > 0)
396 av_log(avctx,
AV_LOG_ERROR,
"Invalid input data or requested bitrate too low, cannot encode\n");
417 #if CONFIG_WMAV1_ENCODER
431 #if CONFIG_WMAV2_ENCODER