Coverage Report

Created: 2025-11-09 07:01

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