32 #define BITSTREAM_READER_LE
42 #define CNG_RANDOM_SEED 12345
50 60, 0, 0, 2489, 60, 0, 0, 5217,
51 1, 6171, 0, 3953, 0, 10364, 1, 9357,
52 -1, 8843, 1, 9396, 0, 5794, -1, 10816,
53 2, 11606, -2, 12072, 0, 8616, 1, 12170,
54 0, 14440, 0, 7787, -1, 13721, 0, 18205,
55 0, 14471, 0, 15807, 1, 15275, 0, 13480,
56 -1, 18375, -1, 0, 1, 11194, -1, 13010,
57 1, 18836, -2, 20354, 1, 16233, -1, 0,
58 60, 0, 0, 12130, 0, 13385, 1, 17834,
59 1, 20875, 0, 21996, 1, 0, 1, 18277,
60 -1, 21321, 1, 13738, -1, 19094, -1, 20387,
61 -1, 0, 0, 21008, 60, 0, -2, 22807,
62 0, 15900, 1, 0, 0, 17989, -1, 22259,
63 1, 24395, 1, 23138, 0, 23948, 1, 22997,
64 2, 22604, -1, 25942, 0, 26246, 1, 25321,
65 0, 26423, 0, 24061, 0, 27247, 60, 0,
66 -1, 25572, 1, 23918, 1, 25930, 2, 26408,
67 -1, 19049, 1, 27357, -1, 24538, 60, 0,
68 -1, 25093, 0, 28549, 1, 0, 0, 22793,
69 -1, 25659, 0, 29377, 0, 30276, 0, 26198,
70 1, 22521, -1, 28919, 0, 27384, 1, 30162,
71 -1, 0, 0, 24237, -1, 30062, 0, 21763,
72 1, 30917, 60, 0, 0, 31284, 0, 29433,
73 1, 26821, 1, 28655, 0, 31327, 2, 30799,
74 1, 31389, 0, 32322, 1, 31760, -2, 31830,
75 0, 26936, -1, 31180, 1, 30875, 0, 27873,
76 -1, 30429, 1, 31050, 0, 0, 0, 31912,
77 1, 31611, 0, 31565, 0, 25557, 0, 31357,
78 60, 0, 1, 29536, 1, 28985, -1, 26984,
79 -1, 31587, 2, 30836, -2, 31133, 0, 30243,
80 -1, 30742, -1, 32090, 60, 0, 2, 30902,
81 60, 0, 0, 30027, 0, 29042, 60, 0,
82 0, 31756, 0, 24553, 0, 25636, -2, 30501,
83 60, 0, -1, 29617, 0, 30649, 60, 0,
84 0, 29274, 2, 30415, 0, 27480, 0, 31213,
85 -1, 28147, 0, 30600, 1, 31652, 2, 29068,
86 60, 0, 1, 28571, 1, 28730, 1, 31422,
87 0, 28257, 0, 24797, 60, 0, 0, 0,
88 60, 0, 0, 22105, 0, 27852, 60, 0,
89 60, 0, -1, 24214, 0, 24642, 0, 23305,
90 60, 0, 60, 0, 1, 22883, 0, 21601,
91 60, 0, 2, 25650, 60, 0, -2, 31253,
105 {21299, 13844, 8999, 5849, 3802, 2471, 1606, 1044, 679, 441},
107 {24576, 18432, 13824, 10368, 7776, 5832, 4374, 3281, 2460, 1845}
112 static const int cng_filt[4] = { 273, 998, 499, 333 };
114 static const int cng_bseg[3] = { 2048, 18432, 231233 };
122 av_log(avctx,
AV_LOG_ERROR,
"Only mono and stereo are supported (requested channels: %d).\n",
153 int temp, info_bits,
i;
163 if (info_bits == 3) {
173 if (info_bits == 2) {
283 enum Rate cur_rate,
int pitch_lag,
int index)
320 for (
i = 0;
i < 8;
i += 2) {
321 offset = ((cb_pos & 7) << 3) + cb_shift +
i;
322 vector[
offset] = (cb_sign & 1) ? cb_gain : -cb_gain;
334 vector[
i] += beta * vector[
i - lag] >> 15;
350 int pitch_lag,
int length,
int dir)
352 int limit, ccr, lag = 0;
359 limit = pitch_lag + 3;
361 for (
i = pitch_lag - 3;
i <=
limit;
i++) {
364 if (ccr > *ccr_max) {
383 int tgt_eng,
int ccr,
int res_eng)
390 temp1 = tgt_eng * res_eng >> 1;
391 temp2 = ccr * ccr << 1;
394 if (ccr >= res_eng) {
397 ppf->
opt_gain = (ccr << 15) / res_eng *
401 temp1 = (tgt_eng << 15) + (ccr * ppf->
opt_gain << 1);
403 pf_residual =
av_sat_add32(temp1, temp2 + (1 << 15)) >> 16;
405 if (tgt_eng >= pf_residual << 1) {
408 temp1 = (tgt_eng << 14) / pf_residual;
445 int energy[5] = {0, 0, 0, 0, 0};
457 if (!back_lag && !fwd_lag)
475 for (
i = 0;
i < 5;
i++)
476 temp1 =
FFMAX(energy[
i], temp1);
479 for (
i = 0;
i < 5;
i++)
480 energy[
i] = (energy[
i] <<
scale) >> 16;
482 if (fwd_lag && !back_lag) {
485 }
else if (!fwd_lag) {
494 temp1 = energy[4] * ((energy[1] * energy[1] + (1 << 14)) >> 15);
495 temp2 = energy[2] * ((energy[3] * energy[3] + (1 << 14)) >> 15);
496 if (temp1 >= temp2) {
517 int *exc_eng,
int *
scale)
544 temp = best_eng * *exc_eng >> 3;
546 if (
temp < ccr * ccr) {
562 int gain,
int *rseed)
568 for (
i = 0;
i < lag;
i++)
569 out[
i] = vector_ptr[
i - lag] * 3 >> 2;
574 *rseed = (int16_t)(*rseed * 521 + 259);
575 out[
i] = gain * *rseed >> 15;
590 #define iir_filter(fir_coef, iir_coef, src, dest, width)\
593 int res_shift = 16 & ~-(width);\
594 int in_shift = 16 - res_shift;\
596 for (m = 0; m < SUBFRAME_LEN; m++) {\
598 for (n = 1; n <= LPC_ORDER; n++) {\
599 filter -= (fir_coef)[n - 1] * (src)[m - n] -\
600 (iir_coef)[n - 1] * ((dest)[m - n] >> in_shift);\
603 (dest)[m] = av_clipl_int32(((src)[m] * 65536) + (filter * 8) +\
604 (1 << 15)) >> res_shift;\
623 int temp = buf[
i] >> 2;
631 num = num << bits1 >> 1;
637 gain = (num >> 1) / (denom >> 16);
659 int16_t *buf, int16_t *dst)
675 iir_filter(filter_coef[0], filter_coef[1], buf +
i, filter_signal +
i, 1);
697 temp = auto_corr[1] >> 16;
707 (signal_ptr[j - 1] >> 16) *
temp) >> 16;
715 energy = auto_corr[1] >>
temp;
729 else if (gain < 0x20)
730 return gain - 8 << 7;
732 return gain - 20 << 8;
743 int i,
shift, seg, seg2, t,
val, val_add, x, y;
754 }
else if(
shift < -31) {
770 seg2 =
FFMIN(seg, 3);
775 t = seg * 32 + (
val << seg2);
784 t = seg * 32 + (
val << seg2);
787 t = seg * 32 + (
val + 1 << seg2);
789 val = (seg2 - 1) * 16 +
val;
793 t = seg * 32 + (
val - 1 << seg2);
795 val = (seg2 - 1) * 16 +
val;
826 for (j = 0; j < 11; j++) {
827 signs[
i * 11 + j] = ((t & 1) * 2 - 1) * (1 << 14);
837 for (j = 0; j <
pulses[
i]; j++, idx++) {
840 pos[idx] =
tmp[idx2] * 2 + off[
i];
859 t |=
FFABS(vector_ptr[j]);
860 t =
FFMIN(t, 0x7FFF);
871 t = vector_ptr[j] * (1 << -
shift);
877 t = vector_ptr[j] >>
shift;
884 for (j = 0; j < 11; j++)
885 b0 +=
tmp[
pos[(
i / 2) * 11 + j]] * signs[(
i / 2) * 11 + j];
886 b0 =
b0 * 2 * 2979LL + (1 << 29) >> 30;
889 if (
shift * 2 + 3 >= 0)
912 for (j = 0; j < 11; j++) {
913 idx = (
i / 2) * 11 + j;
915 (x * signs[idx] >> 15));
919 memcpy(vector_ptr +
PITCH_MAX, vector_ptr,
929 int *got_frame_ptr,
AVPacket *avpkt)
932 const uint8_t *buf = avpkt->
data;
933 int buf_size = avpkt->
size;
934 int dec_mode = buf[0] & 3;
942 int bad_frame = 0,
i, j,
ret;
947 "Expected %d bytes, got %d - skipping packet\n",
957 for (
int ch = 0; ch <
channels; ch++) {
959 int16_t *audio = p->
audio;
970 out = (int16_t *)
frame->extended_data[ch];
1014 if (
s->postfilter) {
1023 vector_ptr +
i + ppf[j].
index,
1042 memset(
frame->data[0], 0,
1084 if (
s->postfilter) {
1097 #define OFFSET(x) offsetof(G723_1_Context, x)
1098 #define AD AV_OPT_FLAG_AUDIO_PARAM | AV_OPT_FLAG_DECODING_PARAM
1102 { .i64 = 1 }, 0, 1,
AD },