Coverage Report

Created: 2026-05-30 06:39

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libxaac/decoder/ixheaacd_hbe_trans.c
Line
Count
Source
1
/******************************************************************************
2
 *                                                                            *
3
 * Copyright (C) 2018 The Android Open Source Project
4
 *
5
 * Licensed under the Apache License, Version 2.0 (the "License");
6
 * you may not use this file except in compliance with the License.
7
 * You may obtain a copy of the License at:
8
 *
9
 * http://www.apache.org/licenses/LICENSE-2.0
10
 *
11
 * Unless required by applicable law or agreed to in writing, software
12
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 * See the License for the specific language governing permissions and
15
 * limitations under the License.
16
 *
17
 *****************************************************************************
18
 * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19
*/
20
#include <math.h>
21
#include <stdlib.h>
22
#include <string.h>
23
24
#include "ixheaac_type_def.h"
25
26
#include "ixheaacd_bitbuffer.h"
27
28
#include "ixheaacd_interface.h"
29
30
#include "ixheaacd_tns_usac.h"
31
#include "ixheaacd_cnst.h"
32
33
#include "ixheaacd_acelp_info.h"
34
35
#include "ixheaacd_sbrdecsettings.h"
36
#include "ixheaacd_info.h"
37
#include "ixheaacd_sbr_common.h"
38
#include "ixheaacd_drc_data_struct.h"
39
#include "ixheaacd_drc_dec.h"
40
#include "ixheaacd_sbrdecoder.h"
41
#include "ixheaacd_mps_polyphase.h"
42
#include "ixheaac_sbr_const.h"
43
44
#include "ixheaacd_env_extr_part.h"
45
#include "ixheaacd_sbr_rom.h"
46
#include "ixheaacd_common_rom.h"
47
#include "ixheaacd_hybrid.h"
48
#include "ixheaacd_sbr_scale.h"
49
#include "ixheaacd_ps_dec.h"
50
#include "ixheaacd_freq_sca.h"
51
#include "ixheaacd_lpp_tran.h"
52
#include "ixheaacd_bitbuffer.h"
53
#include "ixheaacd_env_extr.h"
54
#include "ixheaacd_qmf_dec.h"
55
#include "ixheaacd_env_calc.h"
56
#include "ixheaacd_pvc_dec.h"
57
58
#include "ixheaacd_sbr_dec.h"
59
#include "ixheaac_error_standards.h"
60
#include "ixheaacd_sbrqmftrans.h"
61
#include "ixheaacd_qmf_poly.h"
62
63
#include "ixheaac_constants.h"
64
#include "ixheaac_basic_ops32.h"
65
#include "ixheaac_basic_op.h"
66
67
#include "ixheaac_esbr_rom.h"
68
69
254k
#define SBR_CONST_PMIN 1.0f
70
71
134k
static FLOAT32 *ixheaacd_map_prot_filter(WORD32 filt_length) {
72
134k
  switch (filt_length) {
73
86
    case 4:
74
86
      return (FLOAT32 *)&ixheaac_sub_samp_qmf_window_coeff[0];
75
0
      break;
76
12.2k
    case 8:
77
12.2k
      return (FLOAT32 *)&ixheaac_sub_samp_qmf_window_coeff[40];
78
0
      break;
79
20.3k
    case 12:
80
20.3k
      return (FLOAT32 *)&ixheaac_sub_samp_qmf_window_coeff[120];
81
0
      break;
82
18.8k
    case 16:
83
18.8k
      return (FLOAT32 *)&ixheaac_sub_samp_qmf_window_coeff[240];
84
0
      break;
85
27.7k
    case 20:
86
27.7k
      return (FLOAT32 *)&ixheaac_sub_samp_qmf_window_coeff[400];
87
0
      break;
88
20.3k
    case 24:
89
20.3k
      return (FLOAT32 *)&ixheaac_sub_samp_qmf_window_coeff[600];
90
0
      break;
91
6.61k
    case 32:
92
6.61k
      return (FLOAT32 *)&ixheaac_sub_samp_qmf_window_coeff[840];
93
0
      break;
94
27.7k
    case 40:
95
27.7k
      return (FLOAT32 *)&ixheaac_sub_samp_qmf_window_coeff[1160];
96
0
      break;
97
0
    default:
98
0
      return (FLOAT32 *)&ixheaac_sub_samp_qmf_window_coeff[0];
99
134k
  }
100
134k
}
101
102
WORD32 ixheaacd_qmf_hbe_data_reinit(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
103
                                    WORD16 *p_freq_band_tab[2],
104
67.0k
                                    WORD16 *p_num_sfb, WORD32 upsamp_4_flag) {
105
67.0k
  WORD32 synth_size, sfb, patch, stop_patch;
106
107
67.0k
  if (ptr_hbe_txposer != NULL) {
108
67.0k
    ptr_hbe_txposer->start_band = p_freq_band_tab[LOW][0];
109
67.0k
    ptr_hbe_txposer->end_band = p_freq_band_tab[LOW][p_num_sfb[LOW]];
110
111
67.0k
    ptr_hbe_txposer->synth_size =
112
67.0k
        4 * ((ptr_hbe_txposer->start_band + 4) / 8 + 1);
113
67.0k
    ptr_hbe_txposer->k_start =
114
67.0k
        ixheaac_start_subband2kL_tbl[ptr_hbe_txposer->start_band];
115
116
67.0k
    ptr_hbe_txposer->upsamp_4_flag = upsamp_4_flag;
117
67.0k
    ptr_hbe_txposer->esbr_hq = 0;
118
119
67.0k
    if (upsamp_4_flag) {
120
3.98k
      if (ptr_hbe_txposer->k_start + ptr_hbe_txposer->synth_size > 16)
121
176
        ptr_hbe_txposer->k_start = 16 - ptr_hbe_txposer->synth_size;
122
63.0k
    } else if (ptr_hbe_txposer->core_frame_length == 768) {
123
2.41k
      if (ptr_hbe_txposer->k_start + ptr_hbe_txposer->synth_size > 24)
124
1.26k
        ptr_hbe_txposer->k_start = 24 - ptr_hbe_txposer->synth_size;
125
2.41k
    }
126
127
67.0k
    memset(ptr_hbe_txposer->synth_buf, 0, 1280 * sizeof(FLOAT32));
128
67.0k
    synth_size = ptr_hbe_txposer->synth_size;
129
67.0k
    ptr_hbe_txposer->synth_buf_offset = 18 * synth_size;
130
67.0k
    switch (synth_size) {
131
86
      case 4:
132
86
        ptr_hbe_txposer->synth_cos_tab =
133
86
            (FLOAT32 *)ixheaac_synth_cos_table_kl_4;
134
86
        ptr_hbe_txposer->analy_cos_sin_tab =
135
86
            (FLOAT32 *)ixheaac_analy_cos_sin_table_kl_8;
136
86
        ptr_hbe_txposer->ixheaacd_real_synth_fft = &ixheaac_real_synth_fft_p2;
137
86
        ptr_hbe_txposer->ixheaacd_cmplx_anal_fft = &ixheaac_cmplx_anal_fft_p2;
138
86
        break;
139
12.2k
      case 8:
140
12.2k
        ptr_hbe_txposer->synth_cos_tab =
141
12.2k
            (FLOAT32 *)ixheaac_synth_cos_table_kl_8;
142
12.2k
        ptr_hbe_txposer->analy_cos_sin_tab =
143
12.2k
            (FLOAT32 *)ixheaac_analy_cos_sin_table_kl_16;
144
12.2k
        ptr_hbe_txposer->ixheaacd_real_synth_fft = &ixheaac_real_synth_fft_p2;
145
12.2k
        ptr_hbe_txposer->ixheaacd_cmplx_anal_fft = &ixheaac_cmplx_anal_fft_p2;
146
12.2k
        break;
147
20.3k
      case 12:
148
20.3k
        ptr_hbe_txposer->synth_cos_tab =
149
20.3k
            (FLOAT32 *)ixheaac_synth_cos_table_kl_12;
150
20.3k
        ptr_hbe_txposer->analy_cos_sin_tab =
151
20.3k
            (FLOAT32 *)ixheaac_analy_cos_sin_table_kl_24;
152
20.3k
        ptr_hbe_txposer->ixheaacd_real_synth_fft = &ixheaac_real_synth_fft_p3;
153
20.3k
        ptr_hbe_txposer->ixheaacd_cmplx_anal_fft = &ixheaac_cmplx_anal_fft_p3;
154
20.3k
        break;
155
6.61k
      case 16:
156
6.61k
        ptr_hbe_txposer->synth_cos_tab =
157
6.61k
            (FLOAT32 *)ixheaac_synth_cos_table_kl_16;
158
6.61k
        ptr_hbe_txposer->analy_cos_sin_tab =
159
6.61k
            (FLOAT32 *)ixheaac_analy_cos_sin_table_kl_32;
160
6.61k
        ptr_hbe_txposer->ixheaacd_real_synth_fft = &ixheaac_real_synth_fft_p2;
161
6.61k
        ptr_hbe_txposer->ixheaacd_cmplx_anal_fft = &ixheaac_cmplx_anal_fft_p2;
162
6.61k
        break;
163
27.7k
      case 20:
164
27.7k
        ptr_hbe_txposer->synth_cos_tab =
165
27.7k
            (FLOAT32 *)ixheaac_synth_cos_table_kl_20;
166
27.7k
        ptr_hbe_txposer->analy_cos_sin_tab =
167
27.7k
            (FLOAT32 *)ixheaac_analy_cos_sin_table_kl_40;
168
27.7k
        break;
169
0
      default:
170
0
        ptr_hbe_txposer->synth_cos_tab =
171
0
            (FLOAT32 *)ixheaac_synth_cos_table_kl_4;
172
0
        ptr_hbe_txposer->analy_cos_sin_tab =
173
0
            (FLOAT32 *)ixheaac_analy_cos_sin_table_kl_8;
174
0
        ptr_hbe_txposer->ixheaacd_real_synth_fft = &ixheaac_real_synth_fft_p2;
175
0
        ptr_hbe_txposer->ixheaacd_cmplx_anal_fft = &ixheaac_cmplx_anal_fft_p2;
176
67.0k
    }
177
178
67.0k
    ptr_hbe_txposer->synth_wind_coeff = ixheaacd_map_prot_filter(synth_size);
179
180
67.0k
    memset(ptr_hbe_txposer->analy_buf, 0, 640 * sizeof(FLOAT32));
181
67.0k
    synth_size = 2 * ptr_hbe_txposer->synth_size;
182
67.0k
    ptr_hbe_txposer->analy_wind_coeff = ixheaacd_map_prot_filter(synth_size);
183
184
67.0k
    memset(ptr_hbe_txposer->x_over_qmf, 0, MAX_NUM_PATCHES * sizeof(WORD32));
185
67.0k
    sfb = 0;
186
67.0k
    if (upsamp_4_flag) {
187
3.98k
      stop_patch = MAX_NUM_PATCHES;
188
3.98k
      ptr_hbe_txposer->max_stretch = MAX_STRETCH;
189
63.0k
    } else {
190
63.0k
      stop_patch = MAX_STRETCH;
191
63.0k
    }
192
193
186k
    for (patch = 1; patch <= stop_patch; patch++) {
194
703k
      while (sfb <= p_num_sfb[LOW] &&
195
640k
             p_freq_band_tab[LOW][sfb] <= patch * ptr_hbe_txposer->start_band)
196
521k
        sfb++;
197
182k
      if (sfb <= p_num_sfb[LOW]) {
198
119k
        if ((patch * ptr_hbe_txposer->start_band -
199
119k
             p_freq_band_tab[LOW][sfb - 1]) <= 3) {
200
105k
          ptr_hbe_txposer->x_over_qmf[patch - 1] =
201
105k
              p_freq_band_tab[LOW][sfb - 1];
202
105k
        } else {
203
14.0k
          WORD32 sfb = 0;
204
180k
          while (sfb <= p_num_sfb[HIGH] &&
205
180k
                 p_freq_band_tab[HIGH][sfb] <=
206
180k
                     patch * ptr_hbe_txposer->start_band)
207
166k
            sfb++;
208
14.0k
          ptr_hbe_txposer->x_over_qmf[patch - 1] =
209
14.0k
              p_freq_band_tab[HIGH][sfb - 1];
210
14.0k
        }
211
119k
      } else {
212
62.8k
        ptr_hbe_txposer->x_over_qmf[patch - 1] = ptr_hbe_txposer->end_band;
213
62.8k
        ptr_hbe_txposer->max_stretch = min(patch, MAX_STRETCH);
214
62.8k
        break;
215
62.8k
      }
216
182k
    }
217
67.0k
    if (ptr_hbe_txposer->k_start < 0) {
218
0
      return -1;
219
0
    }
220
67.0k
  }
221
67.0k
  return 0;
222
67.0k
}
223
224
WORD32 ixheaacd_qmf_hbe_apply(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
225
                              FLOAT32 qmf_buf_real[][64],
226
                              FLOAT32 qmf_buf_imag[][64], WORD32 num_columns,
227
                              FLOAT32 pv_qmf_buf_real[][64],
228
                              FLOAT32 pv_qmf_buf_imag[][64],
229
                              WORD32 pitch_in_bins,
230
254k
                              ia_sbr_header_data_struct *ptr_header_data) {
231
254k
  WORD32 i, qmf_band_idx;
232
254k
  WORD32 qmf_voc_columns = ptr_hbe_txposer->no_bins / 2;
233
254k
  WORD32 err_code = 0;
234
235
254k
  memcpy(ptr_hbe_txposer->ptr_input_buf,
236
254k
         ptr_hbe_txposer->ptr_input_buf +
237
254k
             ptr_hbe_txposer->no_bins * ptr_hbe_txposer->synth_size,
238
254k
         ptr_hbe_txposer->synth_size * sizeof(FLOAT32));
239
240
254k
  if (ptr_hbe_txposer->ixheaacd_cmplx_anal_fft == NULL) {
241
18.0k
    WORD32 err = ixheaacd_qmf_hbe_data_reinit(
242
18.0k
        ptr_hbe_txposer,
243
18.0k
        ptr_header_data->pstr_freq_band_data->freq_band_table,
244
18.0k
        ptr_header_data->pstr_freq_band_data->num_sf_bands,
245
18.0k
        ptr_header_data->is_usf_4);
246
18.0k
    if (err)
247
0
      return err;
248
18.0k
  }
249
250
254k
  err_code = ixheaacd_real_synth_filt(ptr_hbe_txposer, num_columns,
251
254k
                                      qmf_buf_real, qmf_buf_imag);
252
254k
  if (err_code) return err_code;
253
254
3.30M
  for (i = 0; i < HBE_OPER_WIN_LEN - 1; i++) {
255
3.05M
    memcpy(ptr_hbe_txposer->qmf_in_buf[i],
256
3.05M
           ptr_hbe_txposer->qmf_in_buf[i + qmf_voc_columns],
257
3.05M
           TWICE_QMF_SYNTH_CHANNELS_NUM * sizeof(FLOAT32));
258
3.05M
  }
259
260
254k
  err_code = ixheaacd_complex_anal_filt(ptr_hbe_txposer);
261
254k
  if (err_code) return err_code;
262
263
9.43M
  for (i = 0; i < (ptr_hbe_txposer->hbe_qmf_out_len - ptr_hbe_txposer->no_bins);
264
9.18M
       i++) {
265
9.18M
    memcpy(ptr_hbe_txposer->qmf_out_buf[i],
266
9.18M
           ptr_hbe_txposer->qmf_out_buf[i + ptr_hbe_txposer->no_bins],
267
9.18M
           TWICE_QMF_SYNTH_CHANNELS_NUM * sizeof(FLOAT32));
268
9.18M
  }
269
270
9.43M
  for (; i < ptr_hbe_txposer->hbe_qmf_out_len; i++) {
271
9.18M
    memset(ptr_hbe_txposer->qmf_out_buf[i], 0,
272
9.18M
           TWICE_QMF_SYNTH_CHANNELS_NUM * sizeof(FLOAT32));
273
9.18M
  }
274
275
254k
  err_code = ixheaacd_hbe_post_anal_process(ptr_hbe_txposer, pitch_in_bins,
276
254k
                                            ptr_hbe_txposer->upsamp_4_flag);
277
254k
  if (err_code) return err_code;
278
279
9.43M
  for (i = 0; i < ptr_hbe_txposer->no_bins; i++) {
280
9.18M
    for (qmf_band_idx = ptr_hbe_txposer->start_band;
281
207M
         qmf_band_idx < ptr_hbe_txposer->end_band; qmf_band_idx++) {
282
198M
      pv_qmf_buf_real[i][qmf_band_idx] =
283
198M
          (FLOAT32)(ptr_hbe_txposer->qmf_out_buf[i][2 * qmf_band_idx] *
284
198M
                        ixheaac_phase_vocoder_cos_table[qmf_band_idx] -
285
198M
                    ptr_hbe_txposer->qmf_out_buf[i][2 * qmf_band_idx + 1] *
286
198M
                        ixheaac_phase_vocoder_sin_table[qmf_band_idx]);
287
288
198M
      pv_qmf_buf_imag[i][qmf_band_idx] =
289
198M
          (FLOAT32)(ptr_hbe_txposer->qmf_out_buf[i][2 * qmf_band_idx] *
290
198M
                        ixheaac_phase_vocoder_sin_table[qmf_band_idx] +
291
198M
                    ptr_hbe_txposer->qmf_out_buf[i][2 * qmf_band_idx + 1] *
292
198M
                        ixheaac_phase_vocoder_cos_table[qmf_band_idx]);
293
198M
    }
294
9.18M
  }
295
254k
  return 0;
296
254k
}
297
298
VOID ixheaacd_norm_qmf_in_buf_4(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
299
86.9k
                                WORD32 qmf_band_idx) {
300
86.9k
  WORD32 i;
301
86.9k
  FLOAT32 *in_buf = &ptr_hbe_txposer->qmf_in_buf[0][2 * qmf_band_idx];
302
86.9k
  FLOAT32 *norm_buf = &ptr_hbe_txposer->norm_qmf_in_buf[0][2 * qmf_band_idx];
303
304
2.56M
  for (; qmf_band_idx <= ptr_hbe_txposer->x_over_qmf[3]; qmf_band_idx++) {
305
88.8M
    for (i = 0; i < ptr_hbe_txposer->hbe_qmf_in_len; i++) {
306
86.3M
      FLOAT32 mag_scaling_fac = 0.0f;
307
86.3M
      FLOAT32 x_r, x_i, temp;
308
86.3M
      FLOAT64 base = 1e-17;
309
86.3M
      x_r = in_buf[0];
310
86.3M
      x_i = in_buf[1];
311
312
86.3M
      temp = x_r * x_r;
313
86.3M
      base = base + temp;
314
86.3M
      temp = x_i * x_i;
315
86.3M
      base = base + temp;
316
317
86.3M
      temp = (FLOAT32)sqrt(sqrt(base));
318
86.3M
      mag_scaling_fac = temp * (FLOAT32)(sqrt(temp));
319
320
86.3M
      mag_scaling_fac = 1 / mag_scaling_fac;
321
322
86.3M
      x_r *= mag_scaling_fac;
323
86.3M
      x_i *= mag_scaling_fac;
324
325
86.3M
      norm_buf[0] = x_r;
326
86.3M
      norm_buf[1] = x_i;
327
328
86.3M
      in_buf += 128;
329
86.3M
      norm_buf += 128;
330
86.3M
    }
331
332
2.47M
    in_buf -= (128 * (ptr_hbe_txposer->hbe_qmf_in_len) - 2);
333
2.47M
    norm_buf -= (128 * (ptr_hbe_txposer->hbe_qmf_in_len) - 2);
334
2.47M
  }
335
86.9k
}
336
337
VOID ixheaacd_norm_qmf_in_buf_2(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
338
238k
                                WORD32 qmf_band_idx) {
339
238k
  WORD32 i;
340
238k
  FLOAT32 *in_buf = &ptr_hbe_txposer->qmf_in_buf[0][2 * qmf_band_idx];
341
238k
  FLOAT32 *norm_buf = &ptr_hbe_txposer->norm_qmf_in_buf[0][2 * qmf_band_idx];
342
343
3.20M
  for (; qmf_band_idx <= ptr_hbe_txposer->x_over_qmf[1]; qmf_band_idx++) {
344
104M
    for (i = 0; i < ptr_hbe_txposer->hbe_qmf_in_len; i++) {
345
101M
      FLOAT32 mag_scaling_fac = 0.0f;
346
101M
      FLOAT32 x_r, x_i, temp;
347
101M
      FLOAT64 base = 1e-17;
348
101M
      x_r = in_buf[0];
349
101M
      x_i = in_buf[1];
350
351
101M
      temp = x_r * x_r;
352
101M
      base = base + temp;
353
101M
      temp = x_i * x_i;
354
101M
      base = base + x_i * x_i;
355
356
101M
      mag_scaling_fac = (FLOAT32)(1.0f / base);
357
101M
      mag_scaling_fac = (FLOAT32)sqrt(sqrt(mag_scaling_fac));
358
359
101M
      x_r *= mag_scaling_fac;
360
101M
      x_i *= mag_scaling_fac;
361
362
101M
      norm_buf[0] = x_r;
363
101M
      norm_buf[1] = x_i;
364
365
101M
      in_buf += 128;
366
101M
      norm_buf += 128;
367
101M
    }
368
369
2.96M
    in_buf -= (128 * (ptr_hbe_txposer->hbe_qmf_in_len) - 2);
370
2.96M
    norm_buf -= (128 * (ptr_hbe_txposer->hbe_qmf_in_len) - 2);
371
2.96M
  }
372
238k
}
373
374
VOID ixheaacd_hbe_xprod_proc_3(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
375
                               WORD32 qmf_band_idx, WORD32 qmf_col_idx,
376
1.22M
                               FLOAT32 p, WORD32 pitch_in_bins_idx) {
377
1.22M
  WORD32 tr, n1, n2, max_trans_fac, max_n1, max_n2;
378
1.22M
  WORD32 k, addrshift;
379
1.22M
  WORD32 inp_band_idx = 2 * qmf_band_idx / 3;
380
381
1.22M
  FLOAT64 temp_fac;
382
1.22M
  FLOAT32 max_mag_value;
383
1.22M
  FLOAT32 mag_zero_band, mag_n1_band, mag_n2_band, temp;
384
1.22M
  FLOAT32 temp_r, temp_i;
385
1.22M
  FLOAT32 mag_cmplx_gain = 1.8856f;
386
387
1.22M
  FLOAT32 *qmf_in_buf_ri =
388
1.22M
      ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + HBE_ZERO_BAND_IDX];
389
390
1.22M
  mag_zero_band =
391
1.22M
      qmf_in_buf_ri[2 * inp_band_idx] * qmf_in_buf_ri[2 * inp_band_idx] +
392
1.22M
      qmf_in_buf_ri[2 * inp_band_idx + 1] * qmf_in_buf_ri[2 * inp_band_idx + 1];
393
1.22M
  max_mag_value = 0;
394
1.22M
  max_n1 = max_n2 = max_trans_fac = 0;
395
396
3.66M
  for (tr = 1; tr < 3; tr++) {
397
2.44M
    temp_fac = (2.0f * qmf_band_idx + 1 - tr * p) * 0.3333334;
398
399
2.44M
    n1 = (WORD32)(temp_fac);
400
2.44M
    n2 = (WORD32)(temp_fac + p);
401
402
2.44M
    mag_n1_band = qmf_in_buf_ri[2 * n1] * qmf_in_buf_ri[2 * n1] +
403
2.44M
                  qmf_in_buf_ri[2 * n1 + 1] * qmf_in_buf_ri[2 * n1 + 1];
404
2.44M
    mag_n2_band = qmf_in_buf_ri[2 * n2] * qmf_in_buf_ri[2 * n2] +
405
2.44M
                  qmf_in_buf_ri[2 * n2 + 1] * qmf_in_buf_ri[2 * n2 + 1];
406
2.44M
    temp = min(mag_n1_band, mag_n2_band);
407
408
2.44M
    if (temp > max_mag_value) {
409
1.50M
      max_mag_value = temp;
410
1.50M
      max_trans_fac = tr;
411
1.50M
      max_n1 = n1;
412
1.50M
      max_n2 = n2;
413
1.50M
    }
414
2.44M
  }
415
416
1.22M
  if (max_mag_value > mag_zero_band && max_n1 >= 0 &&
417
382k
      max_n2 < NO_QMF_SYNTH_CHANNELS) {
418
382k
    FLOAT32 vec_y_r[2], vec_y_i[2], vec_o_r[2], vec_o_i[2];
419
382k
    FLOAT32 coeff_real[2], coeff_imag[2];
420
382k
    FLOAT32 d1, d2;
421
382k
    WORD32 mid_trans_fac, idx;
422
382k
    FLOAT64 base = 1e-17;
423
382k
    FLOAT32 mag_scaling_fac = 0;
424
382k
    FLOAT32 x_zero_band_r;
425
382k
    FLOAT32 x_zero_band_i;
426
427
382k
    x_zero_band_r = 0;
428
382k
    x_zero_band_i = 0;
429
382k
    mid_trans_fac = 3 - max_trans_fac;
430
382k
    if (max_trans_fac == 1) {
431
166k
      WORD32 idx;
432
166k
      d1 = 0;
433
166k
      d2 = 1.5;
434
166k
      x_zero_band_r = qmf_in_buf_ri[2 * max_n1];
435
166k
      x_zero_band_i = qmf_in_buf_ri[2 * max_n1 + 1];
436
437
166k
      idx = max_n2 & 3;
438
166k
      idx = (idx + 1) & 3;
439
166k
      coeff_real[0] = ixheaac_hbe_post_anal_proc_interp_coeff[idx][0];
440
166k
      coeff_imag[0] = ixheaac_hbe_post_anal_proc_interp_coeff[idx][1];
441
442
166k
      coeff_real[1] = coeff_real[0];
443
166k
      coeff_imag[1] = -coeff_imag[0];
444
445
166k
      vec_y_r[1] = qmf_in_buf_ri[2 * max_n2];
446
166k
      vec_y_i[1] = qmf_in_buf_ri[2 * max_n2 + 1];
447
448
166k
      addrshift = -2;
449
166k
      temp_r = ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + addrshift +
450
166k
                                           HBE_ZERO_BAND_IDX][2 * max_n2];
451
166k
      temp_i = ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + addrshift +
452
166k
                                           HBE_ZERO_BAND_IDX][2 * max_n2 + 1];
453
454
166k
      vec_y_r[0] = coeff_real[1] * temp_r - coeff_imag[1] * temp_i;
455
166k
      vec_y_i[0] = coeff_imag[1] * temp_r + coeff_real[1] * temp_i;
456
457
166k
      temp_r = ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + addrshift + 1 +
458
166k
                                           HBE_ZERO_BAND_IDX][2 * max_n2];
459
166k
      temp_i = ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + addrshift + 1 +
460
166k
                                           HBE_ZERO_BAND_IDX][2 * max_n2 + 1];
461
462
166k
      vec_y_r[0] += coeff_real[0] * temp_r - coeff_imag[0] * temp_i;
463
166k
      vec_y_i[0] += coeff_imag[0] * temp_r + coeff_real[0] * temp_i;
464
465
215k
    } else {
466
215k
      WORD32 idx;
467
215k
      d1 = 1.5;
468
215k
      d2 = 0;
469
215k
      mid_trans_fac = max_trans_fac;
470
215k
      max_trans_fac = 3 - max_trans_fac;
471
472
215k
      x_zero_band_r = qmf_in_buf_ri[2 * max_n2];
473
215k
      x_zero_band_i = qmf_in_buf_ri[2 * max_n2 + 1];
474
475
215k
      idx = (max_n1 & 3);
476
215k
      idx = (idx + 1) & 3;
477
215k
      coeff_real[0] = ixheaac_hbe_post_anal_proc_interp_coeff[idx][0];
478
215k
      coeff_imag[0] = ixheaac_hbe_post_anal_proc_interp_coeff[idx][1];
479
480
215k
      coeff_real[1] = coeff_real[0];
481
215k
      coeff_imag[1] = -coeff_imag[0];
482
483
215k
      vec_y_r[1] = qmf_in_buf_ri[2 * max_n1];
484
215k
      vec_y_i[1] = qmf_in_buf_ri[2 * max_n1 + 1];
485
486
215k
      addrshift = -2;
487
488
215k
      temp_r = ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + addrshift +
489
215k
                                           HBE_ZERO_BAND_IDX][2 * max_n1];
490
215k
      temp_i = ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + addrshift +
491
215k
                                           HBE_ZERO_BAND_IDX][2 * max_n1 + 1];
492
493
215k
      vec_y_r[0] = coeff_real[1] * temp_r - coeff_imag[1] * temp_i;
494
215k
      vec_y_i[0] = coeff_imag[1] * temp_r + coeff_real[1] * temp_i;
495
496
215k
      temp_r = ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + addrshift + 1 +
497
215k
                                           HBE_ZERO_BAND_IDX][2 * max_n1];
498
215k
      temp_i = ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + addrshift + 1 +
499
215k
                                           HBE_ZERO_BAND_IDX][2 * max_n1 + 1];
500
501
215k
      vec_y_r[0] += coeff_real[0] * temp_r - coeff_imag[0] * temp_i;
502
215k
      vec_y_i[0] += coeff_imag[0] * temp_r + coeff_real[0] * temp_i;
503
215k
    }
504
505
382k
    base = 1e-17;
506
382k
    base = base + x_zero_band_r * x_zero_band_r;
507
382k
    base = base + x_zero_band_i * x_zero_band_i;
508
382k
    mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base));
509
382k
    x_zero_band_r *= mag_scaling_fac;
510
382k
    x_zero_band_i *= mag_scaling_fac;
511
1.14M
    for (k = 0; k < 2; k++) {
512
764k
      base = 1e-17;
513
764k
      base = base + vec_y_r[k] * vec_y_r[k];
514
764k
      base = base + vec_y_i[k] * vec_y_i[k];
515
764k
      mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base));
516
764k
      vec_y_r[k] *= mag_scaling_fac;
517
764k
      vec_y_i[k] *= mag_scaling_fac;
518
764k
    }
519
520
382k
    temp_r = x_zero_band_r;
521
382k
    temp_i = x_zero_band_i;
522
764k
    for (idx = 0; idx < mid_trans_fac - 1; idx++) {
523
382k
      FLOAT32 tmp = x_zero_band_r;
524
382k
      x_zero_band_r = x_zero_band_r * temp_r - x_zero_band_i * temp_i;
525
382k
      x_zero_band_i = tmp * temp_i + x_zero_band_i * temp_r;
526
382k
    }
527
528
1.14M
    for (k = 0; k < 2; k++) {
529
764k
      temp_r = vec_y_r[k];
530
764k
      temp_i = vec_y_i[k];
531
764k
      for (idx = 0; idx < max_trans_fac - 1; idx++) {
532
0
        FLOAT32 tmp = vec_y_r[k];
533
0
        vec_y_r[k] = vec_y_r[k] * temp_r - vec_y_i[k] * temp_i;
534
0
        vec_y_i[k] = tmp * temp_i + vec_y_i[k] * temp_r;
535
0
      }
536
764k
    }
537
538
1.14M
    for (k = 0; k < 2; k++) {
539
764k
      vec_o_r[k] = vec_y_r[k] * x_zero_band_r - vec_y_i[k] * x_zero_band_i;
540
764k
      vec_o_i[k] = vec_y_r[k] * x_zero_band_i + vec_y_i[k] * x_zero_band_r;
541
764k
    }
542
543
382k
    {
544
382k
      FLOAT32 cos_theta =
545
382k
          ixheaac_hbe_x_prod_cos_table_trans_3[(pitch_in_bins_idx << 1) + 0];
546
382k
      FLOAT32 sin_theta =
547
382k
          ixheaac_hbe_x_prod_cos_table_trans_3[(pitch_in_bins_idx << 1) + 1];
548
382k
      if (d2 < d1) {
549
215k
        sin_theta = -sin_theta;
550
215k
      }
551
382k
      temp_r = vec_o_r[0];
552
382k
      temp_i = vec_o_i[0];
553
382k
      vec_o_r[0] = (FLOAT32)(cos_theta * temp_r - sin_theta * temp_i);
554
382k
      vec_o_i[0] = (FLOAT32)(cos_theta * temp_i + sin_theta * temp_r);
555
382k
    }
556
557
1.14M
    for (k = 0; k < 2; k++) {
558
764k
      ptr_hbe_txposer->qmf_out_buf[qmf_col_idx * 2 + (k + HBE_ZERO_BAND_IDX -
559
764k
                                                      1)][2 * qmf_band_idx] +=
560
764k
          (FLOAT32)(mag_cmplx_gain * vec_o_r[k]);
561
764k
      ptr_hbe_txposer
562
764k
          ->qmf_out_buf[qmf_col_idx * 2 + (k + HBE_ZERO_BAND_IDX - 1)]
563
764k
                       [2 * qmf_band_idx + 1] +=
564
764k
          (FLOAT32)(mag_cmplx_gain * vec_o_i[k]);
565
764k
    }
566
382k
  }
567
1.22M
}
568
569
VOID ixheaacd_hbe_xprod_proc_4(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
570
                               WORD32 qmf_band_idx, WORD32 qmf_col_idx,
571
766k
                               FLOAT32 p, WORD32 pitch_in_bins_idx) {
572
766k
  WORD32 k;
573
766k
  WORD32 inp_band_idx = qmf_band_idx >> 1;
574
766k
  WORD32 tr, n1, n2, max_trans_fac, max_n1, max_n2;
575
576
766k
  FLOAT64 temp_fac;
577
766k
  FLOAT32 max_mag_value, mag_zero_band, mag_n1_band, mag_n2_band, temp;
578
766k
  FLOAT32 temp_r, temp_i;
579
766k
  FLOAT32 mag_cmplx_gain = 2.0f;
580
581
766k
  FLOAT32 *qmf_in_buf_ri =
582
766k
      ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + HBE_ZERO_BAND_IDX];
583
584
766k
  mag_zero_band =
585
766k
      qmf_in_buf_ri[2 * inp_band_idx] * qmf_in_buf_ri[2 * inp_band_idx] +
586
766k
      qmf_in_buf_ri[2 * inp_band_idx + 1] * qmf_in_buf_ri[2 * inp_band_idx + 1];
587
588
766k
  max_mag_value = 0;
589
766k
  max_n1 = max_n2 = max_trans_fac = 0;
590
591
3.06M
  for (tr = 1; tr < 4; tr++) {
592
2.30M
    temp_fac = (2.0 * qmf_band_idx + 1 - tr * p) * 0.25;
593
2.30M
    n1 = ((WORD32)(temp_fac)) << 1;
594
2.30M
    n2 = ((WORD32)(temp_fac + p)) << 1;
595
596
2.30M
    mag_n1_band = qmf_in_buf_ri[n1] * qmf_in_buf_ri[n1] +
597
2.30M
                  qmf_in_buf_ri[n1 + 1] * qmf_in_buf_ri[n1 + 1];
598
2.30M
    mag_n2_band = qmf_in_buf_ri[n2] * qmf_in_buf_ri[n2] +
599
2.30M
                  qmf_in_buf_ri[n2 + 1] * qmf_in_buf_ri[n2 + 1];
600
601
2.30M
    temp = min(mag_n1_band, mag_n2_band);
602
603
2.30M
    if (temp > max_mag_value) {
604
1.06M
      max_mag_value = temp;
605
1.06M
      max_trans_fac = tr;
606
1.06M
      max_n1 = n1;
607
1.06M
      max_n2 = n2;
608
1.06M
    }
609
2.30M
  }
610
766k
  if (max_mag_value > mag_zero_band && max_n1 >= 0 &&
611
260k
      max_n2 < TWICE_QMF_SYNTH_CHANNELS_NUM) {
612
260k
    FLOAT32 vec_y_r[2], vec_y_i[2], vec_o_r[2], vec_o_i[2];
613
260k
    FLOAT32 d1, d2;
614
260k
    WORD32 mid_trans_fac, idx;
615
260k
    FLOAT32 x_zero_band_r;
616
260k
    FLOAT32 x_zero_band_i;
617
260k
    FLOAT64 base = 1e-17;
618
260k
    FLOAT32 mag_scaling_fac = 0.0f;
619
620
260k
    x_zero_band_r = 0;
621
260k
    x_zero_band_i = 0;
622
260k
    mid_trans_fac = 4 - max_trans_fac;
623
624
260k
    if (max_trans_fac == 1) {
625
76.1k
      d1 = 0;
626
76.1k
      d2 = 2;
627
76.1k
      x_zero_band_r = qmf_in_buf_ri[max_n1];
628
76.1k
      x_zero_band_i = qmf_in_buf_ri[max_n1 + 1];
629
228k
      for (k = 0; k < 2; k++) {
630
152k
        vec_y_r[k] =
631
152k
            ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + HBE_ZERO_BAND_IDX +
632
152k
                                        2 * (k - 1)][max_n2];
633
152k
        vec_y_i[k] =
634
152k
            ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + HBE_ZERO_BAND_IDX +
635
152k
                                        2 * (k - 1)][max_n2 + 1];
636
152k
      }
637
183k
    } else if (max_trans_fac == 2) {
638
92.9k
      d1 = 0;
639
92.9k
      d2 = 1;
640
92.9k
      x_zero_band_r = qmf_in_buf_ri[max_n1];
641
92.9k
      x_zero_band_i = qmf_in_buf_ri[max_n1 + 1];
642
278k
      for (k = 0; k < 2; k++) {
643
185k
        vec_y_r[k] =
644
185k
            ptr_hbe_txposer
645
185k
                ->qmf_in_buf[qmf_col_idx + HBE_ZERO_BAND_IDX + (k - 1)][max_n2];
646
185k
        vec_y_i[k] =
647
185k
            ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + HBE_ZERO_BAND_IDX +
648
185k
                                        (k - 1)][max_n2 + 1];
649
185k
      }
650
92.9k
    } else {
651
90.8k
      d1 = 2;
652
90.8k
      d2 = 0;
653
90.8k
      mid_trans_fac = max_trans_fac;
654
90.8k
      max_trans_fac = 4 - max_trans_fac;
655
90.8k
      x_zero_band_r = qmf_in_buf_ri[max_n2];
656
90.8k
      x_zero_band_i = qmf_in_buf_ri[max_n2 + 1];
657
272k
      for (k = 0; k < 2; k++) {
658
181k
        vec_y_r[k] =
659
181k
            ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + HBE_ZERO_BAND_IDX +
660
181k
                                        2 * (k - 1)][max_n1];
661
181k
        vec_y_i[k] =
662
181k
            ptr_hbe_txposer->qmf_in_buf[qmf_col_idx + HBE_ZERO_BAND_IDX +
663
181k
                                        2 * (k - 1)][max_n1 + 1];
664
181k
      }
665
90.8k
    }
666
667
260k
    base = 1e-17;
668
260k
    base = base + x_zero_band_r * x_zero_band_r;
669
260k
    base = base + x_zero_band_i * x_zero_band_i;
670
260k
    {
671
260k
      temp = (FLOAT32)sqrt(sqrt(base));
672
260k
      mag_scaling_fac = temp * (FLOAT32)(sqrt(temp));
673
260k
      mag_scaling_fac = 1 / mag_scaling_fac;
674
260k
    }
675
676
260k
    x_zero_band_r *= mag_scaling_fac;
677
260k
    x_zero_band_i *= mag_scaling_fac;
678
780k
    for (k = 0; k < 2; k++) {
679
520k
      base = 1e-17;
680
520k
      base = base + vec_y_r[k] * vec_y_r[k];
681
520k
      base = base + vec_y_i[k] * vec_y_i[k];
682
520k
      {
683
520k
        temp = (FLOAT32)sqrt(sqrt(base));
684
520k
        mag_scaling_fac = temp * (FLOAT32)(sqrt(temp));
685
686
520k
        mag_scaling_fac = 1 / mag_scaling_fac;
687
520k
      }
688
520k
      vec_y_r[k] *= mag_scaling_fac;
689
520k
      vec_y_i[k] *= mag_scaling_fac;
690
520k
    }
691
692
260k
    temp_r = x_zero_band_r;
693
260k
    temp_i = x_zero_band_i;
694
687k
    for (idx = 0; idx < mid_trans_fac - 1; idx++) {
695
427k
      FLOAT32 tmp = x_zero_band_r;
696
427k
      x_zero_band_r = x_zero_band_r * temp_r - x_zero_band_i * temp_i;
697
427k
      x_zero_band_i = tmp * temp_i + x_zero_band_i * temp_r;
698
427k
    }
699
700
780k
    for (k = 0; k < 2; k++) {
701
520k
      temp_r = vec_y_r[k];
702
520k
      temp_i = vec_y_i[k];
703
706k
      for (idx = 0; idx < max_trans_fac - 1; idx++) {
704
185k
        FLOAT32 tmp = vec_y_r[k];
705
185k
        vec_y_r[k] = vec_y_r[k] * temp_r - vec_y_i[k] * temp_i;
706
185k
        vec_y_i[k] = tmp * temp_i + vec_y_i[k] * temp_r;
707
185k
      }
708
520k
    }
709
710
780k
    for (k = 0; k < 2; k++) {
711
520k
      vec_o_r[k] = vec_y_r[k] * x_zero_band_r - vec_y_i[k] * x_zero_band_i;
712
520k
      vec_o_i[k] = vec_y_r[k] * x_zero_band_i + vec_y_i[k] * x_zero_band_r;
713
520k
    }
714
715
260k
    {
716
260k
      FLOAT32 cos_theta;
717
260k
      FLOAT32 sin_theta;
718
719
260k
      if (d2 == 1) {
720
92.9k
        cos_theta =
721
92.9k
            ixheaac_hbe_x_prod_cos_table_trans_4_1[(pitch_in_bins_idx << 1) +
722
92.9k
                                                    0];
723
92.9k
        sin_theta =
724
92.9k
            ixheaac_hbe_x_prod_cos_table_trans_4_1[(pitch_in_bins_idx << 1) +
725
92.9k
                                                    1];
726
167k
      } else {
727
167k
        cos_theta =
728
167k
            ixheaac_hbe_x_prod_cos_table_trans_4[(pitch_in_bins_idx << 1) + 0];
729
167k
        sin_theta =
730
167k
            ixheaac_hbe_x_prod_cos_table_trans_4[(pitch_in_bins_idx << 1) + 1];
731
167k
        if (d2 < d1) {
732
90.8k
          sin_theta = -sin_theta;
733
90.8k
        }
734
167k
      }
735
260k
      temp_r = vec_o_r[0];
736
260k
      temp_i = vec_o_i[0];
737
260k
      vec_o_r[0] = (FLOAT32)(cos_theta * temp_r - sin_theta * temp_i);
738
260k
      vec_o_i[0] = (FLOAT32)(cos_theta * temp_i + sin_theta * temp_r);
739
260k
    }
740
741
780k
    for (k = 0; k < 2; k++) {
742
520k
      ptr_hbe_txposer->qmf_out_buf[qmf_col_idx * 2 + (k + HBE_ZERO_BAND_IDX -
743
520k
                                                      1)][2 * qmf_band_idx] +=
744
520k
          (FLOAT32)(mag_cmplx_gain * vec_o_r[k]);
745
520k
      ptr_hbe_txposer
746
520k
          ->qmf_out_buf[qmf_col_idx * 2 + (k + HBE_ZERO_BAND_IDX - 1)]
747
520k
                       [2 * qmf_band_idx + 1] +=
748
520k
          (FLOAT32)(mag_cmplx_gain * vec_o_i[k]);
749
520k
    }
750
260k
  }
751
766k
}
752
753
VOID ixheaacd_hbe_post_anal_prod2(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
754
228k
                                  WORD32 qmf_voc_columns, WORD32 qmf_band_idx) {
755
228k
  WORD32 i;
756
228k
  FLOAT32 *norm_ptr = &ptr_hbe_txposer->norm_qmf_in_buf[1][2 * qmf_band_idx];
757
228k
  FLOAT32 *out_ptr = &ptr_hbe_txposer->qmf_out_buf[1][2 * qmf_band_idx];
758
228k
  FLOAT32 *x_norm_ptr =
759
228k
      &ptr_hbe_txposer->norm_qmf_in_buf[HBE_ZERO_BAND_IDX][2 * qmf_band_idx];
760
761
228k
  ixheaacd_norm_qmf_in_buf_2(ptr_hbe_txposer, qmf_band_idx);
762
763
2.83M
  for (; qmf_band_idx < ptr_hbe_txposer->x_over_qmf[1]; qmf_band_idx++) {
764
47.1M
    for (i = 0; i < qmf_voc_columns; i++) {
765
44.5M
      WORD32 k;
766
44.5M
      FLOAT32 x_zero_band_r, x_zero_band_i;
767
768
44.5M
      x_zero_band_r = *x_norm_ptr++;
769
44.5M
      x_zero_band_i = *x_norm_ptr++;
770
771
489M
      for (k = 0; k < HBE_OPER_BLK_LEN_2; k++) {
772
445M
        register FLOAT32 tmp_r, tmp_i;
773
445M
        tmp_r = *norm_ptr++;
774
445M
        tmp_i = *norm_ptr++;
775
776
445M
        *out_ptr++ +=
777
445M
            ((tmp_r * x_zero_band_r - tmp_i * x_zero_band_i) * 0.3333333f);
778
779
445M
        *out_ptr++ +=
780
445M
            ((tmp_r * x_zero_band_i + tmp_i * x_zero_band_r) * 0.3333333f);
781
782
445M
        norm_ptr += 126;
783
445M
        out_ptr += 126;
784
445M
      }
785
786
44.5M
      norm_ptr -= 128 * 9;
787
44.5M
      out_ptr -= 128 * 8;
788
44.5M
      x_norm_ptr += 126;
789
44.5M
    }
790
2.60M
    out_ptr -= (128 * 2 * qmf_voc_columns) - 2;
791
2.60M
    norm_ptr -= (128 * qmf_voc_columns) - 2;
792
2.60M
    x_norm_ptr -= (128 * qmf_voc_columns) - 2;
793
2.60M
  }
794
228k
}
795
796
VOID ixheaacd_hbe_post_anal_prod3(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
797
135k
                                  WORD32 qmf_voc_columns, WORD32 qmf_band_idx) {
798
135k
  WORD32 i, inp_band_idx, rem;
799
800
135k
  FLOAT32 *out_buf = &ptr_hbe_txposer->qmf_out_buf[2][2 * qmf_band_idx];
801
802
1.45M
  for (; qmf_band_idx < ptr_hbe_txposer->x_over_qmf[2]; qmf_band_idx++) {
803
1.31M
    FLOAT32 temp_r, temp_i;
804
1.31M
    FLOAT32 temp_r1, temp_i1;
805
1.31M
    const FLOAT32 *ptr_sel, *ptr_sel1;
806
807
1.31M
    inp_band_idx = (2 * qmf_band_idx) / 3;
808
1.31M
    ptr_sel = &ixheaac_sel_case[(inp_band_idx + 1) & 3][0];
809
1.31M
    ptr_sel1 = &ixheaac_sel_case[((inp_band_idx + 1) & 3) + 1][0];
810
1.31M
    rem = 2 * qmf_band_idx - 3 * inp_band_idx;
811
812
1.31M
    if (rem == 0 || rem == 1) {
813
885k
      FLOAT32 *in_buf = &ptr_hbe_txposer->qmf_in_buf[0][2 * inp_band_idx];
814
815
16.3M
      for (i = 0; i < qmf_voc_columns; i += 1) {
816
15.4M
        WORD32 k;
817
15.4M
        FLOAT32 vec_x[2 * HBE_OPER_WIN_LEN];
818
15.4M
        FLOAT32 *ptr_vec_x = &vec_x[0];
819
15.4M
        FLOAT32 x_zero_band_r, x_zero_band_i;
820
821
15.4M
        FLOAT32 mag_scaling_fac;
822
823
77.0M
        for (k = 0; k < (HBE_OPER_BLK_LEN_3); k += 2) {
824
61.6M
          FLOAT64 base1;
825
61.6M
          FLOAT64 base = 1e-17;
826
827
61.6M
          temp_r = in_buf[0];
828
61.6M
          temp_i = in_buf[1];
829
830
61.6M
          in_buf += 256;
831
832
61.6M
          base1 = base + temp_r * temp_r;
833
61.6M
          base1 = base1 + temp_i * temp_i;
834
835
61.6M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
836
837
61.6M
          ptr_vec_x[0] = temp_r * mag_scaling_fac;
838
61.6M
          ptr_vec_x[1] = temp_i * mag_scaling_fac;
839
840
61.6M
          temp_r = in_buf[0];
841
61.6M
          temp_i = in_buf[1];
842
843
61.6M
          in_buf -= 128;
844
845
61.6M
          temp_r1 = ptr_sel[0] * temp_r + ptr_sel[1] * temp_i;
846
61.6M
          temp_i1 = ptr_sel[2] * temp_r + ptr_sel[3] * temp_i;
847
848
61.6M
          temp_r = in_buf[0];
849
61.6M
          temp_i = in_buf[1];
850
851
61.6M
          temp_r1 += ptr_sel[4] * temp_r + ptr_sel[5] * temp_i;
852
61.6M
          temp_i1 += ptr_sel[6] * temp_r + ptr_sel[7] * temp_i;
853
854
61.6M
          temp_r1 *= 0.3984033437f;
855
61.6M
          temp_i1 *= 0.3984033437f;
856
857
61.6M
          base1 = base + temp_r1 * temp_r1;
858
61.6M
          base1 = base1 + temp_i1 * temp_i1;
859
61.6M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
860
861
61.6M
          ptr_vec_x[2] = temp_r1 * mag_scaling_fac;
862
61.6M
          ptr_vec_x[3] = temp_i1 * mag_scaling_fac;
863
864
61.6M
          ptr_vec_x += 4;
865
61.6M
          in_buf += 256;
866
61.6M
        }
867
15.4M
        ptr_vec_x = &vec_x[0];
868
15.4M
        temp_r = vec_x[2 * (HBE_ZERO_BAND_IDX - 2)];
869
15.4M
        temp_i = vec_x[(2 * (HBE_ZERO_BAND_IDX - 2)) + 1];
870
871
15.4M
        x_zero_band_r = temp_r * temp_r - temp_i * temp_i;
872
15.4M
        x_zero_band_i = temp_r * temp_i + temp_i * temp_r;
873
874
138M
        for (k = 0; k < (HBE_OPER_BLK_LEN_3); k++) {
875
123M
          temp_r = ptr_vec_x[0] * x_zero_band_r - ptr_vec_x[1] * x_zero_band_i;
876
123M
          temp_i = ptr_vec_x[0] * x_zero_band_i + ptr_vec_x[1] * x_zero_band_r;
877
878
123M
          out_buf[0] += (temp_r * 0.4714045f);
879
123M
          out_buf[1] += (temp_i * 0.4714045f);
880
881
123M
          ptr_vec_x += 2;
882
123M
          out_buf += 128;
883
123M
        }
884
885
15.4M
        in_buf -= 128 * 11;
886
15.4M
        out_buf -= 128 * 6;
887
15.4M
      }
888
885k
    } else {
889
431k
      FLOAT32 *in_buf = &ptr_hbe_txposer->qmf_in_buf[0][2 * inp_band_idx];
890
431k
      FLOAT32 *in_buf1 =
891
431k
          &ptr_hbe_txposer->qmf_in_buf[0][2 * (inp_band_idx + 1)];
892
893
7.93M
      for (i = 0; i < qmf_voc_columns; i++) {
894
7.50M
        WORD32 k;
895
7.50M
        FLOAT32 vec_x[2 * HBE_OPER_WIN_LEN];
896
7.50M
        FLOAT32 vec_x_cap[2 * HBE_OPER_WIN_LEN];
897
898
7.50M
        FLOAT32 x_zero_band_r, x_zero_band_i;
899
7.50M
        FLOAT32 *ptr_vec_x = &vec_x[0];
900
7.50M
        FLOAT32 *ptr_vec_x_cap = &vec_x_cap[0];
901
902
7.50M
        FLOAT32 mag_scaling_fac;
903
904
37.5M
        for (k = 0; k < (HBE_OPER_BLK_LEN_3); k += 2) {
905
30.0M
          FLOAT32 tmp_vr, tmp_vi;
906
30.0M
          FLOAT32 tmp_cr, tmp_ci;
907
30.0M
          FLOAT64 base1;
908
30.0M
          FLOAT64 base = 1e-17;
909
910
30.0M
          temp_r1 = in_buf[0];
911
30.0M
          temp_i1 = in_buf[1];
912
30.0M
          temp_r = in_buf1[0];
913
30.0M
          temp_i = in_buf1[1];
914
915
30.0M
          base1 = base + temp_r * temp_r;
916
30.0M
          base1 = base1 + temp_i * temp_i;
917
918
30.0M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
919
920
30.0M
          ptr_vec_x[0] = temp_r * mag_scaling_fac;
921
30.0M
          ptr_vec_x[1] = temp_i * mag_scaling_fac;
922
923
30.0M
          base1 = base + temp_r1 * temp_r1;
924
30.0M
          base1 = base1 + temp_i1 * temp_i1;
925
926
30.0M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
927
928
30.0M
          ptr_vec_x_cap[0] = temp_r1 * mag_scaling_fac;
929
30.0M
          ptr_vec_x_cap[1] = temp_i1 * mag_scaling_fac;
930
931
30.0M
          in_buf += 256;
932
933
30.0M
          temp_r = in_buf[0];
934
30.0M
          temp_i = in_buf[1];
935
936
30.0M
          temp_r1 = ptr_sel[0] * temp_r + ptr_sel[1] * temp_i;
937
30.0M
          temp_i1 = ptr_sel[2] * temp_r + ptr_sel[3] * temp_i;
938
939
30.0M
          in_buf -= 128;
940
941
30.0M
          temp_r = in_buf[0];
942
30.0M
          temp_i = in_buf[1];
943
944
30.0M
          tmp_cr = temp_r1 + ptr_sel[4] * temp_r + ptr_sel[5] * temp_i;
945
30.0M
          tmp_ci = temp_i1 + ptr_sel[6] * temp_r + ptr_sel[7] * temp_i;
946
947
30.0M
          in_buf1 += 256;
948
949
30.0M
          temp_r = in_buf1[0];
950
30.0M
          temp_i = in_buf1[1];
951
952
30.0M
          temp_r1 = ptr_sel1[0] * temp_r + ptr_sel1[1] * temp_i;
953
30.0M
          temp_i1 = ptr_sel1[2] * temp_r + ptr_sel1[3] * temp_i;
954
955
30.0M
          in_buf1 -= 128;
956
957
30.0M
          temp_r = in_buf1[0];
958
30.0M
          temp_i = in_buf1[1];
959
960
30.0M
          tmp_vr = temp_r1 + ptr_sel1[4] * temp_r + ptr_sel1[5] * temp_i;
961
30.0M
          tmp_vi = temp_i1 + ptr_sel1[6] * temp_r + ptr_sel1[7] * temp_i;
962
963
30.0M
          tmp_cr *= 0.3984033437f;
964
30.0M
          tmp_ci *= 0.3984033437f;
965
966
30.0M
          tmp_vr *= 0.3984033437f;
967
30.0M
          tmp_vi *= 0.3984033437f;
968
969
30.0M
          base1 = base + tmp_vr * tmp_vr;
970
30.0M
          base1 = base1 + tmp_vi * tmp_vi;
971
972
30.0M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
973
974
30.0M
          ptr_vec_x[2] = tmp_vr * mag_scaling_fac;
975
30.0M
          ptr_vec_x[3] = tmp_vi * mag_scaling_fac;
976
977
30.0M
          base1 = base + tmp_cr * tmp_cr;
978
30.0M
          base1 = base1 + tmp_ci * tmp_ci;
979
980
30.0M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
981
982
30.0M
          ptr_vec_x_cap[2] = tmp_cr * mag_scaling_fac;
983
30.0M
          ptr_vec_x_cap[3] = tmp_ci * mag_scaling_fac;
984
985
30.0M
          in_buf += 256;
986
30.0M
          in_buf1 += 256;
987
30.0M
          ptr_vec_x += 4;
988
30.0M
          ptr_vec_x_cap += 4;
989
30.0M
        }
990
7.50M
        ptr_vec_x = &vec_x[0];
991
7.50M
        ptr_vec_x_cap = &vec_x_cap[0];
992
993
7.50M
        temp_r = vec_x_cap[2 * (HBE_ZERO_BAND_IDX - 2)];
994
7.50M
        temp_i = vec_x_cap[2 * (HBE_ZERO_BAND_IDX - 2) + 1];
995
7.50M
        temp_r1 = vec_x[2 * (HBE_ZERO_BAND_IDX - 2)];
996
7.50M
        temp_i1 = vec_x[2 * (HBE_ZERO_BAND_IDX - 2) + 1];
997
998
7.50M
        x_zero_band_r = temp_r * temp_r - temp_i * temp_i;
999
7.50M
        x_zero_band_i = temp_r * temp_i + temp_i * temp_r;
1000
1001
7.50M
        temp_r = temp_r1 * temp_r1 - temp_i1 * temp_i1;
1002
7.50M
        temp_i = temp_r1 * temp_i1 + temp_i1 * temp_r1;
1003
1004
67.5M
        for (k = 0; k < (HBE_OPER_BLK_LEN_3); k++) {
1005
60.0M
          temp_r1 = ptr_vec_x[0] * x_zero_band_r - ptr_vec_x[1] * x_zero_band_i;
1006
60.0M
          temp_i1 = ptr_vec_x[0] * x_zero_band_i + ptr_vec_x[1] * x_zero_band_r;
1007
1008
60.0M
          temp_r1 += ptr_vec_x_cap[0] * temp_r - ptr_vec_x_cap[1] * temp_i;
1009
60.0M
          temp_i1 += ptr_vec_x_cap[0] * temp_i + ptr_vec_x_cap[1] * temp_r;
1010
1011
60.0M
          out_buf[0] += (temp_r1 * 0.23570225f);
1012
60.0M
          out_buf[1] += (temp_i1 * 0.23570225f);
1013
1014
60.0M
          out_buf += 128;
1015
60.0M
          ptr_vec_x += 2;
1016
60.0M
          ptr_vec_x_cap += 2;
1017
60.0M
        }
1018
1019
7.50M
        in_buf -= 128 * 11;
1020
7.50M
        in_buf1 -= 128 * 11;
1021
7.50M
        out_buf -= 128 * 6;
1022
7.50M
      }
1023
431k
    }
1024
1025
1.31M
    out_buf -= (256 * qmf_voc_columns) - 2;
1026
1.31M
  }
1027
135k
}
1028
1029
VOID ixheaacd_hbe_post_anal_prod4(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
1030
81.4k
                                  WORD32 qmf_voc_columns, WORD32 qmf_band_idx) {
1031
81.4k
  WORD32 i, inp_band_idx;
1032
81.4k
  FLOAT32 *out_ptr = &ptr_hbe_txposer->qmf_out_buf[3][2 * qmf_band_idx];
1033
1034
81.4k
  ixheaacd_norm_qmf_in_buf_4(ptr_hbe_txposer, ((qmf_band_idx >> 1) - 1));
1035
1036
802k
  for (; qmf_band_idx < ptr_hbe_txposer->x_over_qmf[3]; qmf_band_idx++) {
1037
721k
    WORD32 ip_idx;
1038
721k
    FLOAT32 temp, temp_r, temp_i;
1039
721k
    FLOAT32 *norm_ptr, *x_norm_ptr;
1040
721k
    inp_band_idx = qmf_band_idx >> 1;
1041
721k
    ip_idx = (qmf_band_idx & 1) ? (inp_band_idx + 1) : (inp_band_idx - 1);
1042
1043
721k
    norm_ptr = &ptr_hbe_txposer->norm_qmf_in_buf[0][2 * ip_idx];
1044
721k
    x_norm_ptr =
1045
721k
        &ptr_hbe_txposer->norm_qmf_in_buf[HBE_ZERO_BAND_IDX][2 * inp_band_idx];
1046
1047
13.2M
    for (i = 0; i < qmf_voc_columns; i++) {
1048
12.5M
      WORD32 k;
1049
12.5M
      FLOAT32 x_zero_band_r, x_zero_band_i;
1050
1051
12.5M
      temp_r = x_zero_band_r = *x_norm_ptr++;
1052
12.5M
      temp_i = x_zero_band_i = *x_norm_ptr++;
1053
1054
12.5M
      temp = x_zero_band_r * x_zero_band_r - x_zero_band_i * x_zero_band_i;
1055
12.5M
      x_zero_band_i =
1056
12.5M
          x_zero_band_r * x_zero_band_i + x_zero_band_i * x_zero_band_r;
1057
1058
12.5M
      x_zero_band_r = temp_r * temp - temp_i * x_zero_band_i;
1059
12.5M
      x_zero_band_i = temp_r * x_zero_band_i + temp_i * temp;
1060
1061
87.9M
      for (k = 0; k < HBE_OPER_BLK_LEN_4; k++) {
1062
75.4M
        temp = *norm_ptr++;
1063
75.4M
        temp_i = *norm_ptr++;
1064
1065
75.4M
        temp_r = temp * x_zero_band_r - temp_i * x_zero_band_i;
1066
75.4M
        temp_i = temp * x_zero_band_i + temp_i * x_zero_band_r;
1067
1068
75.4M
        *out_ptr++ += (temp_r * 0.6666667f);
1069
75.4M
        *out_ptr++ += (temp_i * 0.6666667f);
1070
1071
75.4M
        norm_ptr += 254;
1072
75.4M
        out_ptr += 126;
1073
75.4M
      }
1074
1075
12.5M
      norm_ptr -= 128 * 11;
1076
12.5M
      out_ptr -= 128 * 4;
1077
12.5M
      x_norm_ptr += 126;
1078
12.5M
    }
1079
1080
721k
    out_ptr -= (128 * 2 * qmf_voc_columns) - 2;
1081
721k
  }
1082
81.4k
}
1083
1084
VOID ixheaacd_hbe_post_anal_xprod2(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
1085
                                   WORD32 qmf_voc_columns, WORD32 qmf_band_idx,
1086
9.76k
                                   FLOAT32 p, FLOAT32 *cos_sin_theta) {
1087
9.76k
  WORD32 i;
1088
9.76k
  FLOAT32 *norm_ptr = &ptr_hbe_txposer->norm_qmf_in_buf[1][2 * qmf_band_idx];
1089
9.76k
  FLOAT32 *out_ptr = &ptr_hbe_txposer->qmf_out_buf[1][2 * qmf_band_idx];
1090
9.76k
  FLOAT32 *x_norm_ptr =
1091
9.76k
      &ptr_hbe_txposer->norm_qmf_in_buf[HBE_ZERO_BAND_IDX][2 * qmf_band_idx];
1092
1093
9.76k
  ixheaacd_norm_qmf_in_buf_2(ptr_hbe_txposer, qmf_band_idx);
1094
1095
133k
  for (; qmf_band_idx < ptr_hbe_txposer->x_over_qmf[1]; qmf_band_idx++) {
1096
123k
    WORD32 n1, n2;
1097
123k
    FLOAT64 temp_fac;
1098
123k
    FLOAT32 mag_cmplx_gain = 1.666666667f;
1099
123k
    temp_fac = (2.0 * qmf_band_idx + 1 - p) * 0.5;
1100
123k
    n1 = ((WORD32)(temp_fac)) << 1;
1101
123k
    n2 = ((WORD32)(temp_fac + p)) << 1;
1102
1103
2.18M
    for (i = 0; i < qmf_voc_columns; i++) {
1104
2.06M
      WORD32 k;
1105
2.06M
      FLOAT32 x_zero_band_r, x_zero_band_i;
1106
1107
2.06M
      x_zero_band_r = *x_norm_ptr++;
1108
2.06M
      x_zero_band_i = *x_norm_ptr++;
1109
1110
22.7M
      for (k = 1; k < (HBE_OPER_BLK_LEN_2 + 1); k++) {
1111
20.6M
        register FLOAT32 tmp_r, tmp_i;
1112
20.6M
        tmp_r = *norm_ptr++;
1113
20.6M
        tmp_i = *norm_ptr++;
1114
1115
20.6M
        *out_ptr++ +=
1116
20.6M
            ((tmp_r * x_zero_band_r - tmp_i * x_zero_band_i) * 0.3333333f);
1117
1118
20.6M
        *out_ptr++ +=
1119
20.6M
            ((tmp_r * x_zero_band_i + tmp_i * x_zero_band_r) * 0.3333333f);
1120
1121
20.6M
        norm_ptr += 126;
1122
20.6M
        out_ptr += 126;
1123
20.6M
      }
1124
2.06M
      norm_ptr -= 128 * 9;
1125
2.06M
      out_ptr -= 128 * 8;
1126
2.06M
      x_norm_ptr += 126;
1127
1128
2.06M
      {
1129
2.06M
        WORD32 max_trans_fac, max_n1, max_n2;
1130
2.06M
        FLOAT32 max_mag_value;
1131
2.06M
        FLOAT32 mag_zero_band, mag_n1_band, mag_n2_band, temp;
1132
1133
2.06M
        FLOAT32 *qmf_in_buf_ri =
1134
2.06M
            ptr_hbe_txposer->qmf_in_buf[i + HBE_ZERO_BAND_IDX];
1135
1136
2.06M
        mag_zero_band =
1137
2.06M
            qmf_in_buf_ri[2 * qmf_band_idx] * qmf_in_buf_ri[2 * qmf_band_idx] +
1138
2.06M
            qmf_in_buf_ri[2 * qmf_band_idx + 1] *
1139
2.06M
                qmf_in_buf_ri[2 * qmf_band_idx + 1];
1140
1141
2.06M
        mag_n1_band = qmf_in_buf_ri[n1] * qmf_in_buf_ri[n1] +
1142
2.06M
                      qmf_in_buf_ri[n1 + 1] * qmf_in_buf_ri[n1 + 1];
1143
2.06M
        mag_n2_band = qmf_in_buf_ri[n2] * qmf_in_buf_ri[n2] +
1144
2.06M
                      qmf_in_buf_ri[n2 + 1] * qmf_in_buf_ri[n2 + 1];
1145
1146
2.06M
        temp = min(mag_n1_band, mag_n2_band);
1147
1148
2.06M
        max_mag_value = 0;
1149
2.06M
        max_trans_fac = 0;
1150
2.06M
        max_n1 = 0;
1151
2.06M
        max_n2 = 0;
1152
1153
2.06M
        if (temp > 0) {
1154
1.74M
          max_mag_value = temp;
1155
1.74M
          max_trans_fac = 1;
1156
1.74M
          max_n1 = n1;
1157
1.74M
          max_n2 = n2;
1158
1.74M
        }
1159
1160
2.06M
        if (max_mag_value > mag_zero_band && max_n1 >= 0 &&
1161
479k
            max_n2 < TWICE_QMF_SYNTH_CHANNELS_NUM) {
1162
479k
          FLOAT32 vec_y_r[2], vec_y_i[2];
1163
479k
          FLOAT32 temp_r, temp_i, tmp_r1;
1164
479k
          WORD32 mid_trans_fac, idx;
1165
479k
          FLOAT64 base;
1166
479k
          WORD32 k;
1167
479k
          FLOAT32 mag_scaling_fac = 0.0f;
1168
479k
          FLOAT32 x_zero_band_r = 0;
1169
479k
          FLOAT32 x_zero_band_i = 0;
1170
1171
479k
          mid_trans_fac = 2 - max_trans_fac;
1172
1173
479k
          x_zero_band_r = qmf_in_buf_ri[max_n1];
1174
479k
          x_zero_band_i = qmf_in_buf_ri[max_n1 + 1];
1175
479k
          base = 1e-17;
1176
479k
          base = base + x_zero_band_r * x_zero_band_r;
1177
479k
          base = base + x_zero_band_i * x_zero_band_i;
1178
1179
479k
          mag_scaling_fac = (FLOAT32)(1.0f / base);
1180
479k
          mag_scaling_fac = (FLOAT32)sqrt(sqrt(mag_scaling_fac));
1181
1182
479k
          x_zero_band_r *= mag_scaling_fac;
1183
479k
          x_zero_band_i *= mag_scaling_fac;
1184
1185
479k
          temp_r = x_zero_band_r;
1186
479k
          temp_i = x_zero_band_i;
1187
479k
          for (idx = 0; idx < mid_trans_fac - 1; idx++) {
1188
0
            FLOAT32 tmp = x_zero_band_r;
1189
0
            x_zero_band_r = x_zero_band_r * temp_r - x_zero_band_i * temp_i;
1190
0
            x_zero_band_i = tmp * temp_i + x_zero_band_i * temp_r;
1191
0
          }
1192
1193
1.43M
          for (k = 0; k < 2; k++) {
1194
958k
            temp_r = ptr_hbe_txposer
1195
958k
                         ->qmf_in_buf[i + HBE_ZERO_BAND_IDX - 1 + k][max_n2];
1196
958k
            temp_i =
1197
958k
                ptr_hbe_txposer
1198
958k
                    ->qmf_in_buf[i + HBE_ZERO_BAND_IDX - 1 + k][max_n2 + 1];
1199
1200
958k
            base = 1e-17;
1201
958k
            base = base + temp_r * temp_r;
1202
958k
            base = base + temp_i * temp_i;
1203
1204
958k
            mag_scaling_fac = (FLOAT32)(1.0f / base);
1205
958k
            mag_scaling_fac = (FLOAT32)sqrt(sqrt(mag_scaling_fac));
1206
1207
958k
            temp_r *= mag_scaling_fac;
1208
958k
            temp_i *= mag_scaling_fac;
1209
1210
958k
            vec_y_r[k] = temp_r;
1211
958k
            vec_y_i[k] = temp_i;
1212
958k
          }
1213
1214
479k
          temp_r = vec_y_r[0] * x_zero_band_r - vec_y_i[0] * x_zero_band_i;
1215
479k
          temp_i = vec_y_r[0] * x_zero_band_i + vec_y_i[0] * x_zero_band_r;
1216
1217
479k
          tmp_r1 =
1218
479k
              (FLOAT32)(cos_sin_theta[0] * temp_r - cos_sin_theta[1] * temp_i);
1219
479k
          temp_i =
1220
479k
              (FLOAT32)(cos_sin_theta[0] * temp_i + cos_sin_theta[1] * temp_r);
1221
1222
479k
          ptr_hbe_txposer->qmf_out_buf[i * 2 + (HBE_ZERO_BAND_IDX - 1)]
1223
479k
                                      [2 * qmf_band_idx] +=
1224
479k
              (FLOAT32)(mag_cmplx_gain * tmp_r1);
1225
1226
479k
          ptr_hbe_txposer->qmf_out_buf[i * 2 + (HBE_ZERO_BAND_IDX - 1)]
1227
479k
                                      [2 * qmf_band_idx + 1] +=
1228
479k
              (FLOAT32)(mag_cmplx_gain * temp_i);
1229
1230
479k
          temp_r = vec_y_r[1] * x_zero_band_r - vec_y_i[1] * x_zero_band_i;
1231
479k
          temp_i = vec_y_r[1] * x_zero_band_i + vec_y_i[1] * x_zero_band_r;
1232
1233
479k
          ptr_hbe_txposer->qmf_out_buf[i * 2 + (1 + HBE_ZERO_BAND_IDX - 1)]
1234
479k
                                      [2 * qmf_band_idx] +=
1235
479k
              (FLOAT32)(mag_cmplx_gain * temp_r);
1236
1237
479k
          ptr_hbe_txposer->qmf_out_buf[i * 2 + (1 + HBE_ZERO_BAND_IDX - 1)]
1238
479k
                                      [2 * qmf_band_idx + 1] +=
1239
479k
              (FLOAT32)(mag_cmplx_gain * temp_i);
1240
479k
        }
1241
2.06M
      }
1242
2.06M
    }
1243
1244
123k
    out_ptr -= (128 * 2 * qmf_voc_columns) - 2;
1245
123k
    norm_ptr -= (128 * qmf_voc_columns) - 2;
1246
123k
    x_norm_ptr -= (128 * qmf_voc_columns) - 2;
1247
123k
  }
1248
9.76k
}
1249
1250
VOID ixheaacd_hbe_post_anal_xprod3(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
1251
                                   WORD32 qmf_voc_columns, WORD32 qmf_band_idx,
1252
7.76k
                                   FLOAT32 p, WORD32 pitch_in_bins_idx) {
1253
7.76k
  WORD32 i, inp_band_idx, rem;
1254
1255
7.76k
  FLOAT32 *out_buf = &ptr_hbe_txposer->qmf_out_buf[2][2 * qmf_band_idx];
1256
1257
79.4k
  for (; qmf_band_idx < ptr_hbe_txposer->x_over_qmf[2]; qmf_band_idx++) {
1258
71.7k
    FLOAT32 temp_r, temp_i;
1259
71.7k
    FLOAT32 temp_r1, temp_i1;
1260
71.7k
    const FLOAT32 *ptr_sel, *ptr_sel1;
1261
1262
71.7k
    inp_band_idx = (2 * qmf_band_idx) / 3;
1263
71.7k
    ptr_sel = &ixheaac_sel_case[(inp_band_idx + 1) & 3][0];
1264
71.7k
    ptr_sel1 = &ixheaac_sel_case[((inp_band_idx + 1) & 3) + 1][0];
1265
71.7k
    rem = 2 * qmf_band_idx - 3 * inp_band_idx;
1266
1267
71.7k
    if (rem == 0 || rem == 1) {
1268
48.1k
      FLOAT32 *in_buf = &ptr_hbe_txposer->qmf_in_buf[0][2 * inp_band_idx];
1269
1270
866k
      for (i = 0; i < qmf_voc_columns; i += 1) {
1271
818k
        WORD32 k;
1272
818k
        FLOAT32 vec_x[2 * HBE_OPER_WIN_LEN];
1273
818k
        FLOAT32 *ptr_vec_x = &vec_x[0];
1274
818k
        FLOAT32 x_zero_band_r, x_zero_band_i;
1275
1276
818k
        FLOAT32 mag_scaling_fac;
1277
1278
4.09M
        for (k = 0; k < (HBE_OPER_BLK_LEN_3); k += 2) {
1279
3.27M
          FLOAT64 base1;
1280
3.27M
          FLOAT64 base = 1e-17;
1281
1282
3.27M
          temp_r = in_buf[0];
1283
3.27M
          temp_i = in_buf[1];
1284
1285
3.27M
          in_buf += 256;
1286
1287
3.27M
          base1 = base + temp_r * temp_r;
1288
3.27M
          base1 = base1 + temp_i * temp_i;
1289
1290
3.27M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
1291
1292
3.27M
          ptr_vec_x[0] = temp_r * mag_scaling_fac;
1293
3.27M
          ptr_vec_x[1] = temp_i * mag_scaling_fac;
1294
1295
3.27M
          temp_r = in_buf[0];
1296
3.27M
          temp_i = in_buf[1];
1297
1298
3.27M
          in_buf -= 128;
1299
1300
3.27M
          temp_r1 = ptr_sel[0] * temp_r + ptr_sel[1] * temp_i;
1301
3.27M
          temp_i1 = ptr_sel[2] * temp_r + ptr_sel[3] * temp_i;
1302
1303
3.27M
          temp_r = in_buf[0];
1304
3.27M
          temp_i = in_buf[1];
1305
1306
3.27M
          temp_r1 += ptr_sel[4] * temp_r + ptr_sel[5] * temp_i;
1307
3.27M
          temp_i1 += ptr_sel[6] * temp_r + ptr_sel[7] * temp_i;
1308
1309
3.27M
          temp_r1 *= 0.3984033437f;
1310
3.27M
          temp_i1 *= 0.3984033437f;
1311
1312
3.27M
          base1 = base + temp_r1 * temp_r1;
1313
3.27M
          base1 = base1 + temp_i1 * temp_i1;
1314
3.27M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
1315
1316
3.27M
          ptr_vec_x[2] = temp_r1 * mag_scaling_fac;
1317
3.27M
          ptr_vec_x[3] = temp_i1 * mag_scaling_fac;
1318
1319
3.27M
          ptr_vec_x += 4;
1320
3.27M
          in_buf += 256;
1321
3.27M
        }
1322
818k
        ptr_vec_x = &vec_x[0];
1323
818k
        temp_r = vec_x[2 * (HBE_ZERO_BAND_IDX - 2)];
1324
818k
        temp_i = vec_x[(2 * (HBE_ZERO_BAND_IDX - 2)) + 1];
1325
1326
818k
        x_zero_band_r = temp_r * temp_r - temp_i * temp_i;
1327
818k
        x_zero_band_i = temp_r * temp_i + temp_i * temp_r;
1328
1329
7.36M
        for (k = 0; k < (HBE_OPER_BLK_LEN_3); k++) {
1330
6.54M
          temp_r = ptr_vec_x[0] * x_zero_band_r - ptr_vec_x[1] * x_zero_band_i;
1331
6.54M
          temp_i = ptr_vec_x[0] * x_zero_band_i + ptr_vec_x[1] * x_zero_band_r;
1332
1333
6.54M
          out_buf[0] += (temp_r * 0.4714045f);
1334
6.54M
          out_buf[1] += (temp_i * 0.4714045f);
1335
1336
6.54M
          ptr_vec_x += 2;
1337
6.54M
          out_buf += 128;
1338
6.54M
        }
1339
1340
818k
        ixheaacd_hbe_xprod_proc_3(ptr_hbe_txposer, qmf_band_idx, i, p,
1341
818k
                                  pitch_in_bins_idx);
1342
1343
818k
        in_buf -= 128 * 11;
1344
818k
        out_buf -= 128 * 6;
1345
818k
      }
1346
48.1k
    } else {
1347
23.5k
      FLOAT32 *in_buf = &ptr_hbe_txposer->qmf_in_buf[0][2 * inp_band_idx];
1348
23.5k
      FLOAT32 *in_buf1 =
1349
23.5k
          &ptr_hbe_txposer->qmf_in_buf[0][2 * (inp_band_idx + 1)];
1350
1351
428k
      for (i = 0; i < qmf_voc_columns; i++) {
1352
404k
        WORD32 k;
1353
404k
        FLOAT32 vec_x[2 * HBE_OPER_WIN_LEN];
1354
404k
        FLOAT32 vec_x_cap[2 * HBE_OPER_WIN_LEN];
1355
1356
404k
        FLOAT32 x_zero_band_r, x_zero_band_i;
1357
404k
        FLOAT32 *ptr_vec_x = &vec_x[0];
1358
404k
        FLOAT32 *ptr_vec_x_cap = &vec_x_cap[0];
1359
1360
404k
        FLOAT32 mag_scaling_fac;
1361
1362
2.02M
        for (k = 0; k < (HBE_OPER_BLK_LEN_3); k += 2) {
1363
1.61M
          FLOAT32 tmp_vr, tmp_vi;
1364
1.61M
          FLOAT32 tmp_cr, tmp_ci;
1365
1.61M
          FLOAT64 base1;
1366
1.61M
          FLOAT64 base = 1e-17;
1367
1368
1.61M
          temp_r1 = in_buf[0];
1369
1.61M
          temp_i1 = in_buf[1];
1370
1.61M
          temp_r = in_buf1[0];
1371
1.61M
          temp_i = in_buf1[1];
1372
1373
1.61M
          base1 = base + temp_r * temp_r;
1374
1.61M
          base1 = base1 + temp_i * temp_i;
1375
1376
1.61M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
1377
1378
1.61M
          ptr_vec_x[0] = temp_r * mag_scaling_fac;
1379
1.61M
          ptr_vec_x[1] = temp_i * mag_scaling_fac;
1380
1381
1.61M
          base1 = base + temp_r1 * temp_r1;
1382
1.61M
          base1 = base1 + temp_i1 * temp_i1;
1383
1384
1.61M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
1385
1386
1.61M
          ptr_vec_x_cap[0] = temp_r1 * mag_scaling_fac;
1387
1.61M
          ptr_vec_x_cap[1] = temp_i1 * mag_scaling_fac;
1388
1389
1.61M
          in_buf += 256;
1390
1391
1.61M
          temp_r = in_buf[0];
1392
1.61M
          temp_i = in_buf[1];
1393
1394
1.61M
          temp_r1 = ptr_sel[0] * temp_r + ptr_sel[1] * temp_i;
1395
1.61M
          temp_i1 = ptr_sel[2] * temp_r + ptr_sel[3] * temp_i;
1396
1397
1.61M
          in_buf -= 128;
1398
1399
1.61M
          temp_r = in_buf[0];
1400
1.61M
          temp_i = in_buf[1];
1401
1402
1.61M
          tmp_cr = temp_r1 + ptr_sel[4] * temp_r + ptr_sel[5] * temp_i;
1403
1.61M
          tmp_ci = temp_i1 + ptr_sel[6] * temp_r + ptr_sel[7] * temp_i;
1404
1405
1.61M
          in_buf1 += 256;
1406
1407
1.61M
          temp_r = in_buf1[0];
1408
1.61M
          temp_i = in_buf1[1];
1409
1410
1.61M
          temp_r1 = ptr_sel1[0] * temp_r + ptr_sel1[1] * temp_i;
1411
1.61M
          temp_i1 = ptr_sel1[2] * temp_r + ptr_sel1[3] * temp_i;
1412
1413
1.61M
          in_buf1 -= 128;
1414
1415
1.61M
          temp_r = in_buf1[0];
1416
1.61M
          temp_i = in_buf1[1];
1417
1418
1.61M
          tmp_vr = temp_r1 + ptr_sel1[4] * temp_r + ptr_sel1[5] * temp_i;
1419
1.61M
          tmp_vi = temp_i1 + ptr_sel1[6] * temp_r + ptr_sel1[7] * temp_i;
1420
1421
1.61M
          tmp_cr *= 0.3984033437f;
1422
1.61M
          tmp_ci *= 0.3984033437f;
1423
1424
1.61M
          tmp_vr *= 0.3984033437f;
1425
1.61M
          tmp_vi *= 0.3984033437f;
1426
1427
1.61M
          base1 = base + tmp_vr * tmp_vr;
1428
1.61M
          base1 = base1 + tmp_vi * tmp_vi;
1429
1430
1.61M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
1431
1432
1.61M
          ptr_vec_x[2] = tmp_vr * mag_scaling_fac;
1433
1.61M
          ptr_vec_x[3] = tmp_vi * mag_scaling_fac;
1434
1435
1.61M
          base1 = base + tmp_cr * tmp_cr;
1436
1.61M
          base1 = base1 + tmp_ci * tmp_ci;
1437
1438
1.61M
          mag_scaling_fac = (FLOAT32)(ixheaac_cbrt_calc((FLOAT32)base1));
1439
1440
1.61M
          ptr_vec_x_cap[2] = tmp_cr * mag_scaling_fac;
1441
1.61M
          ptr_vec_x_cap[3] = tmp_ci * mag_scaling_fac;
1442
1443
1.61M
          in_buf += 256;
1444
1.61M
          in_buf1 += 256;
1445
1.61M
          ptr_vec_x += 4;
1446
1.61M
          ptr_vec_x_cap += 4;
1447
1.61M
        }
1448
404k
        ptr_vec_x = &vec_x[0];
1449
404k
        ptr_vec_x_cap = &vec_x_cap[0];
1450
1451
404k
        temp_r = vec_x_cap[2 * (HBE_ZERO_BAND_IDX - 2)];
1452
404k
        temp_i = vec_x_cap[2 * (HBE_ZERO_BAND_IDX - 2) + 1];
1453
404k
        temp_r1 = vec_x[2 * (HBE_ZERO_BAND_IDX - 2)];
1454
404k
        temp_i1 = vec_x[2 * (HBE_ZERO_BAND_IDX - 2) + 1];
1455
1456
404k
        x_zero_band_r = temp_r * temp_r - temp_i * temp_i;
1457
404k
        x_zero_band_i = temp_r * temp_i + temp_i * temp_r;
1458
1459
404k
        temp_r = temp_r1 * temp_r1 - temp_i1 * temp_i1;
1460
404k
        temp_i = temp_r1 * temp_i1 + temp_i1 * temp_r1;
1461
1462
3.64M
        for (k = 0; k < (HBE_OPER_BLK_LEN_3); k++) {
1463
3.23M
          temp_r1 = ptr_vec_x[0] * x_zero_band_r - ptr_vec_x[1] * x_zero_band_i;
1464
3.23M
          temp_i1 = ptr_vec_x[0] * x_zero_band_i + ptr_vec_x[1] * x_zero_band_r;
1465
1466
3.23M
          temp_r1 += ptr_vec_x_cap[0] * temp_r - ptr_vec_x_cap[1] * temp_i;
1467
3.23M
          temp_i1 += ptr_vec_x_cap[0] * temp_i + ptr_vec_x_cap[1] * temp_r;
1468
1469
3.23M
          out_buf[0] += (temp_r1 * 0.23570225f);
1470
3.23M
          out_buf[1] += (temp_i1 * 0.23570225f);
1471
1472
3.23M
          out_buf += 128;
1473
3.23M
          ptr_vec_x += 2;
1474
3.23M
          ptr_vec_x_cap += 2;
1475
3.23M
        }
1476
1477
404k
        ixheaacd_hbe_xprod_proc_3(ptr_hbe_txposer, qmf_band_idx, i, p,
1478
404k
                                  pitch_in_bins_idx);
1479
1480
404k
        in_buf -= 128 * 11;
1481
404k
        in_buf1 -= 128 * 11;
1482
404k
        out_buf -= 128 * 6;
1483
404k
      }
1484
23.5k
    }
1485
1486
71.7k
    out_buf -= (256 * qmf_voc_columns) - 2;
1487
71.7k
  }
1488
7.76k
}
1489
1490
VOID ixheaacd_hbe_post_anal_xprod4(ia_esbr_hbe_txposer_struct *ptr_hbe_txposer,
1491
                                   WORD32 qmf_voc_columns, WORD32 qmf_band_idx,
1492
5.50k
                                   FLOAT32 p, WORD32 pitch_in_bins_idx) {
1493
5.50k
  WORD32 i, inp_band_idx;
1494
5.50k
  FLOAT32 *out_ptr = &ptr_hbe_txposer->qmf_out_buf[3][2 * qmf_band_idx];
1495
1496
5.50k
  ixheaacd_norm_qmf_in_buf_4(ptr_hbe_txposer, ((qmf_band_idx >> 1) - 1));
1497
1498
52.0k
  for (; qmf_band_idx < ptr_hbe_txposer->x_over_qmf[3]; qmf_band_idx++) {
1499
46.5k
    WORD32 ip_idx;
1500
46.5k
    FLOAT32 temp, temp_r, temp_i;
1501
46.5k
    FLOAT32 *norm_ptr, *x_norm_ptr;
1502
46.5k
    inp_band_idx = qmf_band_idx >> 1;
1503
46.5k
    ip_idx = (qmf_band_idx & 1) ? (inp_band_idx + 1) : (inp_band_idx - 1);
1504
1505
46.5k
    norm_ptr = &ptr_hbe_txposer->norm_qmf_in_buf[0][2 * ip_idx];
1506
46.5k
    x_norm_ptr =
1507
46.5k
        &ptr_hbe_txposer->norm_qmf_in_buf[HBE_ZERO_BAND_IDX][2 * inp_band_idx];
1508
1509
813k
    for (i = 0; i < qmf_voc_columns; i++) {
1510
766k
      WORD32 k;
1511
766k
      FLOAT32 x_zero_band_r, x_zero_band_i;
1512
1513
766k
      temp_r = x_zero_band_r = *x_norm_ptr++;
1514
766k
      temp_i = x_zero_band_i = *x_norm_ptr++;
1515
1516
766k
      temp = x_zero_band_r * x_zero_band_r - x_zero_band_i * x_zero_band_i;
1517
766k
      x_zero_band_i =
1518
766k
          x_zero_band_r * x_zero_band_i + x_zero_band_i * x_zero_band_r;
1519
1520
766k
      x_zero_band_r = temp_r * temp - temp_i * x_zero_band_i;
1521
766k
      x_zero_band_i = temp_r * x_zero_band_i + temp_i * temp;
1522
1523
5.36M
      for (k = 0; k < HBE_OPER_BLK_LEN_4; k++) {
1524
4.60M
        temp = *norm_ptr++;
1525
4.60M
        temp_i = *norm_ptr++;
1526
1527
4.60M
        temp_r = temp * x_zero_band_r - temp_i * x_zero_band_i;
1528
4.60M
        temp_i = temp * x_zero_band_i + temp_i * x_zero_band_r;
1529
1530
4.60M
        *out_ptr++ += (temp_r * 0.6666667f);
1531
4.60M
        *out_ptr++ += (temp_i * 0.6666667f);
1532
1533
4.60M
        norm_ptr += 254;
1534
4.60M
        out_ptr += 126;
1535
4.60M
      }
1536
1537
766k
      norm_ptr -= 128 * 11;
1538
766k
      out_ptr -= 128 * 4;
1539
766k
      x_norm_ptr += 126;
1540
1541
766k
      ixheaacd_hbe_xprod_proc_4(ptr_hbe_txposer, qmf_band_idx, i, p,
1542
766k
                                pitch_in_bins_idx);
1543
766k
    }
1544
1545
46.5k
    out_ptr -= (128 * 2 * qmf_voc_columns) - 2;
1546
46.5k
  }
1547
5.50k
}
1548
1549
IA_ERRORCODE ixheaacd_hbe_post_anal_process(
1550
    ia_esbr_hbe_txposer_struct *ptr_hbe_txposer, WORD32 pitch_in_bins,
1551
254k
    WORD32 sbr_upsamp_4_flg) {
1552
254k
  FLOAT32 p;
1553
254k
  WORD32 trans_fac;
1554
254k
  WORD32 qmf_voc_columns = ptr_hbe_txposer->no_bins / 2;
1555
254k
  FLOAT32 cos_sin_theta[2];
1556
1557
254k
  p = (sbr_upsamp_4_flg) ? (FLOAT32)(pitch_in_bins * 0.04166666666666)
1558
254k
                         : (FLOAT32)(pitch_in_bins * 0.08333333333333);
1559
1560
254k
  if (p < SBR_CONST_PMIN) {
1561
244k
    trans_fac = 2;
1562
244k
    if (trans_fac <= ptr_hbe_txposer->max_stretch)
1563
228k
      ixheaacd_hbe_post_anal_prod2(ptr_hbe_txposer, qmf_voc_columns,
1564
228k
                                   ptr_hbe_txposer->x_over_qmf[0]);
1565
1566
244k
    trans_fac = 3;
1567
244k
    if (trans_fac <= ptr_hbe_txposer->max_stretch)
1568
135k
      ixheaacd_hbe_post_anal_prod3(ptr_hbe_txposer, qmf_voc_columns,
1569
135k
                                   ptr_hbe_txposer->x_over_qmf[1]);
1570
1571
244k
    trans_fac = 4;
1572
244k
    if (trans_fac <= ptr_hbe_txposer->max_stretch) {
1573
81.4k
      if (ptr_hbe_txposer->x_over_qmf[2] <= 1) return IA_FATAL_ERROR;
1574
81.4k
      ixheaacd_hbe_post_anal_prod4(ptr_hbe_txposer, qmf_voc_columns,
1575
81.4k
                                   ptr_hbe_txposer->x_over_qmf[2]);
1576
81.4k
    }
1577
1578
244k
  } else {
1579
10.3k
    trans_fac = 2;
1580
10.3k
    if (trans_fac <= ptr_hbe_txposer->max_stretch) {
1581
9.76k
      cos_sin_theta[0] = ixheaac_hbe_x_prod_cos_table_trans_2
1582
9.76k
          [((pitch_in_bins + sbr_upsamp_4_flg * 128) << 1) + 0];
1583
9.76k
      cos_sin_theta[1] = ixheaac_hbe_x_prod_cos_table_trans_2
1584
9.76k
          [((pitch_in_bins + sbr_upsamp_4_flg * 128) << 1) + 1];
1585
1586
9.76k
      ixheaacd_hbe_post_anal_xprod2(ptr_hbe_txposer, qmf_voc_columns,
1587
9.76k
                                    ptr_hbe_txposer->x_over_qmf[0], p,
1588
9.76k
                                    cos_sin_theta);
1589
9.76k
    }
1590
1591
10.3k
    trans_fac = 3;
1592
10.3k
    if (trans_fac <= ptr_hbe_txposer->max_stretch)
1593
7.76k
      ixheaacd_hbe_post_anal_xprod3(ptr_hbe_txposer, qmf_voc_columns,
1594
7.76k
                                    ptr_hbe_txposer->x_over_qmf[1], p,
1595
7.76k
                                    (pitch_in_bins + sbr_upsamp_4_flg * 128));
1596
1597
10.3k
    trans_fac = 4;
1598
10.3k
    if (trans_fac <= ptr_hbe_txposer->max_stretch) {
1599
5.50k
      if (ptr_hbe_txposer->x_over_qmf[2] <= 1) return IA_FATAL_ERROR;
1600
5.50k
      ixheaacd_hbe_post_anal_xprod4(ptr_hbe_txposer, qmf_voc_columns,
1601
5.50k
                                    ptr_hbe_txposer->x_over_qmf[2], p,
1602
5.50k
                                    (pitch_in_bins + sbr_upsamp_4_flg * 128));
1603
5.50k
    }
1604
10.3k
  }
1605
254k
  return IA_NO_ERROR;
1606
254k
}