Coverage Report

Created: 2025-09-05 06:55

/src/aac/libAACdec/src/usacdec_acelp.cpp
Line
Count
Source (jump to first uncovered line)
1
/* -----------------------------------------------------------------------------
2
Software License for The Fraunhofer FDK AAC Codec Library for Android
3
4
© Copyright  1995 - 2020 Fraunhofer-Gesellschaft zur Förderung der angewandten
5
Forschung e.V. All rights reserved.
6
7
 1.    INTRODUCTION
8
The Fraunhofer FDK AAC Codec Library for Android ("FDK AAC Codec") is software
9
that implements the MPEG Advanced Audio Coding ("AAC") encoding and decoding
10
scheme for digital audio. This FDK AAC Codec software is intended to be used on
11
a wide variety of Android devices.
12
13
AAC's HE-AAC and HE-AAC v2 versions are regarded as today's most efficient
14
general perceptual audio codecs. AAC-ELD is considered the best-performing
15
full-bandwidth communications codec by independent studies and is widely
16
deployed. AAC has been standardized by ISO and IEC as part of the MPEG
17
specifications.
18
19
Patent licenses for necessary patent claims for the FDK AAC Codec (including
20
those of Fraunhofer) may be obtained through Via Licensing
21
(www.vialicensing.com) or through the respective patent owners individually for
22
the purpose of encoding or decoding bit streams in products that are compliant
23
with the ISO/IEC MPEG audio standards. Please note that most manufacturers of
24
Android devices already license these patent claims through Via Licensing or
25
directly from the patent owners, and therefore FDK AAC Codec software may
26
already be covered under those patent licenses when it is used for those
27
licensed purposes only.
28
29
Commercially-licensed AAC software libraries, including floating-point versions
30
with enhanced sound quality, are also available from Fraunhofer. Users are
31
encouraged to check the Fraunhofer website for additional applications
32
information and documentation.
33
34
2.    COPYRIGHT LICENSE
35
36
Redistribution and use in source and binary forms, with or without modification,
37
are permitted without payment of copyright license fees provided that you
38
satisfy the following conditions:
39
40
You must retain the complete text of this software license in redistributions of
41
the FDK AAC Codec or your modifications thereto in source code form.
42
43
You must retain the complete text of this software license in the documentation
44
and/or other materials provided with redistributions of the FDK AAC Codec or
45
your modifications thereto in binary form. You must make available free of
46
charge copies of the complete source code of the FDK AAC Codec and your
47
modifications thereto to recipients of copies in binary form.
48
49
The name of Fraunhofer may not be used to endorse or promote products derived
50
from this library without prior written permission.
51
52
You may not charge copyright license fees for anyone to use, copy or distribute
53
the FDK AAC Codec software or your modifications thereto.
54
55
Your modified versions of the FDK AAC Codec must carry prominent notices stating
56
that you changed the software and the date of any change. For modified versions
57
of the FDK AAC Codec, the term "Fraunhofer FDK AAC Codec Library for Android"
58
must be replaced by the term "Third-Party Modified Version of the Fraunhofer FDK
59
AAC Codec Library for Android."
60
61
3.    NO PATENT LICENSE
62
63
NO EXPRESS OR IMPLIED LICENSES TO ANY PATENT CLAIMS, including without
64
limitation the patents of Fraunhofer, ARE GRANTED BY THIS SOFTWARE LICENSE.
65
Fraunhofer provides no warranty of patent non-infringement with respect to this
66
software.
67
68
You may use this FDK AAC Codec software or modifications thereto only for
69
purposes that are authorized by appropriate patent licenses.
70
71
4.    DISCLAIMER
72
73
This FDK AAC Codec software is provided by Fraunhofer on behalf of the copyright
74
holders and contributors "AS IS" and WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES,
75
including but not limited to the implied warranties of merchantability and
76
fitness for a particular purpose. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
77
CONTRIBUTORS BE LIABLE for any direct, indirect, incidental, special, exemplary,
78
or consequential damages, including but not limited to procurement of substitute
79
goods or services; loss of use, data, or profits, or business interruption,
80
however caused and on any theory of liability, whether in contract, strict
81
liability, or tort (including negligence), arising in any way out of the use of
82
this software, even if advised of the possibility of such damage.
83
84
5.    CONTACT INFORMATION
85
86
Fraunhofer Institute for Integrated Circuits IIS
87
Attention: Audio and Multimedia Departments - FDK AAC LL
88
Am Wolfsmantel 33
89
91058 Erlangen, Germany
90
91
www.iis.fraunhofer.de/amm
92
amm-info@iis.fraunhofer.de
93
----------------------------------------------------------------------------- */
94
95
/**************************** AAC decoder library ******************************
96
97
   Author(s):   Matthias Hildenbrand
98
99
   Description: USAC ACELP frame decoder
100
101
*******************************************************************************/
102
103
#include "usacdec_acelp.h"
104
105
#include "usacdec_ace_d4t64.h"
106
#include "usacdec_ace_ltp.h"
107
#include "usacdec_rom.h"
108
#include "usacdec_lpc.h"
109
#include "genericStds.h"
110
111
111k
#define PIT_FR2_12k8 128 /* Minimum pitch lag with resolution 1/2      */
112
111k
#define PIT_FR1_12k8 160 /* Minimum pitch lag with resolution 1        */
113
#define TILT_CODE2 \
114
25.1M
  FL2FXCONST_SGL(0.3f * 2.0f) /* ACELP code pre-emphasis factor ( *2 )      */
115
#define PIT_SHARP \
116
2.11M
  FL2FXCONST_SGL(0.85f) /* pitch sharpening factor                    */
117
#define PREEMPH_FAC \
118
50.8M
  FL2FXCONST_SGL(0.68f) /* ACELP synth pre-emphasis factor            */
119
120
247k
#define ACELP_HEADROOM 1
121
247k
#define ACELP_OUTSCALE (MDCT_OUT_HEADROOM - ACELP_HEADROOM)
122
123
/**
124
 * \brief Calculate pre-emphasis (1 - mu z^-1) on input signal.
125
 * \param[in] in pointer to input signal; in[-1] is also needed.
126
 * \param[out] out pointer to output signal.
127
 * \param[in] L length of filtering.
128
 */
129
/* static */
130
52.3k
void E_UTIL_preemph(const FIXP_DBL *in, FIXP_DBL *out, INT L) {
131
52.3k
  int i;
132
133
21.0M
  for (i = 0; i < L; i++) {
134
21.0M
    out[i] = fAddSaturate(in[i], -fMult(PREEMPH_FAC, in[i - 1]));
135
21.0M
  }
136
137
52.3k
  return;
138
52.3k
}
139
140
/**
141
 * \brief Calculate de-emphasis 1/(1 - TILT_CODE z^-1) on innovative codebook
142
 * vector.
143
 * \param[in,out] x innovative codebook vector.
144
 */
145
static void Preemph_code(
146
    FIXP_COD x[] /* (i/o)   : input signal overwritten by the output */
147
399k
) {
148
399k
  int i;
149
399k
  FIXP_DBL L_tmp;
150
151
  /* ARM926: 12 cycles per sample */
152
25.5M
  for (i = L_SUBFR - 1; i > 0; i--) {
153
25.1M
    L_tmp = FX_COD2FX_DBL(x[i]);
154
25.1M
    L_tmp -= fMultDiv2(x[i - 1], TILT_CODE2);
155
25.1M
    x[i] = FX_DBL2FX_COD(L_tmp);
156
25.1M
  }
157
399k
}
158
159
/**
160
 * \brief Apply pitch sharpener to the innovative codebook vector.
161
 * \param[in,out] x innovative codebook vector.
162
 * \param[in] pit_lag decoded pitch lag.
163
 */
164
static void Pit_shrp(
165
    FIXP_COD x[], /* in/out: impulse response (or algebraic code) */
166
    int pit_lag   /* input : pitch lag                            */
167
399k
) {
168
399k
  int i;
169
399k
  FIXP_DBL L_tmp;
170
171
2.51M
  for (i = pit_lag; i < L_SUBFR; i++) {
172
2.11M
    L_tmp = FX_COD2FX_DBL(x[i]);
173
2.11M
    L_tmp += fMult(x[i - pit_lag], PIT_SHARP);
174
2.11M
    x[i] = FX_DBL2FX_COD(L_tmp);
175
2.11M
  }
176
177
399k
  return;
178
399k
}
179
180
  /**
181
   * \brief Calculate Quantized codebook gain, Quantized pitch gain and unbiased
182
   *        Innovative code vector energy.
183
   * \param[in] index index of quantizer.
184
   * \param[in] code innovative code vector with exponent = SF_CODE.
185
   * \param[out] gain_pit Quantized pitch gain g_p with exponent = SF_GAIN_P.
186
   * \param[out] gain_code Quantized codebook gain g_c.
187
   * \param[in] mean_ener mean_ener defined in open-loop (2 bits), exponent = 7.
188
   * \param[out] E_code unbiased innovative code vector energy.
189
   * \param[out] E_code_e exponent of unbiased innovative code vector energy.
190
   */
191
192
391k
#define SF_MEAN_ENER_LG10 9
193
194
/* pow(10.0, {18, 30, 42, 54}/20.0) /(float)(1<<SF_MEAN_ENER_LG10) */
195
static const FIXP_DBL pow_10_mean_energy[4] = {0x01fc5ebd, 0x07e7db92,
196
                                               0x1f791f65, 0x7d4bfba3};
197
198
static void D_gain2_plus(int index, FIXP_COD code[], FIXP_SGL *gain_pit,
199
                         FIXP_DBL *gain_code, int mean_ener_bits, int bfi,
200
                         FIXP_SGL *past_gpit, FIXP_DBL *past_gcode,
201
399k
                         FIXP_DBL *pEner_code, int *pEner_code_e) {
202
399k
  FIXP_DBL Ltmp;
203
399k
  FIXP_DBL gcode0, gcode_inov;
204
399k
  INT gcode0_e, gcode_inov_e;
205
399k
  int i;
206
207
399k
  FIXP_DBL ener_code;
208
399k
  INT ener_code_e;
209
210
  /* ener_code = sum(code[]^2) */
211
399k
  ener_code = FIXP_DBL(0);
212
25.9M
  for (i = 0; i < L_SUBFR; i++) {
213
25.5M
    ener_code += fPow2Div2(code[i]);
214
25.5M
  }
215
216
399k
  ener_code_e = fMax(fNorm(ener_code) - 1, 0);
217
399k
  ener_code <<= ener_code_e;
218
399k
  ener_code_e = 2 * SF_CODE + 1 - ener_code_e;
219
220
  /* export energy of code for calc_period_factor() */
221
399k
  *pEner_code = ener_code;
222
399k
  *pEner_code_e = ener_code_e;
223
224
399k
  ener_code += scaleValue(FL2FXCONST_DBL(0.01f), -ener_code_e);
225
226
  /* ener_code *= 1/L_SUBFR, and make exponent even (because of square root
227
   * below). */
228
399k
  if (ener_code_e & 1) {
229
188k
    ener_code_e -= 5;
230
188k
    ener_code >>= 1;
231
210k
  } else {
232
210k
    ener_code_e -= 6;
233
210k
  }
234
399k
  gcode_inov = invSqrtNorm2(ener_code, &gcode0_e);
235
399k
  gcode_inov_e = gcode0_e - (ener_code_e >> 1);
236
237
399k
  if (bfi) {
238
8.08k
    FIXP_DBL tgcode;
239
8.08k
    FIXP_SGL tgpit;
240
241
8.08k
    tgpit = *past_gpit;
242
243
8.08k
    if (tgpit > FL2FXCONST_SGL(0.95f / (1 << SF_GAIN_P))) {
244
107
      tgpit = FL2FXCONST_SGL(0.95f / (1 << SF_GAIN_P));
245
7.97k
    } else if (tgpit < FL2FXCONST_SGL(0.5f / (1 << SF_GAIN_P))) {
246
6.04k
      tgpit = FL2FXCONST_SGL(0.5f / (1 << SF_GAIN_P));
247
6.04k
    }
248
8.08k
    *gain_pit = tgpit;
249
8.08k
    tgpit = FX_DBL2FX_SGL(fMult(tgpit, FL2FXCONST_DBL(0.95f)));
250
8.08k
    *past_gpit = tgpit;
251
252
8.08k
    tgpit = FL2FXCONST_SGL(1.4f / (1 << SF_GAIN_P)) - tgpit;
253
8.08k
    tgcode = fMult(*past_gcode, tgpit) << SF_GAIN_P;
254
8.08k
    *gain_code = scaleValue(fMult(tgcode, gcode_inov), gcode_inov_e);
255
8.08k
    *past_gcode = tgcode;
256
257
8.08k
    return;
258
8.08k
  }
259
260
  /*-------------- Decode gains ---------------*/
261
  /*
262
   gcode0 = pow(10.0, (float)mean_ener/20.0);
263
   gcode0 = gcode0 / sqrt(ener_code/L_SUBFR);
264
   */
265
391k
  gcode0 = pow_10_mean_energy[mean_ener_bits];
266
391k
  gcode0 = fMultDiv2(gcode0, gcode_inov);
267
391k
  gcode0_e = gcode0_e + SF_MEAN_ENER_LG10 - (ener_code_e >> 1) + 1;
268
269
391k
  i = index << 1;
270
391k
  *gain_pit = t_qua_gain7b[i]; /* adaptive codebook gain */
271
  /* t_qua_gain[ind2p1] : fixed codebook gain correction factor */
272
391k
  Ltmp = fMult(t_qua_gain7b[i + 1], gcode0);
273
391k
  *gain_code = scaleValue(Ltmp, gcode0_e - SF_GAIN_C + SF_QUA_GAIN7B);
274
275
  /* update bad frame handler */
276
391k
  *past_gpit = *gain_pit;
277
278
  /*--------------------------------------------------------
279
    past_gcode  = gain_code/gcode_inov
280
   --------------------------------------------------------*/
281
391k
  {
282
391k
    FIXP_DBL gcode_m;
283
391k
    INT gcode_e;
284
285
391k
    gcode_m = fDivNormHighPrec(Ltmp, gcode_inov, &gcode_e);
286
391k
    gcode_e += (gcode0_e - SF_GAIN_C + SF_QUA_GAIN7B) - (gcode_inov_e);
287
391k
    *past_gcode = scaleValue(gcode_m, gcode_e);
288
391k
  }
289
391k
}
290
291
/**
292
 * \brief Calculate period/voicing factor r_v
293
 * \param[in] exc pitch excitation.
294
 * \param[in] gain_pit gain of pitch g_p.
295
 * \param[in] gain_code gain of code g_c.
296
 * \param[in] gain_code_e exponent of gain of code.
297
 * \param[in] ener_code unbiased innovative code vector energy.
298
 * \param[in] ener_code_e exponent of unbiased innovative code vector energy.
299
 * \return period/voice factor r_v (-1=unvoiced to 1=voiced), exponent SF_PFAC.
300
 */
301
static FIXP_DBL calc_period_factor(FIXP_DBL exc[], FIXP_SGL gain_pit,
302
                                   FIXP_DBL gain_code, FIXP_DBL ener_code,
303
399k
                                   int ener_code_e) {
304
399k
  int ener_exc_e, L_tmp_e, s = 0;
305
399k
  FIXP_DBL ener_exc, L_tmp;
306
399k
  FIXP_DBL period_fac;
307
308
  /* energy of pitch excitation */
309
399k
  ener_exc = (FIXP_DBL)0;
310
25.9M
  for (int i = 0; i < L_SUBFR; i++) {
311
25.5M
    ener_exc += fPow2Div2(exc[i]) >> s;
312
25.5M
    if (ener_exc >= FL2FXCONST_DBL(0.5f)) {
313
111k
      ener_exc >>= 1;
314
111k
      s++;
315
111k
    }
316
25.5M
  }
317
318
399k
  ener_exc_e = fNorm(ener_exc);
319
399k
  ener_exc = fMult(ener_exc << ener_exc_e, fPow2(gain_pit));
320
399k
  if (ener_exc != (FIXP_DBL)0) {
321
364k
    ener_exc_e = 2 * SF_EXC + 1 + 2 * SF_GAIN_P - ener_exc_e + s;
322
364k
  } else {
323
34.9k
    ener_exc_e = 0;
324
34.9k
  }
325
326
  /* energy of innovative code excitation */
327
  /* L_tmp = ener_code * gain_code*gain_code; */
328
399k
  L_tmp_e = fNorm(gain_code);
329
399k
  L_tmp = fPow2(gain_code << L_tmp_e);
330
399k
  L_tmp = fMult(ener_code, L_tmp);
331
399k
  L_tmp_e = 2 * SF_GAIN_C + ener_code_e - 2 * L_tmp_e;
332
333
  /* Find common exponent */
334
399k
  {
335
399k
    FIXP_DBL num, den;
336
399k
    int exp_diff;
337
338
399k
    exp_diff = ener_exc_e - L_tmp_e;
339
399k
    if (exp_diff >= 0) {
340
251k
      ener_exc >>= 1;
341
251k
      if (exp_diff <= DFRACT_BITS - 2) {
342
251k
        L_tmp >>= exp_diff + 1;
343
251k
      } else {
344
221
        L_tmp = (FIXP_DBL)0;
345
221
      }
346
251k
      den = ener_exc + L_tmp;
347
251k
      if (ener_exc_e < DFRACT_BITS - 1) {
348
160k
        den += scaleValue(FL2FXCONST_DBL(0.01f), -ener_exc_e - 1);
349
160k
      }
350
251k
    } else {
351
147k
      if (exp_diff >= -(DFRACT_BITS - 2)) {
352
146k
        ener_exc >>= 1 - exp_diff;
353
146k
      } else {
354
1.26k
        ener_exc = (FIXP_DBL)0;
355
1.26k
      }
356
147k
      L_tmp >>= 1;
357
147k
      den = ener_exc + L_tmp;
358
147k
      if (L_tmp_e < DFRACT_BITS - 1) {
359
140k
        den += scaleValue(FL2FXCONST_DBL(0.01f), -L_tmp_e - 1);
360
140k
      }
361
147k
    }
362
399k
    num = (ener_exc - L_tmp);
363
399k
    num >>= SF_PFAC;
364
365
399k
    if (den > (FIXP_DBL)0) {
366
399k
      if (ener_exc > L_tmp) {
367
170k
        period_fac = schur_div(num, den, 16);
368
229k
      } else {
369
229k
        period_fac = -schur_div(-num, den, 16);
370
229k
      }
371
399k
    } else {
372
321
      period_fac = (FIXP_DBL)MAXVAL_DBL;
373
321
    }
374
399k
  }
375
376
  /* exponent = SF_PFAC */
377
399k
  return period_fac;
378
399k
}
379
380
/*------------------------------------------------------------*
381
 * noise enhancer                                             *
382
 * ~~~~~~~~~~~~~~                                             *
383
 * - Enhance excitation on noise. (modify gain of code)       *
384
 *   If signal is noisy and LPC filter is stable, move gain   *
385
 *   of code 1.5 dB toward gain of code threshold.            *
386
 *   This decrease by 3 dB noise energy variation.            *
387
 *------------------------------------------------------------*/
388
/**
389
 * \brief Enhance excitation on noise. (modify gain of code)
390
 * \param[in] gain_code Quantized codebook gain g_c, exponent = SF_GAIN_C.
391
 * \param[in] period_fac periodicity factor, exponent = SF_PFAC.
392
 * \param[in] stab_fac stability factor, exponent = SF_STAB.
393
 * \param[in,out] p_gc_threshold modified gain of previous subframe.
394
 * \return gain_code smoothed gain of code g_sc, exponent = SF_GAIN_C.
395
 */
396
static FIXP_DBL
397
noise_enhancer(/* (o) : smoothed gain g_sc                     SF_GAIN_C */
398
               FIXP_DBL gain_code, /* (i) : Quantized codebook gain SF_GAIN_C */
399
               FIXP_DBL period_fac, /* (i) : periodicity factor (-1=unvoiced to
400
                                       1=voiced), SF_PFAC */
401
               FIXP_SGL stab_fac,   /* (i) : stability factor (0 <= ... < 1.0)
402
                                       SF_STAB   */
403
               FIXP_DBL
404
                   *p_gc_threshold) /* (io): gain of code threshold SF_GAIN_C */
405
399k
{
406
399k
  FIXP_DBL fac, L_tmp, gc_thres;
407
408
399k
  gc_thres = *p_gc_threshold;
409
410
399k
  L_tmp = gain_code;
411
399k
  if (L_tmp < gc_thres) {
412
173k
    L_tmp += fMultDiv2(gain_code,
413
173k
                       FL2FXCONST_SGL(2.0 * 0.19f)); /* +1.5dB => *(1.0+0.19) */
414
173k
    if (L_tmp > gc_thres) {
415
16.3k
      L_tmp = gc_thres;
416
16.3k
    }
417
226k
  } else {
418
226k
    L_tmp = fMult(gain_code,
419
226k
                  FL2FXCONST_SGL(1.0f / 1.19f)); /* -1.5dB => *10^(-1.5/20) */
420
226k
    if (L_tmp < gc_thres) {
421
19.4k
      L_tmp = gc_thres;
422
19.4k
    }
423
226k
  }
424
399k
  *p_gc_threshold = L_tmp;
425
426
  /* voicing factor     lambda = 0.5*(1-period_fac) */
427
  /* gain smoothing factor S_m = lambda*stab_fac  (=fac)
428
                               = 0.5(stab_fac - stab_fac * period_fac) */
429
399k
  fac = (FX_SGL2FX_DBL(stab_fac) >> (SF_PFAC + 1)) -
430
399k
        fMultDiv2(stab_fac, period_fac);
431
  /* fac_e = SF_PFAC + SF_STAB */
432
399k
  FDK_ASSERT(fac >= (FIXP_DBL)0);
433
434
  /* gain_code = (float)((fac*tmp) + ((1.0-fac)*gain_code)); */
435
399k
  gain_code = fMult(fac, L_tmp) -
436
399k
              fMult(FL2FXCONST_DBL(-1.0f / (1 << (SF_PFAC + SF_STAB))) + fac,
437
399k
                    gain_code);
438
399k
  gain_code <<= (SF_PFAC + SF_STAB);
439
440
399k
  return gain_code;
441
399k
}
442
443
/**
444
 * \brief Update adaptive codebook u'(n) (exc)
445
 *        Enhance pitch of c(n) and build post-processed excitation u(n) (exc2)
446
 * \param[in] code innovative codevector c(n), exponent = SF_CODE.
447
 * \param[in,out] exc filtered adaptive codebook v(n), exponent = SF_EXC.
448
 * \param[in] gain_pit adaptive codebook gain, exponent = SF_GAIN_P.
449
 * \param[in] gain_code innovative codebook gain g_c, exponent = SF_GAIN_C.
450
 * \param[in] gain_code_smoothed smoothed innov. codebook gain g_sc, exponent =
451
 * SF_GAIN_C.
452
 * \param[in] period_fac periodicity factor r_v, exponent = SF_PFAC.
453
 * \param[out] exc2 post-processed excitation u(n), exponent = SF_EXC.
454
 */
455
void BuildAdaptiveExcitation(
456
    FIXP_COD code[],    /* (i) : algebraic codevector c(n)             Q9  */
457
    FIXP_DBL exc[],     /* (io): filtered adaptive codebook v(n)       Q15 */
458
    FIXP_SGL gain_pit,  /* (i) : adaptive codebook gain g_p            Q14 */
459
    FIXP_DBL gain_code, /* (i) : innovative codebook gain g_c          Q16 */
460
    FIXP_DBL gain_code_smoothed, /* (i) : smoothed innov. codebook gain g_sc
461
                                    Q16 */
462
    FIXP_DBL period_fac, /* (i) : periodicity factor r_v                Q15 */
463
    FIXP_DBL exc2[]      /* (o) : post-processed excitation u(n)        Q15 */
464
399k
) {
465
/* Note: code[L_SUBFR] and exc2[L_SUBFR] share the same memory!
466
         If exc2[i] is written, code[i] will be destroyed!
467
*/
468
127M
#define SF_HEADROOM (1)
469
51.1M
#define SF (SF_CODE + SF_GAIN_C + 1 - SF_EXC - SF_HEADROOM)
470
25.5M
#define SF_GAIN_P2 (SF_GAIN_P - SF_HEADROOM)
471
472
399k
  int i;
473
399k
  FIXP_DBL tmp, cpe, code_smooth_prev, code_smooth;
474
475
399k
  FIXP_COD code_i;
476
399k
  FIXP_DBL cpe_code_smooth, cpe_code_smooth_prev;
477
478
  /* cpe = (1+r_v)/8 * 2 ; ( SF = -1) */
479
399k
  cpe = (period_fac >> (2 - SF_PFAC)) + FL2FXCONST_DBL(0.25f);
480
481
  /* u'(n) */
482
399k
  tmp = fMultDiv2(*exc, gain_pit) << (SF_GAIN_P2 + 1); /* v(0)*g_p */
483
399k
  *exc++ = (tmp + (fMultDiv2(code[0], gain_code) << SF)) << SF_HEADROOM;
484
485
  /* u(n) */
486
399k
  code_smooth_prev = fMultDiv2(*code++, gain_code_smoothed)
487
399k
                     << SF; /* c(0) * g_sc */
488
399k
  code_i = *code++;
489
399k
  code_smooth = fMultDiv2(code_i, gain_code_smoothed) << SF; /* c(1) * g_sc */
490
399k
  tmp += code_smooth_prev; /* tmp = v(0)*g_p + c(0)*g_sc */
491
399k
  cpe_code_smooth = fMultDiv2(cpe, code_smooth);
492
399k
  *exc2++ = (tmp - cpe_code_smooth) << SF_HEADROOM;
493
399k
  cpe_code_smooth_prev = fMultDiv2(cpe, code_smooth_prev);
494
495
399k
  i = L_SUBFR - 2;
496
399k
  do /* ARM926: 22 cycles per iteration */
497
24.7M
  {
498
    /* u'(n) */
499
24.7M
    tmp = fMultDiv2(*exc, gain_pit) << (SF_GAIN_P2 + 1);
500
24.7M
    *exc++ = (tmp + (fMultDiv2(code_i, gain_code) << SF)) << SF_HEADROOM;
501
    /* u(n) */
502
24.7M
    tmp += code_smooth; /* += g_sc * c(i) */
503
24.7M
    tmp -= cpe_code_smooth_prev;
504
24.7M
    cpe_code_smooth_prev = cpe_code_smooth;
505
24.7M
    code_i = *code++;
506
24.7M
    code_smooth = fMultDiv2(code_i, gain_code_smoothed) << SF;
507
24.7M
    cpe_code_smooth = fMultDiv2(cpe, code_smooth);
508
24.7M
    *exc2++ = (tmp - cpe_code_smooth)
509
24.7M
              << SF_HEADROOM; /* tmp - c_pe * g_sc * c(i+1) */
510
24.7M
  } while (--i != 0);
511
512
  /* u'(n) */
513
399k
  tmp = fMultDiv2(*exc, gain_pit) << (SF_GAIN_P2 + 1);
514
399k
  *exc = (tmp + (fMultDiv2(code_i, gain_code) << SF)) << SF_HEADROOM;
515
  /* u(n) */
516
399k
  tmp += code_smooth;
517
399k
  tmp -= cpe_code_smooth_prev;
518
399k
  *exc2++ = tmp << SF_HEADROOM;
519
520
399k
  return;
521
399k
}
522
523
/**
524
 * \brief Interpolate LPC vector in LSP domain for current subframe and convert
525
 * to LP domain
526
 * \param[in] lsp_old LPC vector (LSP domain) corresponding to the beginning of
527
 * current ACELP frame.
528
 * \param[in] lsp_new LPC vector (LSP domain) corresponding to the end of
529
 * current ACELP frame.
530
 * \param[in] subfr_nr number of current ACELP subframe 0..3.
531
 * \param[in] nb_subfr total number of ACELP subframes in this frame.
532
 * \param[out] A LP filter coefficients for current ACELP subframe, exponent =
533
 * SF_A_COEFFS.
534
 */
535
/* static */
536
void int_lpc_acelp(
537
    const FIXP_LPC lsp_old[], /* input : LSPs from past frame              */
538
    const FIXP_LPC lsp_new[], /* input : LSPs from present frame           */
539
    int subfr_nr, int nb_subfr,
540
    FIXP_LPC
541
        A[], /* output: interpolated LP coefficients for current subframe */
542
405k
    INT *A_exp) {
543
405k
  int i;
544
405k
  FIXP_LPC lsp_interpol[M_LP_FILTER_ORDER];
545
405k
  FIXP_SGL fac_old, fac_new;
546
547
405k
  FDK_ASSERT((nb_subfr == 3) || (nb_subfr == 4));
548
549
405k
  fac_old = lsp_interpol_factor[nb_subfr & 0x1][(nb_subfr - 1) - subfr_nr];
550
405k
  fac_new = lsp_interpol_factor[nb_subfr & 0x1][subfr_nr];
551
6.89M
  for (i = 0; i < M_LP_FILTER_ORDER; i++) {
552
6.48M
    lsp_interpol[i] = FX_DBL2FX_LPC(
553
6.48M
        (fMultDiv2(lsp_old[i], fac_old) + fMultDiv2(lsp_new[i], fac_new)) << 1);
554
6.48M
  }
555
556
405k
  E_LPC_f_lsp_a_conversion(lsp_interpol, A, A_exp);
557
558
405k
  return;
559
405k
}
560
561
/**
562
 * \brief Perform LP synthesis by filtering the post-processed excitation u(n)
563
 *        through the LP synthesis filter 1/A(z)
564
 * \param[in] a LP filter coefficients, exponent = SF_A_COEFFS.
565
 * \param[in] length length of input/output signal.
566
 * \param[in] x post-processed excitation u(n).
567
 * \param[in,out] y LP synthesis signal and filter memory
568
 * y[-M_LP_FILTER_ORDER..-1].
569
 */
570
571
/* static */
572
void Syn_filt(const FIXP_LPC a[], /* (i) : a[m] prediction coefficients Q12 */
573
              const INT a_exp,
574
              INT length,   /* (i) : length of input/output signal (64|128)   */
575
              FIXP_DBL x[], /* (i) : input signal Qx  */
576
              FIXP_DBL y[]  /* (i/o) : filter states / output signal  Qx-s*/
577
453k
) {
578
453k
  int i, j;
579
453k
  FIXP_DBL L_tmp;
580
581
30.7M
  for (i = 0; i < length; i++) {
582
30.2M
    L_tmp = (FIXP_DBL)0;
583
584
514M
    for (j = 0; j < M_LP_FILTER_ORDER; j++) {
585
484M
      L_tmp -= fMultDiv2(a[j], y[i - (j + 1)]) >> (LP_FILTER_SCALE - 1);
586
484M
    }
587
588
30.2M
    L_tmp = scaleValue(L_tmp, a_exp + LP_FILTER_SCALE);
589
30.2M
    y[i] = fAddSaturate(L_tmp, x[i]);
590
30.2M
  }
591
592
453k
  return;
593
453k
}
594
595
/**
596
 * \brief Calculate de-emphasis 1/(1 - mu z^-1) on input signal.
597
 * \param[in] x input signal.
598
 * \param[out] y output signal.
599
 * \param[in] L length of signal.
600
 * \param[in,out] mem memory (signal[-1]).
601
 */
602
/* static */
603
159k
void Deemph(FIXP_DBL *x, FIXP_DBL *y, int L, FIXP_DBL *mem) {
604
159k
  int i;
605
159k
  FIXP_DBL yi = *mem;
606
607
30.0M
  for (i = 0; i < L; i++) {
608
29.8M
    FIXP_DBL xi = x[i] >> 1;
609
29.8M
    xi = fMultAddDiv2(xi, PREEMPH_FAC, yi);
610
29.8M
    yi = SATURATE_LEFT_SHIFT(xi, 1, 32);
611
29.8M
    y[i] = yi;
612
29.8M
  }
613
159k
  *mem = yi;
614
159k
  return;
615
159k
}
616
617
/**
618
 * \brief Compute the LP residual by filtering the input speech through the
619
 * analysis filter A(z).
620
 * \param[in] a LP filter coefficients, exponent = SF_A_COEFFS
621
 * \param[in] x input signal (note that values x[-m..-1] are needed), exponent =
622
 * SF_SYNTH
623
 * \param[out] y output signal (residual), exponent = SF_EXC
624
 * \param[in] l length of filtering
625
 */
626
/* static */
627
void E_UTIL_residu(const FIXP_LPC *a, const INT a_exp, FIXP_DBL *x, FIXP_DBL *y,
628
91.7k
                   INT l) {
629
91.7k
  FIXP_DBL s;
630
91.7k
  INT i, j;
631
632
  /* (note that values x[-m..-1] are needed) */
633
18.8M
  for (i = 0; i < l; i++) {
634
18.7M
    s = (FIXP_DBL)0;
635
636
318M
    for (j = 0; j < M_LP_FILTER_ORDER; j++) {
637
300M
      s += fMultDiv2(a[j], x[i - j - 1]) >> (LP_FILTER_SCALE - 1);
638
300M
    }
639
640
18.7M
    s = scaleValue(s, a_exp + LP_FILTER_SCALE);
641
18.7M
    y[i] = fAddSaturate(s, x[i]);
642
18.7M
  }
643
644
91.7k
  return;
645
91.7k
}
646
647
/* use to map subfr number to number of bits used for acb_index */
648
static const UCHAR num_acb_idx_bits_table[2][NB_SUBFR] = {
649
    {9, 6, 9, 6}, /* coreCoderFrameLength == 1024 */
650
    {9, 6, 6, 0}  /* coreCoderFrameLength == 768  */
651
};
652
653
static int DecodePitchLag(HANDLE_FDK_BITSTREAM hBs,
654
                          const UCHAR num_acb_idx_bits,
655
                          const int PIT_MIN, /* TMIN */
656
                          const int PIT_FR2, /* TFR2 */
657
                          const int PIT_FR1, /* TFR1 */
658
                          const int PIT_MAX, /* TMAX */
659
400k
                          int *pT0, int *pT0_frac, int *pT0_min, int *pT0_max) {
660
400k
  int acb_idx;
661
400k
  int error = 0;
662
400k
  int T0, T0_frac;
663
664
400k
  FDK_ASSERT((num_acb_idx_bits == 9) || (num_acb_idx_bits == 6));
665
666
400k
  acb_idx = FDKreadBits(hBs, num_acb_idx_bits);
667
668
400k
  if (num_acb_idx_bits == 6) {
669
    /* When the pitch value is encoded on 6 bits, a pitch resolution of 1/4 is
670
       always used in the range [T1-8, T1+7.75], where T1 is nearest integer to
671
       the fractional pitch lag of the previous subframe.
672
    */
673
223k
    T0 = *pT0_min + acb_idx / 4;
674
223k
    T0_frac = acb_idx & 0x3;
675
223k
  } else { /* num_acb_idx_bits == 9 */
676
    /* When the pitch value is encoded on 9 bits, a fractional pitch delay is
677
       used with resolutions 0.25 in the range [TMIN, TFR2-0.25], resolutions
678
       0.5 in the range [TFR2, TFR1-0.5], and integers only in the range [TFR1,
679
       TMAX]. NOTE: for small sampling rates TMAX can get smaller than TFR1.
680
    */
681
176k
    int T0_min, T0_max;
682
683
176k
    if (acb_idx < (PIT_FR2 - PIT_MIN) * 4) {
684
      /* first interval with 0.25 pitch resolution */
685
105k
      T0 = PIT_MIN + (acb_idx / 4);
686
105k
      T0_frac = acb_idx & 0x3;
687
105k
    } else if (acb_idx < ((PIT_FR2 - PIT_MIN) * 4 + (PIT_FR1 - PIT_FR2) * 2)) {
688
      /* second interval with 0.5 pitch resolution */
689
24.6k
      acb_idx -= (PIT_FR2 - PIT_MIN) * 4;
690
24.6k
      T0 = PIT_FR2 + (acb_idx / 2);
691
24.6k
      T0_frac = (acb_idx & 0x1) * 2;
692
46.0k
    } else {
693
      /* third interval with 1.0 pitch resolution */
694
46.0k
      T0 = acb_idx + PIT_FR1 - ((PIT_FR2 - PIT_MIN) * 4) -
695
46.0k
           ((PIT_FR1 - PIT_FR2) * 2);
696
46.0k
      T0_frac = 0;
697
46.0k
    }
698
    /* find T0_min and T0_max for subframe 1 or 3 */
699
176k
    T0_min = T0 - 8;
700
176k
    if (T0_min < PIT_MIN) {
701
55.9k
      T0_min = PIT_MIN;
702
55.9k
    }
703
176k
    T0_max = T0_min + 15;
704
176k
    if (T0_max > PIT_MAX) {
705
4.71k
      T0_max = PIT_MAX;
706
4.71k
      T0_min = T0_max - 15;
707
4.71k
    }
708
176k
    *pT0_min = T0_min;
709
176k
    *pT0_max = T0_max;
710
176k
  }
711
400k
  *pT0 = T0;
712
400k
  *pT0_frac = T0_frac;
713
714
400k
  return error;
715
400k
}
716
static void ConcealPitchLag(CAcelpStaticMem *acelp_mem, const int PIT_MAX,
717
8.08k
                            int *pT0, int *pT0_frac) {
718
8.08k
  USHORT *pold_T0 = &acelp_mem->old_T0;
719
8.08k
  UCHAR *pold_T0_frac = &acelp_mem->old_T0_frac;
720
721
8.08k
  if ((int)*pold_T0 >= PIT_MAX) {
722
40
    *pold_T0 = (USHORT)(PIT_MAX - 5);
723
40
  }
724
8.08k
  *pT0 = (int)*pold_T0;
725
8.08k
  *pT0_frac = (int)*pold_T0_frac;
726
8.08k
}
727
728
static UCHAR tab_coremode2nbits[8] = {20, 28, 36, 44, 52, 64, 12, 16};
729
730
503k
static int MapCoreMode2NBits(int core_mode) {
731
503k
  return (int)tab_coremode2nbits[core_mode];
732
503k
}
733
734
void CLpd_AcelpDecode(CAcelpStaticMem *acelp_mem, INT i_offset,
735
                      const FIXP_LPC lsp_old[M_LP_FILTER_ORDER],
736
                      const FIXP_LPC lsp_new[M_LP_FILTER_ORDER],
737
                      FIXP_SGL stab_fac, CAcelpChannelData *pAcelpData,
738
                      INT numLostSubframes, int lastLpcLost, int frameCnt,
739
                      FIXP_DBL synth[], int pT[], FIXP_DBL *pit_gain,
740
111k
                      INT coreCoderFrameLength) {
741
111k
  int i_subfr, subfr_nr, l_div, T;
742
111k
  int T0 = -1, T0_frac = -1; /* mark invalid */
743
744
111k
  int pit_gain_index = 0;
745
746
111k
  const int PIT_MAX = PIT_MAX_12k8 + (6 * i_offset); /* maximum pitch lag */
747
748
111k
  FIXP_COD *code;
749
111k
  FIXP_DBL *exc2;
750
111k
  FIXP_DBL *syn;
751
111k
  FIXP_DBL *exc;
752
111k
  FIXP_LPC A[M_LP_FILTER_ORDER];
753
111k
  INT A_exp;
754
755
111k
  FIXP_DBL period_fac;
756
111k
  FIXP_SGL gain_pit;
757
111k
  FIXP_DBL gain_code, gain_code_smooth, Ener_code;
758
111k
  int Ener_code_e;
759
111k
  int n;
760
111k
  int bfi = (numLostSubframes > 0) ? 1 : 0;
761
762
111k
  C_ALLOC_SCRATCH_START(
763
111k
      exc_buf, FIXP_DBL,
764
111k
      PIT_MAX_MAX + L_INTERPOL + L_DIV + 1); /* 411 + 17 + 256 + 1 = 685 */
765
111k
  C_ALLOC_SCRATCH_START(syn_buf, FIXP_DBL,
766
111k
                        M_LP_FILTER_ORDER + L_DIV); /* 16 + 256 = 272 */
767
  /* use same memory for code[L_SUBFR] and exc2[L_SUBFR] */
768
111k
  C_ALLOC_SCRATCH_START(tmp_buf, FIXP_DBL, L_SUBFR); /* 64 */
769
  /* make sure they don't overlap if they are accessed alternatingly in
770
   * BuildAdaptiveExcitation() */
771
111k
#if (COD_BITS == FRACT_BITS)
772
111k
  code = (FIXP_COD *)(tmp_buf + L_SUBFR / 2);
773
#elif (COD_BITS == DFRACT_BITS)
774
  code = (FIXP_COD *)tmp_buf;
775
#endif
776
111k
  exc2 = (FIXP_DBL *)tmp_buf;
777
778
111k
  syn = syn_buf + M_LP_FILTER_ORDER;
779
111k
  exc = exc_buf + PIT_MAX_MAX + L_INTERPOL;
780
781
111k
  FDKmemcpy(syn_buf, acelp_mem->old_syn_mem,
782
111k
            M_LP_FILTER_ORDER * sizeof(FIXP_DBL));
783
111k
  FDKmemcpy(exc_buf, acelp_mem->old_exc_mem,
784
111k
            (PIT_MAX_MAX + L_INTERPOL) * sizeof(FIXP_DBL));
785
786
111k
  FDKmemclear(exc_buf + (PIT_MAX_MAX + L_INTERPOL),
787
111k
              (L_DIV + 1) * sizeof(FIXP_DBL));
788
789
111k
  l_div = coreCoderFrameLength / NB_DIV;
790
791
511k
  for (i_subfr = 0, subfr_nr = 0; i_subfr < l_div;
792
399k
       i_subfr += L_SUBFR, subfr_nr++) {
793
    /*-------------------------------------------------*
794
     * - Decode pitch lag (T0 and T0_frac)             *
795
     *-------------------------------------------------*/
796
399k
    if (bfi) {
797
8.08k
      ConcealPitchLag(acelp_mem, PIT_MAX, &T0, &T0_frac);
798
391k
    } else {
799
391k
      T0 = (int)pAcelpData->T0[subfr_nr];
800
391k
      T0_frac = (int)pAcelpData->T0_frac[subfr_nr];
801
391k
    }
802
803
    /*-------------------------------------------------*
804
     * - Find the pitch gain, the interpolation filter *
805
     *   and the adaptive codebook vector.             *
806
     *-------------------------------------------------*/
807
399k
    Pred_lt4(&exc[i_subfr], T0, T0_frac);
808
809
399k
    if ((!bfi && pAcelpData->ltp_filtering_flag[subfr_nr] == 0) ||
810
399k
        (bfi && numLostSubframes == 1 && stab_fac < FL2FXCONST_SGL(0.25f))) {
811
      /* find pitch excitation with lp filter: v'(n) => v(n) */
812
258k
      Pred_lt4_postfilter(&exc[i_subfr]);
813
258k
    }
814
815
    /*-------------------------------------------------------*
816
     * - Decode innovative codebook.                         *
817
     * - Add the fixed-gain pitch contribution to code[].    *
818
     *-------------------------------------------------------*/
819
399k
    if (bfi) {
820
525k
      for (n = 0; n < L_SUBFR; n++) {
821
517k
        code[n] =
822
517k
            FX_SGL2FX_COD((FIXP_SGL)E_UTIL_random(&acelp_mem->seed_ace)) >> 4;
823
517k
      }
824
391k
    } else {
825
391k
      int nbits = MapCoreMode2NBits((int)pAcelpData->acelp_core_mode);
826
391k
      D_ACELP_decode_4t64(pAcelpData->icb_index[subfr_nr], nbits, &code[0]);
827
391k
    }
828
829
399k
    T = T0;
830
399k
    if (T0_frac > 2) {
831
55.2k
      T += 1;
832
55.2k
    }
833
834
399k
    Preemph_code(code);
835
399k
    Pit_shrp(code, T);
836
837
    /* Output pitch lag for bass post-filter */
838
399k
    if (T > PIT_MAX) {
839
2.16k
      pT[subfr_nr] = PIT_MAX;
840
397k
    } else {
841
397k
      pT[subfr_nr] = T;
842
397k
    }
843
399k
    D_gain2_plus(
844
399k
        pAcelpData->gains[subfr_nr],
845
399k
        code,       /* (i)  : Innovative code vector, exponent = SF_CODE */
846
399k
        &gain_pit,  /* (o)  : Quantized pitch gain, exponent = SF_GAIN_P */
847
399k
        &gain_code, /* (o)  : Quantized codebook gain                    */
848
399k
        pAcelpData
849
399k
            ->mean_energy, /* (i)  : mean_ener defined in open-loop (2 bits) */
850
399k
        bfi, &acelp_mem->past_gpit, &acelp_mem->past_gcode,
851
399k
        &Ener_code,    /* (o)  : Innovative code vector energy              */
852
399k
        &Ener_code_e); /* (o)  : Innovative code vector energy exponent     */
853
854
399k
    pit_gain[pit_gain_index++] = FX_SGL2FX_DBL(gain_pit);
855
856
    /* calc periodicity factor r_v */
857
399k
    period_fac =
858
399k
        calc_period_factor(/* (o) : factor (-1=unvoiced to 1=voiced)    */
859
399k
                           &exc[i_subfr], /* (i) : pitch excitation, exponent =
860
                                             SF_EXC */
861
399k
                           gain_pit,      /* (i) : gain of pitch, exponent =
862
                                             SF_GAIN_P */
863
399k
                           gain_code,     /* (i) : gain of code     */
864
399k
                           Ener_code,     /* (i) : Energy of code[]     */
865
399k
                           Ener_code_e);  /* (i) : Exponent of energy of code[]
866
                                           */
867
868
399k
    if (lastLpcLost && frameCnt == 0) {
869
516
      if (gain_pit > FL2FXCONST_SGL(1.0f / (1 << SF_GAIN_P))) {
870
10
        gain_pit = FL2FXCONST_SGL(1.0f / (1 << SF_GAIN_P));
871
10
      }
872
516
    }
873
874
399k
    gain_code_smooth =
875
399k
        noise_enhancer(/* (o) : smoothed gain g_sc exponent = SF_GAIN_C */
876
399k
                       gain_code,  /* (i) : Quantized codebook gain  */
877
399k
                       period_fac, /* (i) : periodicity factor (-1=unvoiced to
878
                                      1=voiced)  */
879
399k
                       stab_fac,   /* (i) : stability factor (0 <= ... < 1),
880
                                      exponent = 1 */
881
399k
                       &acelp_mem->gc_threshold);
882
883
    /* Compute adaptive codebook update u'(n), pitch enhancement c'(n) and
884
     * post-processed excitation u(n). */
885
399k
    BuildAdaptiveExcitation(code, exc + i_subfr, gain_pit, gain_code,
886
399k
                            gain_code_smooth, period_fac, exc2);
887
888
    /* Interpolate filter coeffs for current subframe in lsp domain and convert
889
     * to LP domain */
890
399k
    int_lpc_acelp(lsp_old,  /* input : LSPs from past frame              */
891
399k
                  lsp_new,  /* input : LSPs from present frame           */
892
399k
                  subfr_nr, /* input : ACELP subframe index              */
893
399k
                  coreCoderFrameLength / L_DIV,
894
399k
                  A, /* output: LP coefficients of this subframe  */
895
399k
                  &A_exp);
896
897
399k
    Syn_filt(A, /* (i) : a[m] prediction coefficients               */
898
399k
             A_exp, L_SUBFR, /* (i) : length */
899
399k
             exc2, /* (i) : input signal                               */
900
399k
             &syn[i_subfr] /* (i/o) : filter states / output signal */
901
399k
    );
902
903
399k
  } /* end of subframe loop */
904
905
  /* update pitch value for bfi procedure */
906
111k
  acelp_mem->old_T0_frac = T0_frac;
907
111k
  acelp_mem->old_T0 = T0;
908
909
  /* save old excitation and old synthesis memory for next ACELP frame */
910
111k
  FDKmemcpy(acelp_mem->old_exc_mem, exc + l_div - (PIT_MAX_MAX + L_INTERPOL),
911
111k
            sizeof(FIXP_DBL) * (PIT_MAX_MAX + L_INTERPOL));
912
111k
  FDKmemcpy(acelp_mem->old_syn_mem, syn_buf + l_div,
913
111k
            sizeof(FIXP_DBL) * M_LP_FILTER_ORDER);
914
915
111k
  Deemph(syn, synth, l_div,
916
111k
         &acelp_mem->de_emph_mem); /* ref soft: mem = synth[-1] */
917
918
111k
  scaleValues(synth, l_div, -ACELP_OUTSCALE);
919
111k
  acelp_mem->deemph_mem_wsyn = acelp_mem->de_emph_mem;
920
921
111k
  C_ALLOC_SCRATCH_END(tmp_buf, FIXP_DBL, L_SUBFR);
922
111k
  C_ALLOC_SCRATCH_END(syn_buf, FIXP_DBL, M_LP_FILTER_ORDER + L_DIV);
923
111k
  C_ALLOC_SCRATCH_END(exc_buf, FIXP_DBL, PIT_MAX_MAX + L_INTERPOL + L_DIV + 1);
924
111k
  return;
925
111k
}
926
927
32.4k
void CLpd_AcelpReset(CAcelpStaticMem *acelp) {
928
32.4k
  acelp->gc_threshold = (FIXP_DBL)0;
929
930
32.4k
  acelp->past_gpit = (FIXP_SGL)0;
931
32.4k
  acelp->past_gcode = (FIXP_DBL)0;
932
32.4k
  acelp->old_T0 = 64;
933
32.4k
  acelp->old_T0_frac = 0;
934
32.4k
  acelp->deemph_mem_wsyn = (FIXP_DBL)0;
935
32.4k
  acelp->wsyn_rms = (FIXP_DBL)0;
936
32.4k
  acelp->seed_ace = 0;
937
32.4k
}
938
939
/* TCX time domain concealment */
940
/*   Compare to figure 13a on page 54 in 3GPP TS 26.290 */
941
void CLpd_TcxTDConceal(CAcelpStaticMem *acelp_mem, SHORT *pitch,
942
                       const FIXP_LPC lsp_old[M_LP_FILTER_ORDER],
943
                       const FIXP_LPC lsp_new[M_LP_FILTER_ORDER],
944
                       const FIXP_SGL stab_fac, INT nLostSf, FIXP_DBL synth[],
945
1.64k
                       INT coreCoderFrameLength, UCHAR last_tcx_noise_factor) {
946
  /* repeat past excitation with pitch from previous decoded TCX frame */
947
1.64k
  C_ALLOC_SCRATCH_START(
948
1.64k
      exc_buf, FIXP_DBL,
949
1.64k
      PIT_MAX_MAX + L_INTERPOL + L_DIV); /* 411 +  17 + 256 + 1 =  */
950
1.64k
  C_ALLOC_SCRATCH_START(syn_buf, FIXP_DBL,
951
1.64k
                        M_LP_FILTER_ORDER + L_DIV); /* 256 +  16           =  */
952
                                                    /*                    +=  */
953
1.64k
  FIXP_DBL ns_buf[L_DIV + 1];
954
1.64k
  FIXP_DBL *syn = syn_buf + M_LP_FILTER_ORDER;
955
1.64k
  FIXP_DBL *exc = exc_buf + PIT_MAX_MAX + L_INTERPOL;
956
1.64k
  FIXP_DBL *ns = ns_buf + 1;
957
1.64k
  FIXP_DBL tmp, fact_exc;
958
1.64k
  INT T = fMin(*pitch, (SHORT)PIT_MAX_MAX);
959
1.64k
  int i, i_subfr, subfr_nr;
960
1.64k
  int lDiv = coreCoderFrameLength / NB_DIV;
961
962
1.64k
  FDKmemcpy(syn_buf, acelp_mem->old_syn_mem,
963
1.64k
            M_LP_FILTER_ORDER * sizeof(FIXP_DBL));
964
1.64k
  FDKmemcpy(exc_buf, acelp_mem->old_exc_mem,
965
1.64k
            (PIT_MAX_MAX + L_INTERPOL) * sizeof(FIXP_DBL));
966
967
  /* if we lost all packets (i.e. 1 packet of TCX-20 ms, 2 packets of
968
     the TCX-40 ms or 4 packets of the TCX-80ms), we lost the whole
969
     coded frame extrapolation strategy: repeat lost excitation and
970
     use extrapolated LSFs */
971
972
  /* AMR-WB+ like TCX TD concealment */
973
974
  /* number of lost frame cmpt */
975
1.64k
  if (nLostSf < 2) {
976
332
    fact_exc = FL2FXCONST_DBL(0.8f);
977
1.30k
  } else {
978
1.30k
    fact_exc = FL2FXCONST_DBL(0.4f);
979
1.30k
  }
980
981
  /* repeat past excitation */
982
377k
  for (i = 0; i < lDiv; i++) {
983
376k
    exc[i] = fMult(fact_exc, exc[i - T]);
984
376k
  }
985
986
1.64k
  tmp = fMult(fact_exc, acelp_mem->wsyn_rms);
987
1.64k
  acelp_mem->wsyn_rms = tmp;
988
989
  /* init deemph_mem_wsyn */
990
1.64k
  acelp_mem->deemph_mem_wsyn = exc[-1];
991
992
1.64k
  ns[-1] = acelp_mem->deemph_mem_wsyn;
993
994
7.52k
  for (i_subfr = 0, subfr_nr = 0; i_subfr < lDiv;
995
5.88k
       i_subfr += L_SUBFR, subfr_nr++) {
996
5.88k
    FIXP_DBL tRes[L_SUBFR];
997
5.88k
    FIXP_LPC A[M_LP_FILTER_ORDER];
998
5.88k
    INT A_exp;
999
1000
    /* interpolate LPC coefficients */
1001
5.88k
    int_lpc_acelp(lsp_old, lsp_new, subfr_nr, lDiv / L_SUBFR, A, &A_exp);
1002
1003
5.88k
    Syn_filt(A,              /* (i) : a[m] prediction coefficients         */
1004
5.88k
             A_exp, L_SUBFR, /* (i) : length                               */
1005
5.88k
             &exc[i_subfr],  /* (i) : input signal                         */
1006
5.88k
             &syn[i_subfr]   /* (i/o) : filter states / output signal      */
1007
5.88k
    );
1008
1009
5.88k
    E_LPC_a_weight(
1010
5.88k
        A, A,
1011
5.88k
        M_LP_FILTER_ORDER); /* overwrite A as it is not needed any longer */
1012
1013
5.88k
    E_UTIL_residu(A, A_exp, &syn[i_subfr], tRes, L_SUBFR);
1014
1015
5.88k
    Deemph(tRes, &ns[i_subfr], L_SUBFR, &acelp_mem->deemph_mem_wsyn);
1016
1017
    /* Amplitude limiter (saturate at wsyn_rms) */
1018
382k
    for (i = i_subfr; i < i_subfr + L_SUBFR; i++) {
1019
376k
      if (ns[i] > tmp) {
1020
105k
        ns[i] = tmp;
1021
271k
      } else {
1022
271k
        if (ns[i] < -tmp) {
1023
105k
          ns[i] = -tmp;
1024
105k
        }
1025
271k
      }
1026
376k
    }
1027
1028
5.88k
    E_UTIL_preemph(&ns[i_subfr], tRes, L_SUBFR);
1029
1030
5.88k
    Syn_filt(A,              /* (i) : a[m] prediction coefficients         */
1031
5.88k
             A_exp, L_SUBFR, /* (i) : length                               */
1032
5.88k
             tRes,           /* (i) : input signal                         */
1033
5.88k
             &syn[i_subfr]   /* (i/o) : filter states / output signal      */
1034
5.88k
    );
1035
1036
5.88k
    FDKmemmove(&synth[i_subfr], &syn[i_subfr], L_SUBFR * sizeof(FIXP_DBL));
1037
5.88k
  }
1038
1039
  /* save old excitation and old synthesis memory for next ACELP frame */
1040
1.64k
  FDKmemcpy(acelp_mem->old_exc_mem, exc + lDiv - (PIT_MAX_MAX + L_INTERPOL),
1041
1.64k
            sizeof(FIXP_DBL) * (PIT_MAX_MAX + L_INTERPOL));
1042
1.64k
  FDKmemcpy(acelp_mem->old_syn_mem, syn_buf + lDiv,
1043
1.64k
            sizeof(FIXP_DBL) * M_LP_FILTER_ORDER);
1044
1.64k
  acelp_mem->de_emph_mem = acelp_mem->deemph_mem_wsyn;
1045
1046
1.64k
  C_ALLOC_SCRATCH_END(syn_buf, FIXP_DBL, M_LP_FILTER_ORDER + L_DIV);
1047
1.64k
  C_ALLOC_SCRATCH_END(exc_buf, FIXP_DBL, PIT_MAX_MAX + L_INTERPOL + L_DIV);
1048
1.64k
}
1049
1050
void Acelp_PreProcessing(FIXP_DBL *synth_buf, FIXP_DBL *old_synth, INT *pitch,
1051
                         INT *old_T_pf, FIXP_DBL *pit_gain,
1052
                         FIXP_DBL *old_gain_pf, INT samplingRate, INT *i_offset,
1053
                         INT coreCoderFrameLength, INT synSfd,
1054
48.9k
                         INT nbSubfrSuperfr) {
1055
48.9k
  int n;
1056
1057
  /* init beginning of synth_buf with old synthesis from previous frame */
1058
48.9k
  FDKmemcpy(synth_buf, old_synth, sizeof(FIXP_DBL) * (PIT_MAX_MAX - BPF_DELAY));
1059
1060
  /* calculate pitch lag offset for ACELP decoder */
1061
48.9k
  *i_offset =
1062
48.9k
      (samplingRate * PIT_MIN_12k8 + (FSCALE_DENOM / 2)) / FSCALE_DENOM -
1063
48.9k
      PIT_MIN_12k8;
1064
1065
  /* for bass postfilter */
1066
346k
  for (n = 0; n < synSfd; n++) {
1067
298k
    pitch[n] = old_T_pf[n];
1068
298k
    pit_gain[n] = old_gain_pf[n];
1069
298k
  }
1070
742k
  for (n = 0; n < nbSubfrSuperfr; n++) {
1071
693k
    pitch[n + synSfd] = L_SUBFR;
1072
693k
    pit_gain[n + synSfd] = (FIXP_DBL)0;
1073
693k
  }
1074
48.9k
}
1075
1076
void Acelp_PostProcessing(FIXP_DBL *synth_buf, FIXP_DBL *old_synth, INT *pitch,
1077
                          INT *old_T_pf, INT coreCoderFrameLength, INT synSfd,
1078
48.9k
                          INT nbSubfrSuperfr) {
1079
48.9k
  int n;
1080
1081
  /* store last part of synth_buf (which is not handled by the IMDCT overlap)
1082
   * for next frame */
1083
48.9k
  FDKmemcpy(old_synth, synth_buf + coreCoderFrameLength,
1084
48.9k
            sizeof(FIXP_DBL) * (PIT_MAX_MAX - BPF_DELAY));
1085
1086
  /* for bass postfilter */
1087
346k
  for (n = 0; n < synSfd; n++) {
1088
298k
    old_T_pf[n] = pitch[nbSubfrSuperfr + n];
1089
298k
  }
1090
48.9k
}
1091
1092
42.1k
#define L_FAC_ZIR (LFAC)
1093
1094
void CLpd_Acelp_Zir(const FIXP_LPC A[], const INT A_exp,
1095
                    CAcelpStaticMem *acelp_mem, const INT length,
1096
42.1k
                    FIXP_DBL zir[], int doDeemph) {
1097
42.1k
  C_ALLOC_SCRATCH_START(tmp_buf, FIXP_DBL, L_FAC_ZIR + M_LP_FILTER_ORDER);
1098
42.1k
  FDK_ASSERT(length <= L_FAC_ZIR);
1099
1100
42.1k
  FDKmemcpy(tmp_buf, acelp_mem->old_syn_mem,
1101
42.1k
            M_LP_FILTER_ORDER * sizeof(FIXP_DBL));
1102
42.1k
  FDKmemset(tmp_buf + M_LP_FILTER_ORDER, 0, L_FAC_ZIR * sizeof(FIXP_DBL));
1103
1104
42.1k
  Syn_filt(A, A_exp, length, &tmp_buf[M_LP_FILTER_ORDER],
1105
42.1k
           &tmp_buf[M_LP_FILTER_ORDER]);
1106
42.1k
  if (!doDeemph) {
1107
    /* if last lpd mode was TD concealment, then bypass deemph */
1108
3
    FDKmemcpy(zir, tmp_buf, length * sizeof(*zir));
1109
42.1k
  } else {
1110
42.1k
    Deemph(&tmp_buf[M_LP_FILTER_ORDER], &zir[0], length,
1111
42.1k
           &acelp_mem->de_emph_mem);
1112
42.1k
    scaleValues(zir, length, -ACELP_OUTSCALE);
1113
42.1k
  }
1114
42.1k
  C_ALLOC_SCRATCH_END(tmp_buf, FIXP_DBL, L_FAC_ZIR + M_LP_FILTER_ORDER);
1115
42.1k
}
1116
1117
void CLpd_AcelpPrepareInternalMem(const FIXP_DBL *synth, UCHAR last_lpd_mode,
1118
                                  UCHAR last_last_lpd_mode,
1119
                                  const FIXP_LPC *A_new, const INT A_new_exp,
1120
                                  const FIXP_LPC *A_old, const INT A_old_exp,
1121
                                  CAcelpStaticMem *acelp_mem,
1122
                                  INT coreCoderFrameLength, INT clearOldExc,
1123
46.8k
                                  UCHAR lpd_mode) {
1124
46.8k
  int l_div =
1125
46.8k
      coreCoderFrameLength / NB_DIV; /* length of one ACELP/TCX20 frame */
1126
46.8k
  int l_div_partial;
1127
46.8k
  FIXP_DBL *syn, *old_exc_mem;
1128
1129
46.8k
  C_ALLOC_SCRATCH_START(synth_buf, FIXP_DBL,
1130
46.8k
                        PIT_MAX_MAX + L_INTERPOL + M_LP_FILTER_ORDER);
1131
46.8k
  syn = &synth_buf[M_LP_FILTER_ORDER];
1132
1133
46.8k
  l_div_partial = PIT_MAX_MAX + L_INTERPOL - l_div;
1134
46.8k
  old_exc_mem = acelp_mem->old_exc_mem;
1135
1136
46.8k
  if (lpd_mode == 4) {
1137
    /* Bypass Domain conversion. TCXTD Concealment does no deemphasis in the
1138
     * end. */
1139
332
    FDKmemcpy(
1140
332
        synth_buf, &synth[-(PIT_MAX_MAX + L_INTERPOL + M_LP_FILTER_ORDER)],
1141
332
        (PIT_MAX_MAX + L_INTERPOL + M_LP_FILTER_ORDER) * sizeof(FIXP_DBL));
1142
    /* Set deemphasis memory state for TD concealment */
1143
332
    acelp_mem->deemph_mem_wsyn = scaleValueSaturate(synth[-1], ACELP_OUTSCALE);
1144
46.4k
  } else {
1145
    /* convert past [PIT_MAX_MAX+L_INTERPOL+M_LP_FILTER_ORDER] synthesis to
1146
     * preemph domain */
1147
46.4k
    E_UTIL_preemph(&synth[-(PIT_MAX_MAX + L_INTERPOL + M_LP_FILTER_ORDER)],
1148
46.4k
                   synth_buf, PIT_MAX_MAX + L_INTERPOL + M_LP_FILTER_ORDER);
1149
46.4k
    scaleValuesSaturate(synth_buf, PIT_MAX_MAX + L_INTERPOL + M_LP_FILTER_ORDER,
1150
46.4k
                        ACELP_OUTSCALE);
1151
46.4k
  }
1152
1153
  /* Set deemphasis memory state */
1154
46.8k
  acelp_mem->de_emph_mem = scaleValueSaturate(synth[-1], ACELP_OUTSCALE);
1155
1156
  /* update acelp synth filter memory */
1157
46.8k
  FDKmemcpy(acelp_mem->old_syn_mem,
1158
46.8k
            &syn[PIT_MAX_MAX + L_INTERPOL - M_LP_FILTER_ORDER],
1159
46.8k
            M_LP_FILTER_ORDER * sizeof(FIXP_DBL));
1160
1161
46.8k
  if (clearOldExc) {
1162
2
    FDKmemclear(old_exc_mem, (PIT_MAX_MAX + L_INTERPOL) * sizeof(FIXP_DBL));
1163
2
    C_ALLOC_SCRATCH_END(synth_buf, FIXP_DBL,
1164
2
                        PIT_MAX_MAX + L_INTERPOL + M_LP_FILTER_ORDER);
1165
2
    return;
1166
2
  }
1167
1168
  /* update past [PIT_MAX_MAX+L_INTERPOL] samples of exc memory */
1169
46.8k
  if (last_lpd_mode == 1) {        /* last frame was TCX20 */
1170
21.8k
    if (last_last_lpd_mode == 0) { /* ACELP -> TCX20 -> ACELP transition */
1171
      /* Delay valid part of excitation buffer (from previous ACELP frame) by
1172
       * l_div samples */
1173
7.76k
      FDKmemmove(old_exc_mem, old_exc_mem + l_div,
1174
7.76k
                 sizeof(FIXP_DBL) * l_div_partial);
1175
14.1k
    } else if (last_last_lpd_mode > 0) { /* TCX -> TCX20 -> ACELP transition */
1176
14.1k
      E_UTIL_residu(A_old, A_old_exp, syn, old_exc_mem, l_div_partial);
1177
14.1k
    }
1178
21.8k
    E_UTIL_residu(A_new, A_new_exp, syn + l_div_partial,
1179
21.8k
                  old_exc_mem + l_div_partial, l_div);
1180
24.9k
  } else { /* prev frame was FD, TCX40 or TCX80 */
1181
24.9k
    int exc_A_new_length = (coreCoderFrameLength / 2 > PIT_MAX_MAX + L_INTERPOL)
1182
24.9k
                               ? PIT_MAX_MAX + L_INTERPOL
1183
24.9k
                               : coreCoderFrameLength / 2;
1184
24.9k
    int exc_A_old_length = PIT_MAX_MAX + L_INTERPOL - exc_A_new_length;
1185
24.9k
    E_UTIL_residu(A_old, A_old_exp, syn, old_exc_mem, exc_A_old_length);
1186
24.9k
    E_UTIL_residu(A_new, A_new_exp, &syn[exc_A_old_length],
1187
24.9k
                  &old_exc_mem[exc_A_old_length], exc_A_new_length);
1188
24.9k
  }
1189
46.8k
  C_ALLOC_SCRATCH_END(synth_buf, FIXP_DBL,
1190
46.8k
                      PIT_MAX_MAX + L_INTERPOL + M_LP_FILTER_ORDER);
1191
1192
46.8k
  return;
1193
46.8k
}
1194
1195
42.1k
FIXP_DBL *CLpd_ACELP_GetFreeExcMem(CAcelpStaticMem *acelp_mem, INT length) {
1196
42.1k
  FDK_ASSERT(length <= PIT_MAX_MAX + L_INTERPOL);
1197
42.1k
  return acelp_mem->old_exc_mem;
1198
42.1k
}
1199
1200
INT CLpd_AcelpRead(HANDLE_FDK_BITSTREAM hBs, CAcelpChannelData *acelp,
1201
                   INT acelp_core_mode, INT coreCoderFrameLength,
1202
111k
                   INT i_offset) {
1203
111k
  int nb_subfr = coreCoderFrameLength / L_DIV;
1204
111k
  const UCHAR *num_acb_index_bits =
1205
111k
      (nb_subfr == 4) ? num_acb_idx_bits_table[0] : num_acb_idx_bits_table[1];
1206
111k
  int nbits;
1207
111k
  int error = 0;
1208
1209
111k
  const int PIT_MIN = PIT_MIN_12k8 + i_offset;
1210
111k
  const int PIT_FR2 = PIT_FR2_12k8 - i_offset;
1211
111k
  const int PIT_FR1 = PIT_FR1_12k8;
1212
111k
  const int PIT_MAX = PIT_MAX_12k8 + (6 * i_offset);
1213
111k
  int T0, T0_frac, T0_min = 0, T0_max;
1214
1215
111k
  if (PIT_MAX > PIT_MAX_MAX) {
1216
0
    error = AAC_DEC_DECODE_FRAME_ERROR;
1217
0
    goto bail;
1218
0
  }
1219
1220
111k
  acelp->acelp_core_mode = acelp_core_mode;
1221
1222
111k
  nbits = MapCoreMode2NBits(acelp_core_mode);
1223
1224
  /* decode mean energy with 2 bits : 18, 30, 42 or 54 dB */
1225
111k
  acelp->mean_energy = FDKreadBits(hBs, 2);
1226
1227
512k
  for (int sfr = 0; sfr < nb_subfr; sfr++) {
1228
    /* read ACB index and store T0 and T0_frac for each ACELP subframe. */
1229
400k
    error = DecodePitchLag(hBs, num_acb_index_bits[sfr], PIT_MIN, PIT_FR2,
1230
400k
                           PIT_FR1, PIT_MAX, &T0, &T0_frac, &T0_min, &T0_max);
1231
400k
    if (error) {
1232
0
      goto bail;
1233
0
    }
1234
400k
    acelp->T0[sfr] = (USHORT)T0;
1235
400k
    acelp->T0_frac[sfr] = (UCHAR)T0_frac;
1236
400k
    acelp->ltp_filtering_flag[sfr] = FDKreadBits(hBs, 1);
1237
400k
    switch (nbits) {
1238
43.0k
      case 12: /* 12 bits AMR-WB codebook is used */
1239
43.0k
        acelp->icb_index[sfr][0] = FDKreadBits(hBs, 1);
1240
43.0k
        acelp->icb_index[sfr][1] = FDKreadBits(hBs, 5);
1241
43.0k
        acelp->icb_index[sfr][2] = FDKreadBits(hBs, 1);
1242
43.0k
        acelp->icb_index[sfr][3] = FDKreadBits(hBs, 5);
1243
43.0k
        break;
1244
87.2k
      case 16: /* 16 bits AMR-WB codebook is used */
1245
87.2k
        acelp->icb_index[sfr][0] = FDKreadBits(hBs, 1);
1246
87.2k
        acelp->icb_index[sfr][1] = FDKreadBits(hBs, 5);
1247
87.2k
        acelp->icb_index[sfr][2] = FDKreadBits(hBs, 5);
1248
87.2k
        acelp->icb_index[sfr][3] = FDKreadBits(hBs, 5);
1249
87.2k
        break;
1250
127k
      case 20: /* 20 bits AMR-WB codebook is used */
1251
127k
        acelp->icb_index[sfr][0] = FDKreadBits(hBs, 5);
1252
127k
        acelp->icb_index[sfr][1] = FDKreadBits(hBs, 5);
1253
127k
        acelp->icb_index[sfr][2] = FDKreadBits(hBs, 5);
1254
127k
        acelp->icb_index[sfr][3] = FDKreadBits(hBs, 5);
1255
127k
        break;
1256
28.6k
      case 28: /* 28 bits AMR-WB codebook is used */
1257
28.6k
        acelp->icb_index[sfr][0] = FDKreadBits(hBs, 9);
1258
28.6k
        acelp->icb_index[sfr][1] = FDKreadBits(hBs, 9);
1259
28.6k
        acelp->icb_index[sfr][2] = FDKreadBits(hBs, 5);
1260
28.6k
        acelp->icb_index[sfr][3] = FDKreadBits(hBs, 5);
1261
28.6k
        break;
1262
49.6k
      case 36: /* 36 bits AMR-WB codebook is used */
1263
49.6k
        acelp->icb_index[sfr][0] = FDKreadBits(hBs, 9);
1264
49.6k
        acelp->icb_index[sfr][1] = FDKreadBits(hBs, 9);
1265
49.6k
        acelp->icb_index[sfr][2] = FDKreadBits(hBs, 9);
1266
49.6k
        acelp->icb_index[sfr][3] = FDKreadBits(hBs, 9);
1267
49.6k
        break;
1268
6.24k
      case 44: /* 44 bits AMR-WB codebook is used */
1269
6.24k
        acelp->icb_index[sfr][0] = FDKreadBits(hBs, 13);
1270
6.24k
        acelp->icb_index[sfr][1] = FDKreadBits(hBs, 13);
1271
6.24k
        acelp->icb_index[sfr][2] = FDKreadBits(hBs, 9);
1272
6.24k
        acelp->icb_index[sfr][3] = FDKreadBits(hBs, 9);
1273
6.24k
        break;
1274
10.4k
      case 52: /* 52 bits AMR-WB codebook is used */
1275
10.4k
        acelp->icb_index[sfr][0] = FDKreadBits(hBs, 13);
1276
10.4k
        acelp->icb_index[sfr][1] = FDKreadBits(hBs, 13);
1277
10.4k
        acelp->icb_index[sfr][2] = FDKreadBits(hBs, 13);
1278
10.4k
        acelp->icb_index[sfr][3] = FDKreadBits(hBs, 13);
1279
10.4k
        break;
1280
47.0k
      case 64: /* 64 bits AMR-WB codebook is used */
1281
47.0k
        acelp->icb_index[sfr][0] = FDKreadBits(hBs, 2);
1282
47.0k
        acelp->icb_index[sfr][1] = FDKreadBits(hBs, 2);
1283
47.0k
        acelp->icb_index[sfr][2] = FDKreadBits(hBs, 2);
1284
47.0k
        acelp->icb_index[sfr][3] = FDKreadBits(hBs, 2);
1285
47.0k
        acelp->icb_index[sfr][4] = FDKreadBits(hBs, 14);
1286
47.0k
        acelp->icb_index[sfr][5] = FDKreadBits(hBs, 14);
1287
47.0k
        acelp->icb_index[sfr][6] = FDKreadBits(hBs, 14);
1288
47.0k
        acelp->icb_index[sfr][7] = FDKreadBits(hBs, 14);
1289
47.0k
        break;
1290
0
      default:
1291
0
        FDK_ASSERT(0);
1292
0
        break;
1293
400k
    }
1294
400k
    acelp->gains[sfr] = FDKreadBits(hBs, 7);
1295
400k
  }
1296
1297
111k
bail:
1298
111k
  return error;
1299
111k
}