44 #define LPC_FILTERORDER 10
48 #define ST_MEM_L_TBL 85
49 #define MEM_LF_TBL 147
50 #define STATE_SHORT_LEN_20MS 57
51 #define STATE_SHORT_LEN_30MS 58
53 #define BLOCKL_MAX 240
56 #define CB_HALFFILTERLEN 4
57 #define CB_FILTERLEN 8
59 #define ENH_NBLOCKS_TOT 8
61 #define ENH_BUFL (ENH_NBLOCKS_TOT)*ENH_BLOCKL
62 #define ENH_BUFL_FILTEROVERHEAD 3
63 #define BLOCKL_MAX 240
71 #define STATE_SHORT_LEN_30MS 58
72 #define STATE_SHORT_LEN_20MS 57
74 #define SPL_MUL_16_16(a, b) ((int32_t) (((int16_t)(a)) * ((int16_t)(b))))
75 #define SPL_MUL_16_16_RSFT(a, b, c) (SPL_MUL_16_16(a, b) >> (c))
165 for (j = 0; j < 48; j++)
200 for (j = 0; j < 56; j++)
273 for (k = 4; k < 6; k++) {
276 }
else if (
index[k] >= 108 &&
index[k] < 128) {
284 int i, j,
pos = 0, cb_pos = 0;
312 for (
int n = 0; n < 2; n++) {
313 for (
int m = 0; m < nb_vectors; m++) {
314 for (
int k = 0; k <
dim - 1; k++) {
317 if ((lsf[
i + 1] - lsf[
i]) < 319) {
318 if (lsf[
i + 1] < lsf[
i]) {
319 lsf[
i + 1] = lsf[
i] + 160;
320 lsf[
i] = lsf[
i + 1] - 160;
334 int16_t *in2, int16_t coef,
337 int invcoef = 16384 - coef,
i;
340 out[
i] = (coef * in1[
i] + invcoef * in2[
i] + 8192) >> 14;
343 static void lsf2lsp(int16_t *lsf, int16_t *lsp,
int order)
349 for (
i = 0;
i < order;
i++) {
350 freq = (lsf[
i] * 20861) >> 15;
357 k =
FFMIN(freq >> 8, 63);
373 f[1] = lsp[0] * -1024;
375 for (
i = 2, k = 2, l = 2;
i <= 5;
i++, k += 2) {
378 for (j =
i; j > 1; j--, l--) {
379 high =
f[l - 1] >> 16;
380 low = (
f[l - 1] - (high * (1 << 16))) >> 1;
382 tmp = ((high * lsp[k]) * 4) + (((low * lsp[k]) >> 15) * 4);
385 f[l] -= (unsigned)
tmp;
388 f[l] -= lsp[k] * (1 << 10);
405 for (
i = 5;
i > 0;
i--) {
406 f[0][
i] += (unsigned)
f[0][
i - 1];
407 f[1][
i] -= (unsigned)
f[1][
i - 1];
411 for (
i = 5;
i > 0;
i--) {
412 tmp =
f[0][6 -
i] + (unsigned)
f[1][6 -
i] + 4096;
413 a[6 -
i] =
tmp >> 13;
415 tmp =
f[0][6 -
i] - (unsigned)
f[1][6 -
i] + 4096;
416 a[5 +
i] =
tmp >> 13;
421 int16_t *lsf2,
int coef,
int length)
429 static void bw_expand(int16_t *
out,
const int16_t *in,
const int16_t *coef,
int length)
434 for (
i = 1;
i < length;
i++)
435 out[
i] = (coef[
i] * in[
i] + 16384) >> 15;
439 int16_t *lsfdeq, int16_t length,
443 int i,
pos, lp_length;
445 lsfdeq2 = lsfdeq + length;
446 lp_length = length + 1;
450 memcpy(syntdenum, lp, lp_length * 2);
454 for (
i = 1;
i < 6;
i++) {
458 memcpy(syntdenum +
pos, lp, lp_length * 2);
464 for (
i = 0;
i <
s->nsub;
i++) {
467 memcpy(syntdenum +
pos, lp, lp_length * 2);
474 memcpy(
s->lsfdeqold, lsfdeq2, length * 2);
476 memcpy(
s->lsfdeqold, lsfdeq, length * 2);
481 int16_t *
B, int16_t B_length,
486 for (
i = 0;
i < length;
i++) {
487 const int16_t *b_ptr = &
B[0];
488 const int16_t *x_ptr = &in_ptr[
i];
491 for (j = 0; j < B_length; j++)
492 o += b_ptr[j] * *x_ptr--;
494 o =
av_clip(o, -134217728, 134215679);
496 out_ptr[
i] = ((o + 2048) >> 12);
503 int coefficients_length,
508 for (
i = 0;
i < data_length;
i++) {
511 for (j = coefficients_length - 1; j > 0; j--) {
518 data_out[
i] = (
output + 2048) >> 12;
523 int16_t *synt_denum, int16_t *Out_fix,
528 int16_t *tmp1, *tmp2, *tmp3;
549 tmp2 = &idx[
len - 1];
552 for (k = 0; k <
len; k++) {
559 }
else if (ifm < 59) {
560 for (k = 0; k <
len; k++) {
568 for (k = 0; k <
len; k++) {
578 memset(&sampleVal[
len], 0,
len * 2);
590 tmp1 = &sampleAr[
len - 1];
591 tmp2 = &sampleAr[2 *
len - 1];
593 for (k = 0; k <
len; k++) {
594 (*tmp3) = (*tmp1) + (*tmp2);
610 int length,
int shift)
612 for (
int i = 0;
i < length;
i++)
617 const int16_t *
win,
int length,
620 for (
int i = 0;
i < length;
i++)
625 const int16_t *in2,
int length,
628 for (
int i = 0;
i < length;
i++)
636 int16_t ilow =
index - interpolation_length;
654 int16_t k, base_size;
657 int16_t tempbuff2[
SUBL + 5];
660 base_size = lMem - cbveclen + 1;
662 if (cbveclen ==
SUBL) {
663 base_size += cbveclen / 2;
667 if (
index < lMem - cbveclen + 1) {
670 k =
index + cbveclen;
672 memcpy(cbvec, mem + lMem - k, cbveclen * 2);
673 }
else if (
index < base_size) {
687 if (
index - base_size < lMem - cbveclen + 1) {
691 memIndTest = lMem - (
index - base_size + cbveclen);
709 lag = (cbveclen << 1) - 20 +
index - base_size - lMem - 1;
725 int16_t cbvec0[
SUBL];
726 int16_t cbvec1[
SUBL];
727 int16_t cbvec2[
SUBL];
746 for (j = 0; j < veclen; j++) {
751 decvector[j] = (
int)(a32 + 8192) >> 14;
757 int16_t* destPtr = dest;
758 int16_t* sourcePtr =
source;
761 for (j = 0; j < length; j++)
762 *destPtr-- = *sourcePtr++;
767 int16_t *decresidual,
770 int16_t meml_gotten, Nfor, Nback,
diff, start_pos;
771 int16_t subcount, subframe;
772 int16_t *reverseDecresidual =
s->enh_buf;
773 int16_t *memVec =
s->prevResidual;
790 memset(mem, 0, (int16_t) (
CB_MEML -
s->state_short_len) * 2);
791 memcpy(mem +
CB_MEML -
s->state_short_len, decresidual + start_pos,
s->state_short_len * 2);
799 meml_gotten =
s->state_short_len;
801 memset(mem, 0, (int16_t) (
CB_MEML - meml_gotten) * 2);
814 Nfor =
s->nsub - encbits->
start - 1;
822 for (subframe = 0; subframe < Nfor; subframe++) {
836 Nback = encbits->
start - 1;
840 meml_gotten =
SUBL * (
s->nsub + 1 - encbits->
start);
846 memset(mem, 0, (int16_t) (
CB_MEML - meml_gotten) * 2);
849 for (subframe = 0; subframe < Nback; subframe++) {
868 int i = 0, absolute = 0, maximum = 0;
870 if (vector ==
NULL || length <= 0) {
874 for (
i = 0;
i < length;
i++) {
875 absolute =
FFABS(vector[
i]);
876 if (absolute > maximum)
881 return FFMIN(maximum, INT16_MAX);
888 if (0xFFFF0000 & n) {
894 if (0x0000FF00 & (n >>
bits))
bits += 8;
895 if (0x000000F0 & (n >>
bits))
bits += 4;
896 if (0x0000000C & (n >>
bits))
bits += 2;
897 if (0x00000002 & (n >>
bits))
bits += 1;
898 if (0x00000001 & (n >>
bits))
bits += 1;
907 for (
int i = 0;
i < length;
i++)
908 sum += (v1[
i] * v2[
i]) >> scaling;
914 int16_t lag, int16_t blen, int16_t srange, int16_t
scale)
918 w16ptr = &
buffer[blen - srange - lag];
929 #define SPL_SHIFT_W32(x, c) (((c) >= 0) ? ((x) << (c)) : ((x) >> (-(c))))
950 static void do_plc(int16_t *plc_residual,
954 int16_t *decresidual,
960 int32_t cross, ener, cross_comp, ener_comp = 0;
961 int32_t measure, max_measure, energy;
962 int16_t
max, cross_square_max, cross_square;
963 int16_t j, lag, tmp1, tmp2, randlag;
970 int16_t max_perSquare;
971 int16_t scale1, scale2;
983 s->consPLICount += 1;
988 if (
s->prevPLI != 1) {
1000 s->prevScale = scale3;
1007 corrLen =
FFMIN(60,
s->block_samples - (inlag + 3));
1009 correlation(&cross, &ener,
s->prevResidual, lag,
s->block_samples, corrLen, scale3);
1015 for (j = inlag - 2; j <= inlag + 3; j++) {
1016 correlation(&cross_comp, &ener_comp,
s->prevResidual, j,
s->block_samples, corrLen, scale3);
1032 if (((shift_max << 1) + shift3) > ((
shift1 << 1) +
shift2)) {
1040 if ((measure >> tmp1) > (max_measure >> tmp2)) {
1043 cross_square_max = cross_square;
1058 tmp2W32 =
scale_dot_product(&
s->prevResidual[
s->block_samples - corrLen], &
s->prevResidual[
s->block_samples - corrLen], corrLen, scale3);
1060 if ((tmp2W32 > 0) && (ener_comp > 0)) {
1074 totscale = scale1 + scale2 - 1;
1086 max_perSquare =
s->per_square;
1094 if (
s->consPLICount *
s->block_samples > 320) {
1096 }
else if (
s->consPLICount *
s->block_samples > 640) {
1098 }
else if (
s->consPLICount *
s->block_samples > 960) {
1100 }
else if (
s->consPLICount *
s->block_samples > 1280) {
1110 if (max_perSquare > 7868) {
1112 }
else if (max_perSquare > 839) {
1115 while ((max_perSquare <
kPlcPerSqr[ind]) && (ind > 0)) {
1121 pitchfact =
FFMIN(tmpW32, 32767);
1136 for (
i = 0;
i <
s->block_samples;
i++) {
1139 randlag = 53 + (
s->seed & 63);
1144 randvec[
i] =
s->prevResidual[
s->block_samples + pick];
1146 randvec[
i] =
s->prevResidual[pick];
1153 plc_residual[
i] =
s->prevResidual[
s->block_samples + pick];
1155 plc_residual[
i] = plc_residual[pick];
1160 tot_gain = use_gain;
1161 }
else if (
i < 160) {
1168 plc_residual[
i] =
SPL_MUL_16_16_RSFT(tot_gain, (pitchfact * plc_residual[
i] + (32767 - pitchfact) * randvec[
i] + 16384) >> 15, 15);
1177 if (energy <
SPL_SHIFT_W32(
s->block_samples * 900, -
s->prevScale - 1)) {
1179 for (
i = 0;
i <
s->block_samples;
i++) {
1180 plc_residual[
i] = randvec[
i];
1189 s->per_square = max_perSquare;
1191 memcpy(plc_residual, decresidual,
s->block_samples * 2);
1193 s->consPLICount = 0;
1199 memcpy(
s->prevResidual, plc_residual,
s->block_samples * 2);
1205 int16_t subl, int16_t searchLen,
1211 int16_t cross_corr_scale, energy_scale;
1212 int16_t cross_corr_sg_mod, cross_corr_sg_mod_max;
1214 int16_t cross_corr_mod, energy_mod, enery_mod_max;
1216 int16_t *rp_beg, *rp_end;
1217 int16_t totscale, totscale_max;
1224 cross_corr_sg_mod_max = 0;
1225 enery_mod_max = INT16_MAX;
1226 totscale_max = -500;
1234 rp_end = ®ressor[subl];
1237 rp_beg = ®ressor[-1];
1238 rp_end = ®ressor[subl - 1];
1254 for (k = 0; k < searchLen; k++) {
1256 rp = ®ressor[
pos];
1260 if ((energy > 0) && (cross_corr > 0)) {
1262 cross_corr_scale =
norm_w32(cross_corr) - 16;
1263 cross_corr_mod = (int16_t)
SPL_SHIFT_W32(cross_corr, cross_corr_scale);
1264 energy_scale =
norm_w32(energy) - 16;
1268 cross_corr_sg_mod = (int16_t)
SPL_MUL_16_16_RSFT(cross_corr_mod, cross_corr_mod, 16);
1273 totscale = energy_scale - (cross_corr_scale * 2);
1278 scalediff = totscale - totscale_max;
1279 scalediff =
FFMIN(scalediff, 31);
1280 scalediff =
FFMAX(scalediff, -31);
1286 if (scalediff < 0) {
1287 new_crit = ((
int32_t) cross_corr_sg_mod * enery_mod_max) >> (-scalediff);
1288 max_crit = ((
int32_t) cross_corr_sg_mod_max * energy_mod);
1290 new_crit = ((
int32_t) cross_corr_sg_mod * enery_mod_max);
1291 max_crit = ((
int32_t) cross_corr_sg_mod_max * energy_mod) >> scalediff;
1297 if (new_crit > max_crit) {
1298 cross_corr_sg_mod_max = cross_corr_sg_mod;
1299 enery_mod_max = energy_mod;
1300 totscale_max = totscale;
1307 energy += (unsigned)
step * ((*rp_end * *rp_end - *rp_beg * *rp_beg) >>
shifts);
1316 static void hp_output(int16_t *signal,
const int16_t *ba, int16_t *y,
1317 int16_t *x, int16_t
len)
1321 for (
int i = 0;
i <
len;
i++) {
1345 if (
tmp > 268435455) {
1347 }
else if (
tmp < -268435456) {
1354 y[1] = (
tmp - (y[0] * (1 << 16))) >> 1;
1359 int *got_frame_ptr,
AVPacket *avpkt)
1361 const uint8_t *buf = avpkt->
data;
1371 frame->nb_samples =
s->block_samples;
1377 if (
s->frame.start < 1 ||
s->frame.start > 5)
1389 do_plc(
s->plc_residual,
s->plc_lpc, 0,
1393 memcpy(
s->decresidual,
s->plc_residual,
s->block_samples * 2);
1402 if (
s->mode == 20) {
1403 lag =
xcorr_coeff(&
s->decresidual[
s->block_samples-60], &
s->decresidual[
s->block_samples-80],
1415 memcpy(plc_data,
s->decresidual,
s->block_samples * 2);
1420 for (
i = 0;
i <
s->nsub;
i++) {
1430 memcpy(
frame->data[0], plc_data,
s->block_samples * 2);
1433 s->hpimemy,
s->hpimemx,
s->block_samples);
1455 s->mode = avctx->
bit_rate <= 14000 ? 30 : 20;
1464 if (
s->mode == 30) {
1465 s->block_samples = 240;
1471 s->block_samples = 160;