Coverage Report

Created: 2025-12-08 06:50

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