Coverage Report

Created: 2025-08-03 06:57

/src/libxaac/encoder/ixheaace_sbr_qmf_enc.c
Line
Count
Source (jump to first uncovered line)
1
/******************************************************************************
2
 *                                                                            *
3
 * Copyright (C) 2023 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
21
#include <string.h>
22
#include <stdlib.h>
23
24
#include "ixheaac_type_def.h"
25
#include "ixheaac_constants.h"
26
#include "ixheaace_sbr_def.h"
27
#include "ixheaace_resampler.h"
28
#include "ixheaace_sbr_rom.h"
29
#include "ixheaace_common_rom.h"
30
#include "ixheaace_sbr_hbe.h"
31
#include "ixheaace_sbr_qmf_enc.h"
32
#include "ixheaace_sbr_hybrid.h"
33
34
#include "ixheaace_aac_constants.h"
35
#include "ixheaac_basic_ops32.h"
36
#include "ixheaac_basic_ops16.h"
37
#include "ixheaac_basic_ops40.h"
38
#include "ixheaac_basic_ops.h"
39
40
#include "ixheaace_psy_const.h"
41
#include "ixheaace_tns.h"
42
#include "ixheaace_tns_params.h"
43
#include "ixheaace_rom.h"
44
#include "ixheaace_fft.h"
45
46
192M
static VOID ia_enhaacplus_enc_fct3_4(FLOAT32 *ptr_x) {
47
192M
  FLOAT32 tmp00, tmp01, tmp10, tmp11, xp, xp2;
48
49
192M
  xp2 = ptr_x[1];
50
192M
  xp = ptr_x[0];
51
52
192M
  xp2 = xp2 * IXHEAACE_COS_PI_BY_4;
53
54
192M
  tmp00 = xp + xp2;
55
192M
  tmp01 = xp - xp2;
56
57
192M
  xp = ptr_x[2];
58
192M
  xp2 = ptr_x[3];
59
60
192M
  tmp10 = (xp * IXHEAACE_COS_PI_BY_8) + (xp2 * IXHEAACE_SIN_PI_BY_8);
61
62
192M
  ptr_x[0] = tmp00 + tmp10;
63
192M
  ptr_x[3] = tmp00 - tmp10;
64
65
192M
  tmp11 = (xp * IXHEAACE_SIN_PI_BY_8) - (xp2 * IXHEAACE_COS_PI_BY_8);
66
67
192M
  ptr_x[1] = tmp01 + tmp11;
68
192M
  ptr_x[2] = tmp01 - tmp11;
69
192M
}
70
71
160M
static VOID ia_enhaacplus_enc_fst3_4r(FLOAT32 *ptr_x) {
72
160M
  FLOAT32 tmp00, tmp01, tmp10, tmp11, xp, xp2;
73
74
160M
  xp2 = ptr_x[2];
75
160M
  xp = ptr_x[3];
76
77
160M
  xp2 = xp2 * IXHEAACE_COS_PI_BY_4;
78
79
160M
  tmp00 = xp + xp2;
80
160M
  tmp01 = xp - xp2;
81
82
160M
  xp = ptr_x[1];
83
160M
  xp2 = ptr_x[0];
84
85
160M
  tmp10 = (xp * IXHEAACE_COS_PI_BY_8) + (xp2 * IXHEAACE_SIN_PI_BY_8);
86
87
160M
  ptr_x[3] = tmp00 + tmp10;
88
160M
  ptr_x[0] = tmp10 - tmp00;
89
90
160M
  tmp11 = (xp2 * IXHEAACE_COS_PI_BY_8) - (xp * IXHEAACE_SIN_PI_BY_8);
91
92
160M
  ptr_x[2] = tmp11 - tmp01;
93
160M
  ptr_x[1] = tmp11 + tmp01;
94
160M
}
95
96
96.2M
static VOID ia_enhaacplus_enc_fct4_4r(FLOAT32 *ptr_x) {
97
96.2M
  FLOAT32 tmp00, tmp01, tmp10, tmp11, xp, xp2;
98
99
96.2M
  xp = ptr_x[1];
100
96.2M
  xp2 = ptr_x[0];
101
102
96.2M
  xp = xp * IXHEAACE_COS_PI_BY_4;
103
96.2M
  tmp00 = xp2 + xp;
104
96.2M
  tmp01 = xp2 - xp;
105
106
96.2M
  xp = ptr_x[2];
107
96.2M
  xp2 = ptr_x[3];
108
109
96.2M
  xp = xp * IXHEAACE_COS_PI_BY_4;
110
96.2M
  tmp11 = xp2 - xp;
111
96.2M
  tmp10 = xp2 + xp;
112
113
96.2M
  ptr_x[3] = tmp00 * IXHEAACE_COS_PI_BY_16 + tmp10 * IXHEAACE_SIN_PI_BY_16;
114
96.2M
  ptr_x[0] = tmp00 * IXHEAACE_SIN_PI_BY_16 - tmp10 * IXHEAACE_COS_PI_BY_16;
115
116
96.2M
  ptr_x[2] = tmp01 * IXHEAACE_COS_3_PI_BY_16 - tmp11 * IXHEAACE_SIN_3_PI_BY_16;
117
96.2M
  ptr_x[1] = tmp01 * IXHEAACE_SIN_3_PI_BY_16 + tmp11 * IXHEAACE_COS_3_PI_BY_16;
118
96.2M
}
119
120
64.1M
static VOID ia_enhaacplus_enc_fst4_4(FLOAT32 *ptr_x) {
121
64.1M
  FLOAT32 tmp00, tmp01, tmp10, tmp11, xp, xp2;
122
123
64.1M
  xp = ptr_x[1];
124
64.1M
  xp2 = ptr_x[0];
125
126
64.1M
  xp = xp * IXHEAACE_COS_PI_BY_4;
127
64.1M
  tmp10 = xp2 + xp;
128
64.1M
  tmp11 = xp2 - xp;
129
130
64.1M
  xp = ptr_x[2];
131
64.1M
  xp2 = ptr_x[3];
132
133
64.1M
  xp = xp * IXHEAACE_COS_PI_BY_4;
134
64.1M
  tmp01 = xp2 - xp;
135
64.1M
  tmp00 = xp2 + xp;
136
137
64.1M
  ptr_x[0] = tmp00 * IXHEAACE_COS_PI_BY_16 + tmp10 * IXHEAACE_SIN_PI_BY_16;
138
64.1M
  ptr_x[3] = tmp10 * IXHEAACE_COS_PI_BY_16 - tmp00 * IXHEAACE_SIN_PI_BY_16;
139
64.1M
  ptr_x[1] = tmp11 * IXHEAACE_SIN_3_PI_BY_16 - tmp01 * IXHEAACE_COS_3_PI_BY_16;
140
64.1M
  ptr_x[2] = tmp01 * IXHEAACE_SIN_3_PI_BY_16 + tmp11 * IXHEAACE_COS_3_PI_BY_16;
141
64.1M
}
142
143
32.0M
static VOID ia_enhaacplus_enc_fct3_64(FLOAT32 *ptr_a, ixheaace_str_qmf_tabs *pstr_qmf_tab) {
144
32.0M
  WORD32 k;
145
146
32.0M
  const FLOAT32 *ptr_t1;
147
32.0M
  FLOAT32 xp, xp2, xp3, xp4, wc, ws;
148
149
32.0M
  FLOAT32 *ptr1, *ptr2;
150
32.0M
  FLOAT32 *ptr_ap, *ptr_an;
151
152
  /* bit reversal */
153
32.0M
  xp = ptr_a[1];
154
32.0M
  ptr_a[1] = ptr_a[32];
155
32.0M
  ptr_a[32] = xp;
156
32.0M
  xp = ptr_a[2];
157
32.0M
  ptr_a[2] = ptr_a[16];
158
32.0M
  ptr_a[16] = xp;
159
32.0M
  xp = ptr_a[3];
160
32.0M
  ptr_a[3] = ptr_a[48];
161
32.0M
  ptr_a[48] = xp;
162
32.0M
  xp = ptr_a[4];
163
32.0M
  ptr_a[4] = ptr_a[8];
164
32.0M
  ptr_a[8] = xp;
165
32.0M
  xp = ptr_a[5];
166
32.0M
  ptr_a[5] = ptr_a[40];
167
32.0M
  ptr_a[40] = xp;
168
32.0M
  xp = ptr_a[6];
169
32.0M
  ptr_a[6] = ptr_a[24];
170
32.0M
  ptr_a[24] = xp;
171
32.0M
  xp = ptr_a[7];
172
32.0M
  ptr_a[7] = ptr_a[56];
173
32.0M
  ptr_a[56] = xp;
174
32.0M
  xp = ptr_a[9];
175
32.0M
  ptr_a[9] = ptr_a[36];
176
32.0M
  ptr_a[36] = xp;
177
32.0M
  xp = ptr_a[10];
178
32.0M
  ptr_a[10] = ptr_a[20];
179
32.0M
  ptr_a[20] = xp;
180
32.0M
  xp = ptr_a[11];
181
32.0M
  ptr_a[11] = ptr_a[52];
182
32.0M
  ptr_a[52] = xp;
183
32.0M
  xp = ptr_a[13];
184
32.0M
  ptr_a[13] = ptr_a[44];
185
32.0M
  ptr_a[44] = xp;
186
32.0M
  xp = ptr_a[14];
187
32.0M
  ptr_a[14] = ptr_a[28];
188
32.0M
  ptr_a[28] = xp;
189
32.0M
  xp = ptr_a[15];
190
32.0M
  ptr_a[15] = ptr_a[60];
191
32.0M
  ptr_a[60] = xp;
192
32.0M
  xp = ptr_a[17];
193
32.0M
  ptr_a[17] = ptr_a[34];
194
32.0M
  ptr_a[34] = xp;
195
32.0M
  xp = ptr_a[19];
196
32.0M
  ptr_a[19] = ptr_a[50];
197
32.0M
  ptr_a[50] = xp;
198
32.0M
  xp = ptr_a[21];
199
32.0M
  ptr_a[21] = ptr_a[42];
200
32.0M
  ptr_a[42] = xp;
201
32.0M
  xp = ptr_a[22];
202
32.0M
  ptr_a[22] = ptr_a[26];
203
32.0M
  ptr_a[26] = xp;
204
32.0M
  xp = ptr_a[23];
205
32.0M
  ptr_a[23] = ptr_a[58];
206
32.0M
  ptr_a[58] = xp;
207
32.0M
  xp = ptr_a[25];
208
32.0M
  ptr_a[25] = ptr_a[38];
209
32.0M
  ptr_a[38] = xp;
210
32.0M
  xp = ptr_a[27];
211
32.0M
  ptr_a[27] = ptr_a[54];
212
32.0M
  ptr_a[54] = xp;
213
32.0M
  xp = ptr_a[29];
214
32.0M
  ptr_a[29] = ptr_a[46];
215
32.0M
  ptr_a[46] = xp;
216
32.0M
  xp = ptr_a[31];
217
32.0M
  ptr_a[31] = ptr_a[62];
218
32.0M
  ptr_a[62] = xp;
219
32.0M
  xp = ptr_a[35];
220
32.0M
  ptr_a[35] = ptr_a[49];
221
32.0M
  ptr_a[49] = xp;
222
32.0M
  xp = ptr_a[37];
223
32.0M
  ptr_a[37] = ptr_a[41];
224
32.0M
  ptr_a[41] = xp;
225
32.0M
  xp = ptr_a[39];
226
32.0M
  ptr_a[39] = ptr_a[57];
227
32.0M
  ptr_a[57] = xp;
228
32.0M
  xp = ptr_a[43];
229
32.0M
  ptr_a[43] = ptr_a[53];
230
32.0M
  ptr_a[53] = xp;
231
32.0M
  xp = ptr_a[47];
232
32.0M
  ptr_a[47] = ptr_a[61];
233
32.0M
  ptr_a[61] = xp;
234
32.0M
  xp = ptr_a[55];
235
32.0M
  ptr_a[55] = ptr_a[59];
236
32.0M
  ptr_a[59] = xp;
237
238
32.0M
  xp = ptr_a[33];
239
32.0M
  xp2 = ptr_a[62];
240
32.0M
  ptr_a[62] = xp2 - xp;
241
32.0M
  ptr_a[33] = xp2 + xp;
242
32.0M
  xp = ptr_a[34];
243
32.0M
  xp2 = ptr_a[60];
244
32.0M
  ptr_a[60] = xp2 - xp;
245
32.0M
  ptr_a[34] = xp2 + xp;
246
32.0M
  xp = ptr_a[35];
247
32.0M
  xp2 = ptr_a[61];
248
32.0M
  ptr_a[61] = xp2 - xp;
249
32.0M
  ptr_a[35] = xp2 + xp;
250
32.0M
  xp = ptr_a[36];
251
32.0M
  xp2 = ptr_a[56];
252
32.0M
  ptr_a[56] = xp2 - xp;
253
32.0M
  ptr_a[36] = xp2 + xp;
254
32.0M
  xp = ptr_a[37];
255
32.0M
  xp2 = ptr_a[57];
256
32.0M
  ptr_a[57] = xp2 - xp;
257
32.0M
  ptr_a[37] = xp2 + xp;
258
32.0M
  xp = ptr_a[38];
259
32.0M
  xp2 = ptr_a[58];
260
32.0M
  ptr_a[58] = xp2 - xp;
261
32.0M
  ptr_a[38] = xp2 + xp;
262
32.0M
  xp = ptr_a[39];
263
32.0M
  xp2 = ptr_a[59];
264
32.0M
  ptr_a[59] = xp2 - xp;
265
32.0M
  ptr_a[39] = xp2 + xp;
266
32.0M
  xp = ptr_a[40];
267
32.0M
  xp2 = ptr_a[48];
268
32.0M
  ptr_a[48] = xp2 - xp;
269
32.0M
  ptr_a[40] = xp2 + xp;
270
32.0M
  xp = ptr_a[41];
271
32.0M
  xp2 = ptr_a[49];
272
32.0M
  ptr_a[49] = xp2 - xp;
273
32.0M
  ptr_a[41] = xp2 + xp;
274
32.0M
  xp = ptr_a[42];
275
32.0M
  xp2 = ptr_a[50];
276
32.0M
  ptr_a[50] = xp2 - xp;
277
32.0M
  ptr_a[42] = xp2 + xp;
278
32.0M
  xp = ptr_a[43];
279
32.0M
  xp2 = ptr_a[51];
280
32.0M
  ptr_a[51] = xp2 - xp;
281
32.0M
  ptr_a[43] = xp2 + xp;
282
32.0M
  xp = ptr_a[44];
283
32.0M
  xp2 = ptr_a[52];
284
32.0M
  ptr_a[52] = xp2 - xp;
285
32.0M
  ptr_a[44] = xp2 + xp;
286
32.0M
  xp = ptr_a[45];
287
32.0M
  xp2 = ptr_a[53];
288
32.0M
  ptr_a[53] = xp2 - xp;
289
32.0M
  ptr_a[45] = xp2 + xp;
290
32.0M
  xp = ptr_a[46];
291
32.0M
  xp2 = ptr_a[54];
292
32.0M
  ptr_a[54] = xp2 - xp;
293
32.0M
  ptr_a[46] = xp2 + xp;
294
32.0M
  xp = ptr_a[47];
295
32.0M
  xp2 = ptr_a[55];
296
32.0M
  ptr_a[55] = xp2 - xp;
297
32.0M
  ptr_a[47] = xp2 + xp;
298
32.0M
  xp = ptr_a[17];
299
32.0M
  xp2 = ptr_a[30];
300
32.0M
  ptr_a[30] = xp2 - xp;
301
32.0M
  ptr_a[17] = xp2 + xp;
302
32.0M
  xp = ptr_a[18];
303
32.0M
  xp2 = ptr_a[28];
304
32.0M
  ptr_a[28] = xp2 - xp;
305
32.0M
  ptr_a[18] = xp2 + xp;
306
32.0M
  xp = ptr_a[19];
307
32.0M
  xp2 = ptr_a[29];
308
32.0M
  ptr_a[29] = xp2 - xp;
309
32.0M
  ptr_a[19] = xp2 + xp;
310
32.0M
  xp = ptr_a[20];
311
32.0M
  xp2 = ptr_a[24];
312
32.0M
  ptr_a[24] = xp2 - xp;
313
32.0M
  ptr_a[20] = xp2 + xp;
314
32.0M
  xp = ptr_a[21];
315
32.0M
  xp2 = ptr_a[25];
316
32.0M
  ptr_a[25] = xp2 - xp;
317
32.0M
  ptr_a[21] = xp2 + xp;
318
32.0M
  xp = ptr_a[22];
319
32.0M
  xp2 = ptr_a[26];
320
32.0M
  ptr_a[26] = xp2 - xp;
321
32.0M
  ptr_a[22] = xp2 + xp;
322
32.0M
  xp = ptr_a[23];
323
32.0M
  xp2 = ptr_a[27];
324
32.0M
  ptr_a[27] = xp2 - xp;
325
32.0M
  ptr_a[23] = xp2 + xp;
326
32.0M
  xp = ptr_a[9];
327
32.0M
  xp2 = ptr_a[14];
328
32.0M
  ptr_a[14] = xp2 - xp;
329
32.0M
  ptr_a[9] = xp2 + xp;
330
32.0M
  xp = ptr_a[10];
331
32.0M
  xp2 = ptr_a[12];
332
32.0M
  ptr_a[12] = xp2 - xp;
333
32.0M
  ptr_a[10] = xp2 + xp;
334
32.0M
  xp = ptr_a[11];
335
32.0M
  xp2 = ptr_a[13];
336
32.0M
  ptr_a[13] = xp2 - xp;
337
32.0M
  ptr_a[11] = xp2 + xp;
338
32.0M
  xp = ptr_a[41];
339
32.0M
  xp2 = ptr_a[46];
340
32.0M
  ptr_a[46] = xp2 - xp;
341
32.0M
  ptr_a[41] = xp2 + xp;
342
32.0M
  xp = ptr_a[42];
343
32.0M
  xp2 = ptr_a[44];
344
32.0M
  ptr_a[44] = xp2 - xp;
345
32.0M
  ptr_a[42] = xp2 + xp;
346
32.0M
  xp = ptr_a[43];
347
32.0M
  xp2 = ptr_a[45];
348
32.0M
  ptr_a[45] = xp2 - xp;
349
32.0M
  ptr_a[43] = xp2 + xp;
350
32.0M
  xp = ptr_a[49];
351
32.0M
  xp2 = ptr_a[54];
352
32.0M
  ptr_a[49] = xp - xp2;
353
32.0M
  ptr_a[54] = xp2 + xp;
354
32.0M
  xp = ptr_a[50];
355
32.0M
  xp2 = ptr_a[52];
356
32.0M
  ptr_a[50] = xp - xp2;
357
32.0M
  ptr_a[52] = xp2 + xp;
358
32.0M
  xp = ptr_a[51];
359
32.0M
  xp2 = ptr_a[53];
360
32.0M
  ptr_a[51] = xp - xp2;
361
32.0M
  ptr_a[53] = xp2 + xp;
362
32.0M
  xp = ptr_a[5];
363
32.0M
  xp2 = ptr_a[6];
364
32.0M
  ptr_a[6] = xp2 - xp;
365
32.0M
  ptr_a[5] = xp2 + xp;
366
32.0M
  xp = ptr_a[21];
367
32.0M
  xp2 = ptr_a[22];
368
32.0M
  ptr_a[22] = xp2 - xp;
369
32.0M
  ptr_a[21] = xp2 + xp;
370
32.0M
  xp = ptr_a[25];
371
32.0M
  xp2 = ptr_a[26];
372
32.0M
  ptr_a[25] = xp - xp2;
373
32.0M
  ptr_a[26] = xp2 + xp;
374
32.0M
  xp = ptr_a[37];
375
32.0M
  xp2 = ptr_a[38];
376
32.0M
  ptr_a[38] = xp2 - xp;
377
32.0M
  ptr_a[37] = xp2 + xp;
378
32.0M
  xp = ptr_a[57];
379
32.0M
  xp2 = ptr_a[58];
380
32.0M
  ptr_a[57] = xp - xp2;
381
32.0M
  ptr_a[58] = xp2 + xp;
382
383
32.0M
  ia_enhaacplus_enc_fct3_4(ptr_a);
384
32.0M
  ia_enhaacplus_enc_fct4_4r(ptr_a + 4);
385
32.0M
  ia_enhaacplus_enc_fct3_4(ptr_a + 8);
386
32.0M
  ia_enhaacplus_enc_fst3_4r(ptr_a + 12);
387
388
32.0M
  ia_enhaacplus_enc_fct3_4(ptr_a + 16);
389
32.0M
  ia_enhaacplus_enc_fct4_4r(ptr_a + 20);
390
32.0M
  ia_enhaacplus_enc_fst4_4(ptr_a + 24);
391
32.0M
  ia_enhaacplus_enc_fst3_4r(ptr_a + 28);
392
393
32.0M
  ia_enhaacplus_enc_fct3_4(ptr_a + 32);
394
32.0M
  ia_enhaacplus_enc_fct4_4r(ptr_a + 36);
395
32.0M
  ia_enhaacplus_enc_fct3_4(ptr_a + 40);
396
32.0M
  ia_enhaacplus_enc_fst3_4r(ptr_a + 44);
397
398
32.0M
  ia_enhaacplus_enc_fct3_4(ptr_a + 48);
399
32.0M
  ia_enhaacplus_enc_fst3_4r(ptr_a + 52);
400
32.0M
  ia_enhaacplus_enc_fst4_4(ptr_a + 56);
401
32.0M
  ia_enhaacplus_enc_fst3_4r(ptr_a + 60);
402
403
32.0M
  ptr_ap = ptr_a;
404
32.0M
  ptr_an = ptr_a + 7;
405
160M
  for (k = 4; k != 0; k--) {
406
128M
    xp = *ptr_ap++;
407
128M
    xp2 = *ptr_an--;
408
128M
    xp3 = *(ptr_ap + 15);
409
128M
    xp4 = *(ptr_an + 17);
410
128M
    *(ptr_an + 1) = xp - xp2;
411
128M
    *(ptr_ap - 1) = xp + xp2;
412
413
128M
    xp = *(ptr_ap + 23);
414
128M
    xp2 = *(ptr_an + 25);
415
128M
    *(ptr_an + 17) = xp3 - xp4;
416
128M
    *(ptr_ap + 15) = xp3 + xp4;
417
418
128M
    xp3 = *(ptr_ap + 31);
419
128M
    xp4 = *(ptr_an + 33);
420
128M
    *(ptr_ap + 23) = xp - xp2;
421
128M
    *(ptr_an + 25) = xp + xp2;
422
423
128M
    xp = *(ptr_ap + 55);
424
128M
    xp2 = *(ptr_an + 57);
425
128M
    *(ptr_an + 33) = xp3 - xp4;
426
128M
    *(ptr_ap + 31) = xp3 + xp4;
427
428
128M
    *(ptr_ap + 55) = xp - xp2;
429
128M
    *(ptr_an + 57) = xp + xp2;
430
128M
  }
431
432
32.0M
  ptr_t1 = pstr_qmf_tab->cos_sin_fct4_8;
433
434
32.0M
  ptr_ap = ptr_a + 8;
435
32.0M
  ptr_an = ptr_a + 15;
436
160M
  for (k = 4; k != 0; k--) {
437
128M
    wc = *ptr_t1++;
438
128M
    ws = *ptr_t1++;
439
440
128M
    xp = *ptr_ap * wc + *ptr_an * ws;
441
128M
    *ptr_ap = *ptr_ap * ws - *ptr_an * wc;
442
128M
    ptr_ap++;
443
128M
    *ptr_an-- = xp;
444
445
128M
    xp = *(ptr_ap + 31) * wc + *(ptr_an + 33) * ws;
446
128M
    *(ptr_ap + 31) = *(ptr_ap + 31) * ws - *(ptr_an + 33) * wc;
447
128M
    *(ptr_an + 33) = xp;
448
449
128M
    xp = *(ptr_ap + 39) * ws + *(ptr_an + 41) * wc;
450
128M
    *(ptr_an + 41) = *(ptr_ap + 39) * wc - *(ptr_an + 41) * ws;
451
128M
    *(ptr_ap + 39) = xp;
452
128M
  }
453
454
32.0M
  ptr_ap = ptr_a;
455
32.0M
  ptr_an = ptr_a + 15;
456
288M
  for (k = 8; k != 0; k--) {
457
256M
    xp = *ptr_ap++;
458
256M
    xp2 = *ptr_an--;
459
256M
    xp3 = *(ptr_ap + 31);
460
256M
    xp4 = *(ptr_an + 33);
461
462
256M
    *(ptr_an + 1) = xp - xp2;
463
256M
    *(ptr_ap - 1) = xp + xp2;
464
465
256M
    xp = *(ptr_ap + 47);
466
256M
    xp2 = *(ptr_an + 49);
467
256M
    *(ptr_an + 33) = xp3 - xp4;
468
256M
    *(ptr_ap + 31) = xp3 + xp4;
469
256M
    *(ptr_ap + 47) = xp - xp2;
470
256M
    *(ptr_an + 49) = xp + xp2;
471
256M
  }
472
473
32.0M
  ptr_t1 = pstr_qmf_tab->cos_sin_fct4_16;
474
475
32.0M
  ptr1 = &ptr_a[16];
476
32.0M
  ptr2 = &ptr_a[31];
477
288M
  for (k = 7; k >= 0; k--) {
478
256M
    wc = *ptr_t1++;
479
256M
    ws = *ptr_t1++;
480
481
256M
    xp = *ptr1;
482
256M
    xp2 = *ptr2;
483
484
256M
    *ptr2-- = xp * wc + xp2 * ws;
485
256M
    *ptr1++ = xp * ws - xp2 * wc;
486
256M
  }
487
488
32.0M
  ptr1 = &ptr_a[0];
489
32.0M
  ptr2 = &ptr_a[31];
490
545M
  for (k = 15; k >= 0; k--) {
491
513M
    xp = *ptr1;
492
513M
    xp2 = *ptr2;
493
494
513M
    *ptr1++ = xp + xp2;
495
513M
    *ptr2-- = xp - xp2;
496
513M
  }
497
498
32.0M
  ptr_t1 = pstr_qmf_tab->cos_sin_fct4_32;
499
32.0M
  ptr1 = &ptr_a[32];
500
32.0M
  ptr2 = &ptr_a[63];
501
502
545M
  for (k = 15; k >= 0; k--) {
503
513M
    wc = *ptr_t1++;
504
513M
    ws = *ptr_t1++;
505
506
513M
    xp = *ptr1;
507
513M
    xp2 = *ptr2;
508
509
513M
    *ptr2-- = xp * wc + xp2 * ws;
510
513M
    *ptr1++ = xp * ws - xp2 * wc;
511
513M
  }
512
513
32.0M
  ptr1 = &ptr_a[0];
514
32.0M
  ptr2 = &ptr_a[63];
515
1.05G
  for (k = 31; k >= 0; k--) {
516
1.02G
    xp = *ptr1;
517
1.02G
    xp2 = *ptr2;
518
519
1.02G
    *ptr1++ = xp + xp2;
520
1.02G
    *ptr2-- = xp - xp2;
521
1.02G
  }
522
32.0M
}
523
524
16.0M
static VOID ia_enhaacplus_enc_fst3_64(FLOAT32 *ptr_a, ixheaace_str_qmf_tabs *pstr_qmf_tab) {
525
16.0M
  WORD32 k;
526
16.0M
  FLOAT32 xp, xp2;
527
16.0M
  FLOAT32 *ptr1, *ptr2;
528
529
16.0M
  ptr1 = &ptr_a[0];
530
16.0M
  ptr2 = &ptr_a[63];
531
532
529M
  for (k = 31; k >= 0; k--) {
533
513M
    xp = *ptr1;
534
513M
    xp2 = *ptr2;
535
513M
    *ptr2-- = xp;
536
513M
    *ptr1++ = xp2;
537
513M
  }
538
539
16.0M
  ia_enhaacplus_enc_fct3_64(ptr_a, pstr_qmf_tab);
540
541
16.0M
  ptr1 = &ptr_a[1];
542
543
272M
  for (k = 15; k >= 0; k--) {
544
256M
    xp = *ptr1;
545
256M
    xp2 = *(ptr1 + 2);
546
256M
    *ptr1++ = -xp;
547
256M
    ptr1++;
548
256M
    *ptr1++ = -xp2;
549
256M
    ptr1++;
550
256M
  }
551
16.0M
}
552
553
2.00M
static VOID ixheaace_sbr_pre_mdct(FLOAT32 *ptr_x, WORD32 len, const FLOAT32 *ptr_sine_window) {
554
2.00M
  WORD32 i;
555
2.00M
  FLOAT32 wre, wim, re1, re2, im1, im2;
556
557
34.1M
  for (i = 0; i < len / 4; i++) {
558
32.0M
    re1 = ptr_x[2 * i];
559
32.0M
    re2 = ptr_x[2 * i + 1];
560
32.0M
    im2 = ptr_x[len - 2 - 2 * i];
561
32.0M
    im1 = ptr_x[len - 1 - 2 * i];
562
563
32.0M
    wim = ptr_sine_window[2 * i];
564
32.0M
    wre = ptr_sine_window[len - 1 - 2 * i];
565
566
32.0M
    ptr_x[2 * i] = im1 * wim + re1 * wre;
567
568
32.0M
    ptr_x[2 * i + 1] = im1 * wre - re1 * wim;
569
570
32.0M
    wre = ptr_sine_window[len - 2 - 2 * i];
571
32.0M
    wim = ptr_sine_window[2 * i + 1];
572
573
32.0M
    ptr_x[len - 2 - 2 * i] = im2 * wim + re2 * wre;
574
575
32.0M
    ptr_x[len - 1 - 2 * i] = -(im2 * wre - re2 * wim);
576
32.0M
  }
577
2.00M
}
578
2.00M
static VOID ixheaace_sbr_pre_mdst(FLOAT32 *ptr_x, WORD32 len, const FLOAT32 *ptr_sine_window) {
579
2.00M
  WORD32 i;
580
2.00M
  FLOAT32 wre, wim, re1, re2, im1, im2;
581
582
34.1M
  for (i = 0; i < len / 4; i++) {
583
32.0M
    re1 = -ptr_x[2 * i];
584
32.0M
    re2 = ptr_x[2 * i + 1];
585
32.0M
    im2 = -ptr_x[len - 2 - 2 * i];
586
32.0M
    im1 = ptr_x[len - 1 - 2 * i];
587
588
32.0M
    wim = ptr_sine_window[2 * i];
589
32.0M
    wre = ptr_sine_window[len - 1 - 2 * i];
590
591
32.0M
    ptr_x[2 * i] = im1 * wim + re1 * wre;
592
593
32.0M
    ptr_x[2 * i + 1] = im1 * wre - re1 * wim;
594
595
32.0M
    wim = ptr_sine_window[2 * i + 1];
596
32.0M
    wre = ptr_sine_window[len - 2 - 2 * i];
597
598
32.0M
    ptr_x[len - 2 - 2 * i] = im2 * wim + re2 * wre;
599
600
32.0M
    ptr_x[len - 1 - 2 * i] = -(im2 * wre - re2 * wim);
601
32.0M
  }
602
2.00M
}
603
2.00M
static VOID ixheaace_sbr_post_mdct(FLOAT32 *ptr_x, WORD32 len, const FLOAT32 *ptr_trig_data) {
604
2.00M
  WORD32 i;
605
2.00M
  FLOAT32 wre, wim, re1, re2, im1, im2;
606
607
2.00M
  FLOAT32 temp1 = -ptr_x[1];
608
2.00M
  FLOAT32 temp2 = ptr_x[len / 2];
609
2.00M
  FLOAT32 temp3 = ptr_x[len / 2 + 1];
610
2.00M
  FLOAT32 val = 0.70709228515625f;
611
612
2.00M
  re2 = ptr_x[len - 2];
613
2.00M
  im2 = ptr_x[len - 1];
614
32.0M
  for (i = 1; i < len / 4; i++) {
615
30.0M
    wim = ptr_trig_data[i];
616
30.0M
    wre = ptr_trig_data[len / 2 - 1 - i];
617
618
30.0M
    ptr_x[2 * i - 1] = (re2 * wre - im2 * wim);
619
30.0M
    ptr_x[len - 2 * i] = (re2 * wim + im2 * wre);
620
621
30.0M
    re1 = ptr_x[2 * i];
622
30.0M
    im1 = ptr_x[2 * i + 1];
623
30.0M
    re2 = ptr_x[len - 2 - 2 * i];
624
30.0M
    im2 = ptr_x[len - 1 - 2 * i];
625
626
30.0M
    ptr_x[2 * i] = (re1 * wre + im1 * wim);
627
30.0M
    ptr_x[len - 1 - 2 * i] = (re1 * wim - im1 * wre);
628
30.0M
  }
629
630
2.00M
  ptr_x[len / 2 - 1] = (temp2 - temp3) * val;
631
2.00M
  ptr_x[len / 2] = (temp2 + temp3) * val;
632
2.00M
  ptr_x[len - 1] = temp1;
633
2.00M
}
634
2.00M
static VOID ixheaace_sbr_post_mdst(FLOAT32 *ptr_x, WORD32 len, const FLOAT32 *ptr_trig_data) {
635
2.00M
  WORD32 i;
636
2.00M
  FLOAT32 wre, wim, re1, re2, im1, im2;
637
2.00M
  FLOAT32 temp0 = -ptr_x[0];
638
2.00M
  FLOAT32 temp1 = ptr_x[1];
639
2.00M
  FLOAT32 temp2 = ptr_x[len / 2];
640
2.00M
  FLOAT32 temp3 = ptr_x[len / 2 + 1];
641
2.00M
  FLOAT32 val = 0.70709228515625f;
642
643
2.00M
  re2 = ptr_x[len - 2];
644
2.00M
  im2 = ptr_x[len - 1];
645
646
32.0M
  for (i = 1; i < len / 4; i++) {
647
30.0M
    wim = ptr_trig_data[i];
648
30.0M
    wre = ptr_trig_data[len / 2 - 1 - i];
649
650
30.0M
    ptr_x[2 * i - 1] = -(re2 * wim + im2 * wre);
651
30.0M
    ptr_x[len - 2 * i] = -(re2 * wre - im2 * wim);
652
653
30.0M
    re1 = ptr_x[2 * i];
654
30.0M
    im1 = ptr_x[2 * i + 1];
655
30.0M
    re2 = ptr_x[len - 2 - 2 * i];
656
30.0M
    im2 = ptr_x[len - 1 - 2 * i];
657
658
30.0M
    ptr_x[len - 1 - 2 * i] = -(re1 * wre + im1 * wim);
659
30.0M
    ptr_x[2 * i] = -(re1 * wim - im1 * wre);
660
30.0M
  }
661
662
2.00M
  ptr_x[len / 2] = (temp3 - temp2) * val;
663
2.00M
  ptr_x[len / 2 - 1] = -(temp3 + temp2) * val;
664
665
2.00M
  ptr_x[0] = temp1;
666
2.00M
  ptr_x[len - 1] = temp0;
667
2.00M
}
668
2.00M
static VOID ixheaace_sbr_mdct(FLOAT32 *ptr_dct_data, WORD32 n, FLOAT32 *ptr_sbr_scratch) {
669
2.00M
  ixheaace_sbr_pre_mdct(ptr_dct_data, n, &long_window_sine_ld_64[0]);
670
671
2.00M
  ia_enhaacplus_enc_complex_fft_p2(ptr_dct_data, n / 2, ptr_sbr_scratch);
672
673
2.00M
  ixheaace_sbr_post_mdct(ptr_dct_data, n, &fft_twiddle_tab_32[0]);
674
2.00M
}
675
676
2.00M
static VOID ixheaace_sbr_mdst(FLOAT32 *ptr_dct_data, WORD32 n, FLOAT32 *ptr_sbr_scratch) {
677
2.00M
  ixheaace_sbr_pre_mdst(ptr_dct_data, n, &long_window_sine_ld_64[0]);
678
679
2.00M
  ia_enhaacplus_enc_complex_fft_p2(ptr_dct_data, n / 2, ptr_sbr_scratch);
680
681
2.00M
  ixheaace_sbr_post_mdst(ptr_dct_data, n, &fft_twiddle_tab_32[0]);
682
2.00M
}
683
static VOID ia_enhaacplus_enc_forward_modulation(const FLOAT32 *ptr_time_in,
684
                                                 FLOAT32 *ptr_r_subband, FLOAT32 *ptr_i_subband,
685
                                                 ixheaace_str_qmf_tabs *pstr_qmf_tab,
686
18.0M
                                                 WORD32 is_ld_sbr, FLOAT32 *ptr_sbr_scratch) {
687
18.0M
  WORD32 i;
688
18.0M
  FLOAT32 tmp1, tmp2, tmp3, tmp4;
689
18.0M
  const FLOAT32 *ptr_inp1, *ptr_inp2;
690
18.0M
  FLOAT32 *ptr_re, *ptr_im;
691
18.0M
  FLOAT32 real, imag;
692
18.0M
  const FLOAT32 *ptr_window = &sbr_sin_cos_window[0];
693
18.0M
  if (is_ld_sbr) {
694
2.00M
    ptr_re = &ptr_r_subband[0];
695
2.00M
    ptr_im = &ptr_i_subband[0];
696
2.00M
    ptr_inp1 = &ptr_time_in[0];
697
16.0M
  } else {
698
16.0M
    ptr_r_subband[0] = ptr_time_in[0];
699
16.0M
    ptr_re = &ptr_r_subband[1];
700
16.0M
    ptr_im = &ptr_i_subband[0];
701
16.0M
    ptr_inp1 = &ptr_time_in[1];
702
16.0M
  }
703
18.0M
  ptr_inp2 = &ptr_time_in[127];
704
18.0M
  if (is_ld_sbr) {
705
2.00M
    i = IXHEAACE_QMF_CHANNELS / 2 - 1;
706
66.2M
    while (i >= 0) {
707
64.1M
      tmp1 = *ptr_inp1++;
708
64.1M
      tmp2 = *ptr_inp2--;
709
64.1M
      tmp3 = *ptr_inp1++;
710
64.1M
      tmp4 = *ptr_inp2--;
711
64.1M
      *ptr_re++ = (tmp1 - tmp2);
712
64.1M
      *ptr_im++ = (tmp1 + tmp2);
713
64.1M
      *ptr_re++ = (tmp3 - tmp4);
714
64.1M
      *ptr_im++ = (tmp3 + tmp4);
715
64.1M
      i--;
716
64.1M
    }
717
718
2.00M
    ixheaace_sbr_mdct(ptr_r_subband, 64, ptr_sbr_scratch);
719
2.00M
    ixheaace_sbr_mdst(ptr_i_subband, 64, ptr_sbr_scratch);
720
721
2.00M
    i = 0;
722
130M
    while (i < IXHEAACE_QMF_CHANNELS) {
723
128M
      real = ptr_r_subband[i];
724
128M
      imag = ptr_i_subband[i];
725
128M
      ptr_r_subband[i] =
726
128M
          imag * ptr_window[i] + real * ptr_window[2 * IXHEAACE_QMF_CHANNELS - 1 - i];
727
128M
      ptr_i_subband[i] =
728
128M
          imag * ptr_window[2 * IXHEAACE_QMF_CHANNELS - 1 - i] - real * ptr_window[i];
729
128M
      i++;
730
128M
    }
731
16.0M
  } else {
732
513M
    for (i = 30; i >= 0; i--) {
733
497M
      tmp1 = *ptr_inp1++;
734
497M
      tmp2 = *ptr_inp2--;
735
497M
      tmp3 = *ptr_inp1++;
736
737
497M
      *ptr_re++ = tmp1 - tmp2;
738
497M
      tmp4 = *ptr_inp2--;
739
497M
      *ptr_im++ = tmp1 + tmp2;
740
497M
      *ptr_re++ = tmp3 - tmp4;
741
497M
      *ptr_im++ = tmp3 + tmp4;
742
497M
    }
743
16.0M
    tmp1 = *ptr_inp1;
744
16.0M
    tmp2 = *ptr_inp2;
745
16.0M
    *ptr_re = tmp1 - tmp2;
746
16.0M
    *ptr_im = tmp1 + tmp2;
747
748
16.0M
    ptr_i_subband[63] = ptr_time_in[64];
749
750
16.0M
    ia_enhaacplus_enc_fct3_64(ptr_r_subband, pstr_qmf_tab);
751
752
16.0M
    ia_enhaacplus_enc_fst3_64(ptr_i_subband, pstr_qmf_tab);
753
16.0M
  }
754
18.0M
}
755
756
static VOID ia_enhaacplus_enc_sbr_qmf_analysis_win_add(const FLOAT32 *ptr_pf_l,
757
                                                       const FLOAT32 *ptr_pf_r, FLOAT32 *ptr_fp1,
758
                                                       FLOAT32 *ptr_fp2,
759
16.0M
                                                       FLOAT32 *ptr_syn_buffer) {
760
16.0M
  FLOAT32 accu_l = 0, accu_r = 0;
761
16.0M
  WORD k;
762
1.04G
  for (k = 0; k < 64; k++) {
763
1.02G
    accu_l = 0;
764
1.02G
    accu_r = 0;
765
766
1.02G
    {
767
1.02G
      accu_l += *ptr_pf_l++ * ptr_fp1[k];
768
1.02G
      accu_l += *ptr_pf_l++ * ptr_fp1[128 + k];
769
1.02G
      accu_l += *ptr_pf_l++ * ptr_fp1[256 + k];
770
1.02G
      accu_l += *ptr_pf_l++ * ptr_fp1[384 + k];
771
1.02G
      accu_l += *ptr_pf_l++ * ptr_fp1[512 + k];
772
773
1.02G
      accu_r += *--ptr_pf_r * ptr_fp2[k];
774
1.02G
      accu_r += *--ptr_pf_r * ptr_fp2[128 + k];
775
1.02G
      accu_r += *--ptr_pf_r * ptr_fp2[256 + k];
776
1.02G
      accu_r += *--ptr_pf_r * ptr_fp2[384 + k];
777
1.02G
      accu_r += *--ptr_pf_r * ptr_fp2[512 + k];
778
1.02G
    }
779
1.02G
    ptr_syn_buffer[127 - k] = accu_l;
780
1.02G
    ptr_syn_buffer[63 - k] = accu_r;
781
1.02G
    ptr_pf_l += 5;
782
1.02G
    ptr_pf_r -= 5;
783
1.02G
  }
784
16.0M
}
785
786
static VOID ia_enhaacplus_enc_sbr_cld_analysis_win_add(FLOAT32 *ptr_filter_states,
787
                                                       const FLOAT32 *ptr_coeffs,
788
                                                       FLOAT32 *ptr_sync_buffer,
789
2.00M
                                                       WORD32 num_qmf_ch, WORD32 time_sn_stride) {
790
2.00M
  WORD32 i;
791
2.00M
  WORD32 len = num_qmf_ch * time_sn_stride;
792
2.00M
  FLOAT32 *ptr_fil_states = &ptr_filter_states[CLD_FILTER_LENGTH - 1];
793
794
2.00M
  memset(ptr_sync_buffer, 0, len * sizeof(*ptr_sync_buffer));
795
796
1.28G
  for (i = 0; i < CLD_FILTER_LENGTH; i++) {
797
1.28G
    ptr_sync_buffer[i % len] += (*ptr_fil_states-- * ptr_coeffs[i]);
798
1.28G
  }
799
2.00M
}
800
VOID ixheaace_sbr_analysis_filtering(const FLOAT32 *ptr_time_in, WORD32 time_sn_stride,
801
                                     FLOAT32 **ptr_ana_r, FLOAT32 **ptr_ana_i,
802
                                     ixheaace_pstr_sbr_qmf_filter_bank pstr_qmf_bank,
803
                                     ixheaace_str_qmf_tabs *pstr_qmf_tab, WORD32 num_qmf_subsamp,
804
                                     WORD32 is_ld_sbr, FLOAT32 *ptr_sbr_scratch,
805
565k
                                     WORD32 is_ps_960) {
806
565k
  WORD32 i, k;
807
565k
  const FLOAT32 *ptr_pf_l, *ptr_pf_r;
808
565k
  FLOAT32 *ptr_fp1, *ptr_fp2, *ptr_tmp;
809
565k
  FLOAT32 syn_buffer[2 * IXHEAACE_QMF_CHANNELS] = {0};
810
565k
  const FLOAT32 *ptr_start_coeff_l;
811
565k
  const FLOAT32 *ptr_start_coeff_r;
812
565k
  FLOAT32 *ptr_qmf_states_curr_pos;
813
565k
  WORD32 start_coeff_cnt = 0;
814
565k
  WORD16 flag = 0;
815
565k
  WORD32 offset;
816
565k
  if (is_ld_sbr) {
817
129k
    offset = 576;
818
129k
    i = 0;
819
2.13M
    while (i < num_qmf_subsamp) {
820
2.00M
      ptr_qmf_states_curr_pos = pstr_qmf_bank->ptr_qmf_states_curr_pos;
821
822
2.00M
      if (ptr_time_in) {
823
2.00M
        FLOAT32 *ptr_qmf_states = pstr_qmf_bank->ptr_qmf_states_curr_pos + offset;
824
825
2.00M
        const FLOAT32 *ptr_inp = &ptr_time_in[(i * 64 * time_sn_stride)];
826
2.00M
        FLOAT32 tmp1, tmp2, tmp3, tmp4;
827
34.1M
        for (k = 15; k >= 0; k--) {
828
32.0M
          tmp1 = *ptr_inp;
829
32.0M
          ptr_inp += time_sn_stride;
830
831
32.0M
          tmp2 = *ptr_inp;
832
32.0M
          ptr_inp += time_sn_stride;
833
834
32.0M
          tmp3 = *ptr_inp;
835
32.0M
          ptr_inp += time_sn_stride;
836
837
32.0M
          *ptr_qmf_states++ = tmp1;
838
32.0M
          tmp4 = *ptr_inp;
839
32.0M
          ptr_inp += time_sn_stride;
840
841
32.0M
          *ptr_qmf_states++ = tmp2;
842
32.0M
          *ptr_qmf_states++ = tmp3;
843
32.0M
          *ptr_qmf_states++ = tmp4;
844
32.0M
        }
845
2.00M
      } else {
846
0
        memset(&ptr_qmf_states_curr_pos[0], 0,
847
0
               sizeof(ptr_qmf_states_curr_pos[0]) * IXHEAACE_QMF_CHANNELS);
848
0
      }
849
850
2.00M
      ia_enhaacplus_enc_sbr_cld_analysis_win_add(&ptr_qmf_states_curr_pos[0],
851
2.00M
                                                 pstr_qmf_bank->ptr_filter, syn_buffer,
852
2.00M
                                                 IXHEAACE_QMF_CHANNELS, time_sn_stride);
853
854
2.00M
      ia_enhaacplus_enc_forward_modulation(syn_buffer, &(ptr_ana_r[i][0]), &(ptr_ana_i[i][0]),
855
2.00M
                                           pstr_qmf_tab, is_ld_sbr, ptr_sbr_scratch);
856
857
1.15G
      for (k = 0; k < offset; k++) {
858
1.15G
        pstr_qmf_bank->ptr_qmf_states_curr_pos[k] =
859
1.15G
            pstr_qmf_bank->ptr_qmf_states_curr_pos[64 + k];
860
1.15G
      }
861
862
2.00M
      i++;
863
2.00M
    }
864
435k
  } else {
865
435k
    flag = pstr_qmf_bank->flag;
866
435k
    ptr_fp1 = pstr_qmf_bank->ptr_qmf_states_buf;
867
435k
    ptr_fp2 = pstr_qmf_bank->ptr_qmf_states_buf + 64;
868
435k
    pstr_qmf_bank->ptr_qmf_states_curr_pos =
869
435k
        ((FLOAT32 *)(pstr_qmf_bank->ptr_qmf_states_buf) + (pstr_qmf_bank->offset * 64));
870
871
435k
    if (pstr_qmf_bank->offset == 8) {
872
84.3k
      pstr_qmf_bank->offset = 0;
873
351k
    } else {
874
351k
      pstr_qmf_bank->offset += 2;
875
351k
    }
876
877
435k
    ptr_start_coeff_l = pstr_qmf_bank->ptr_ref_coeff_l + pstr_qmf_bank->offset_l;
878
435k
    ptr_start_coeff_r = pstr_qmf_bank->ptr_ref_coeff_r - pstr_qmf_bank->offset_r;
879
880
16.4M
    for (i = 0; i < num_qmf_subsamp; i++) {
881
16.0M
      ptr_qmf_states_curr_pos = pstr_qmf_bank->ptr_qmf_states_curr_pos;
882
16.0M
      ptr_tmp = ptr_fp1;
883
16.0M
      ptr_fp1 = ptr_fp2;
884
16.0M
      ptr_fp2 = ptr_tmp;
885
16.0M
      if (((1 == is_ld_sbr) && start_coeff_cnt) || ((0 == is_ld_sbr) && (i % 2))) {
886
8.02M
        ptr_start_coeff_l--;
887
8.02M
        if (ptr_start_coeff_l == pstr_qmf_bank->ptr_ref_coeff_l) {
888
1.60M
          ptr_start_coeff_l += 5;
889
1.60M
        }
890
8.02M
      } else {
891
8.02M
        ptr_start_coeff_r++;
892
8.02M
        if (ptr_start_coeff_r == pstr_qmf_bank->ptr_ref_coeff_r) {
893
1.60M
          ptr_start_coeff_r -= 5;
894
1.60M
        }
895
8.02M
      }
896
897
16.0M
      if (ptr_time_in) {
898
16.0M
        FLOAT32 *ptr_qmf_states = &ptr_qmf_states_curr_pos[0];
899
16.0M
        const FLOAT32 *ptr_inp = &ptr_time_in[(i * 64 * time_sn_stride)];
900
16.0M
        FLOAT32 tmp1, tmp2, tmp3, tmp4;
901
272M
        for (k = 15; k >= 0; k--) {
902
256M
          tmp1 = *ptr_inp;
903
256M
          ptr_inp += time_sn_stride;
904
905
256M
          tmp2 = *ptr_inp;
906
256M
          ptr_inp += time_sn_stride;
907
908
256M
          tmp3 = *ptr_inp;
909
256M
          ptr_inp += time_sn_stride;
910
911
256M
          *ptr_qmf_states++ = tmp1;
912
256M
          tmp4 = *ptr_inp;
913
256M
          ptr_inp += time_sn_stride;
914
915
256M
          *ptr_qmf_states++ = tmp2;
916
256M
          *ptr_qmf_states++ = tmp3;
917
256M
          *ptr_qmf_states++ = tmp4;
918
256M
        }
919
16.0M
      } else {
920
0
        memset(&ptr_qmf_states_curr_pos[0], 0,
921
0
               sizeof(ptr_qmf_states_curr_pos[0]) * IXHEAACE_QMF_CHANNELS);
922
0
      }
923
924
16.0M
      ptr_pf_l = ptr_start_coeff_l;
925
16.0M
      ptr_pf_r = ptr_start_coeff_r;
926
927
16.0M
      ia_enhaacplus_enc_sbr_qmf_analysis_win_add(ptr_pf_l, ptr_pf_r, ptr_fp1, ptr_fp2,
928
16.0M
                                                 syn_buffer);
929
930
16.0M
      ia_enhaacplus_enc_forward_modulation(syn_buffer, &(ptr_ana_r[i][0]), &(ptr_ana_i[i][0]),
931
16.0M
                                           pstr_qmf_tab, is_ld_sbr, ptr_sbr_scratch);
932
933
16.0M
      pstr_qmf_bank->ptr_qmf_states_curr_pos = pstr_qmf_bank->ptr_qmf_states_curr_pos + 64;
934
16.0M
      if (pstr_qmf_bank->ptr_qmf_states_curr_pos == pstr_qmf_bank->ptr_qmf_states_buf + 640) {
935
1.60M
        pstr_qmf_bank->ptr_qmf_states_curr_pos = pstr_qmf_bank->ptr_qmf_states_buf;
936
1.60M
      }
937
16.0M
    }
938
939
435k
    pstr_qmf_bank->offset_l = ptr_start_coeff_l - pstr_qmf_bank->ptr_ref_coeff_l;
940
435k
    pstr_qmf_bank->offset_r = pstr_qmf_bank->ptr_ref_coeff_r - ptr_start_coeff_r;
941
435k
    pstr_qmf_bank->flag = flag;
942
435k
  }
943
565k
  if (is_ps_960 == 1) {
944
15.6k
    memset(&ptr_ana_r[num_qmf_subsamp][0], 0, sizeof(ptr_ana_r[num_qmf_subsamp][0]) *
945
15.6k
           IXHEAACE_QMF_CHANNELS * (IXHEAACE_QMF_TIME_SLOTS - num_qmf_subsamp));
946
15.6k
    memset(&ptr_ana_i[num_qmf_subsamp][0], 0, sizeof(ptr_ana_i[num_qmf_subsamp][0]) *
947
15.6k
           IXHEAACE_QMF_CHANNELS * (IXHEAACE_QMF_TIME_SLOTS - num_qmf_subsamp));
948
15.6k
  }
949
565k
}
950
951
VOID ixheaace_get_energy_from_cplx_qmf(
952
    FLOAT32 **ptr_energy_vals, FLOAT32 **ptr_real_values, FLOAT32 **ptr_imag_values,
953
    WORD32 is_ld_sbr, WORD32 num_time_slots, WORD32 samp_ratio_fac,
954
    ixheaace_str_hbe_enc *pstr_hbe_enc, WORD32 op_delay, WORD32 harmonic_sbr)
955
956
530k
{
957
530k
  WORD32 j, k;
958
530k
  FLOAT32 avg_fac = 0.5f;
959
530k
  if (samp_ratio_fac == 4) {
960
61.5k
    avg_fac = 0.25f;
961
61.5k
  }
962
530k
  if (0 == is_ld_sbr) {
963
400k
    FLOAT32 *ptr_energy_val = &ptr_energy_vals[0][0];
964
400k
    FLOAT32 *ptr_hbe_real = NULL;
965
400k
    FLOAT32 *ptr_hbe_imag = NULL;
966
400k
    if (harmonic_sbr == 1) {
967
106k
      ptr_hbe_real = &pstr_hbe_enc->qmf_buf_real[op_delay][0];
968
106k
      ptr_hbe_imag = &pstr_hbe_enc->qmf_buf_imag[op_delay][0];
969
106k
    }
970
6.75M
    for (k = 0; k < num_time_slots; k++) {
971
413M
      for (j = 0; j < IXHEAACE_QMF_CHANNELS; j++) {
972
406M
        FLOAT32 tmp = 0.0f;
973
406M
        if (harmonic_sbr == 1) {
974
108M
          FLOAT32 real_hbe, imag_hbe;
975
108M
          real_hbe = *(ptr_hbe_real);
976
108M
          imag_hbe = *(ptr_hbe_imag);
977
108M
          tmp += (real_hbe * real_hbe) + (imag_hbe * imag_hbe);
978
108M
          *ptr_energy_val = tmp;
979
108M
          ptr_hbe_real++;
980
108M
          ptr_hbe_imag++;
981
108M
          ptr_energy_val++;
982
298M
        } else {
983
298M
          FLOAT32 real, imag;
984
298M
          WORD32 i, subband;
985
298M
          subband = samp_ratio_fac * k;
986
937M
          for (i = 0; i < samp_ratio_fac; i++) {
987
639M
            real = ptr_real_values[subband + i][j];
988
639M
            imag = ptr_imag_values[subband + i][j];
989
639M
            tmp += (real * real) + (imag * imag);
990
639M
          }
991
298M
          ptr_energy_vals[k][j] = tmp * avg_fac;
992
298M
        }
993
406M
      }
994
6.35M
      if (harmonic_sbr == 1) {
995
1.69M
        ptr_hbe_real += 64;
996
1.69M
        ptr_hbe_imag += 64;
997
1.69M
      }
998
6.35M
    }
999
400k
  } else {
1000
129k
    FLOAT32 *ptr_real = &ptr_real_values[0][0];
1001
129k
    FLOAT32 *ptr_imag = &ptr_imag_values[0][0];
1002
2.13M
    for (k = 0; k < num_time_slots; k++) {
1003
2.00M
      FLOAT32 *ptr_energy_val = &ptr_energy_vals[k][0];
1004
130M
      for (j = 0; j < 64; j++) {
1005
128M
        FLOAT32 real, imag, tmp;
1006
128M
        real = *ptr_real;
1007
128M
        ptr_real++;
1008
128M
        imag = *ptr_imag;
1009
128M
        ptr_imag++;
1010
1011
128M
        tmp = (real * real) + (imag * imag);
1012
128M
        *ptr_energy_val = tmp;
1013
128M
        ptr_energy_val++;
1014
128M
      }
1015
2.00M
    }
1016
129k
  }
1017
530k
}
1018
1019
1.47M
VOID ixheaace_fft16(FLOAT32 *vector) {
1020
1.47M
  FLOAT32 var10, var11, var12, var13, var14, var15, var16, var17, var18, var19, var110, var111,
1021
1.47M
      var112, var113, var114, var115;
1022
1.47M
  FLOAT32 var20, var21, var22, var23, var24, var25, var26, var27, var28, var29, var210, var211,
1023
1.47M
      var212, var213, var214, var215;
1024
1.47M
  FLOAT32 arr0, arr1, arr2, arr3, arr4, arr5, arr6, arr7, arr8, arr9, arr10, arr11, arr12, arr13,
1025
1.47M
      arr14, arr15;
1026
1027
1.47M
  arr0 = vector[0] + vector[16];
1028
1.47M
  arr8 = vector[8] + vector[24];
1029
1.47M
  var10 = arr0 + arr8;
1030
1.47M
  var12 = arr0 - arr8;
1031
1.47M
  arr1 = vector[1] + vector[17];
1032
1.47M
  arr9 = vector[9] + vector[25];
1033
1.47M
  var11 = arr1 + arr9;
1034
1.47M
  var13 = arr1 - arr9;
1035
1.47M
  arr2 = vector[2] + vector[18];
1036
1.47M
  arr10 = vector[10] + vector[26];
1037
1.47M
  var14 = arr2 + arr10;
1038
1.47M
  var16 = arr2 - arr10;
1039
1.47M
  arr3 = vector[3] + vector[19];
1040
1.47M
  arr11 = vector[11] + vector[27];
1041
1.47M
  var15 = arr3 + arr11;
1042
1.47M
  var17 = arr3 - arr11;
1043
1.47M
  arr4 = vector[4] + vector[20];
1044
1.47M
  arr12 = vector[12] + vector[28];
1045
1.47M
  var18 = arr4 + arr12;
1046
1.47M
  var110 = arr4 - arr12;
1047
1.47M
  arr5 = vector[5] + vector[21];
1048
1.47M
  arr13 = vector[13] + vector[29];
1049
1.47M
  var19 = arr5 + arr13;
1050
1.47M
  var111 = arr5 - arr13;
1051
1.47M
  arr6 = vector[6] + vector[22];
1052
1.47M
  arr14 = vector[14] + vector[30];
1053
1.47M
  var112 = arr6 + arr14;
1054
1.47M
  var114 = arr6 - arr14;
1055
1.47M
  arr7 = vector[7] + vector[23];
1056
1.47M
  arr15 = vector[15] + vector[31];
1057
1.47M
  var113 = arr7 + arr15;
1058
1.47M
  var115 = arr7 - arr15;
1059
1060
1.47M
  var20 = var10 + var18;
1061
1.47M
  var24 = var10 - var18;
1062
1.47M
  var21 = var11 + var19;
1063
1.47M
  var25 = var11 - var19;
1064
1.47M
  var28 = var12 - var111;
1065
1.47M
  var210 = var12 + var111;
1066
1.47M
  var29 = var13 + var110;
1067
1.47M
  var211 = var13 - var110;
1068
1.47M
  var22 = var14 + var112;
1069
1.47M
  var27 = var14 - var112;
1070
1.47M
  var23 = var15 + var113;
1071
1.47M
  var26 = var113 - var15;
1072
1073
1.47M
  var11 = var16 + var114;
1074
1.47M
  var12 = var16 - var114;
1075
1.47M
  var10 = var17 + var115;
1076
1.47M
  var13 = var17 - var115;
1077
1078
1.47M
  var212 = (var10 + var12) * IXHEAACE_INV_SQRT2;
1079
1.47M
  var214 = (var10 - var12) * IXHEAACE_INV_SQRT2;
1080
1.47M
  var213 = (var13 - var11) * IXHEAACE_INV_SQRT2;
1081
1.47M
  var215 = (var11 + var13) * -IXHEAACE_INV_SQRT2;
1082
1083
1.47M
  arr0 = vector[0] - vector[16];
1084
1.47M
  arr1 = vector[1] - vector[17];
1085
1.47M
  arr2 = vector[2] - vector[18];
1086
1.47M
  arr3 = vector[3] - vector[19];
1087
1.47M
  arr4 = vector[4] - vector[20];
1088
1.47M
  arr5 = vector[5] - vector[21];
1089
1.47M
  arr6 = vector[6] - vector[22];
1090
1.47M
  arr7 = vector[7] - vector[23];
1091
1.47M
  arr8 = vector[8] - vector[24];
1092
1.47M
  arr9 = vector[9] - vector[25];
1093
1.47M
  arr10 = vector[10] - vector[26];
1094
1.47M
  arr11 = vector[11] - vector[27];
1095
1.47M
  arr12 = vector[12] - vector[28];
1096
1.47M
  arr13 = vector[13] - vector[29];
1097
1.47M
  arr14 = vector[14] - vector[30];
1098
1.47M
  arr15 = vector[15] - vector[31];
1099
1100
1.47M
  var19 = ((arr2 + arr14) * -IXHEAACE_COS_3PI_DIV8);
1101
1.47M
  var110 = ((arr2 - arr14) * IXHEAACE_COS_PI_DIV8);
1102
1.47M
  var18 = ((arr3 + arr15) * IXHEAACE_COS_3PI_DIV8);
1103
1.47M
  var111 = ((arr3 - arr15) * IXHEAACE_COS_PI_DIV8);
1104
1.47M
  var15 = ((arr4 + arr12) * -IXHEAACE_INV_SQRT2);
1105
1.47M
  var16 = ((arr4 - arr12) * IXHEAACE_INV_SQRT2);
1106
1.47M
  var14 = ((arr5 + arr13) * IXHEAACE_INV_SQRT2);
1107
1.47M
  var17 = ((arr5 - arr13) * IXHEAACE_INV_SQRT2);
1108
1.47M
  var113 = ((arr6 + arr10) * -IXHEAACE_COS_PI_DIV8);
1109
1.47M
  var114 = ((arr6 - arr10) * IXHEAACE_COS_3PI_DIV8);
1110
1.47M
  var112 = ((arr7 + arr11) * IXHEAACE_COS_PI_DIV8);
1111
1.47M
  var115 = ((arr7 - arr11) * IXHEAACE_COS_3PI_DIV8);
1112
1113
1.47M
  arr2 = (var18 * IXHEAACE_SQRT2PLUS1) - (var112 * IXHEAACE_SQRT2MINUS1);
1114
1.47M
  arr3 = (var19 * IXHEAACE_SQRT2PLUS1) - (var113 * IXHEAACE_SQRT2MINUS1);
1115
1.47M
  arr4 = (var110 * IXHEAACE_SQRT2MINUS1) - (var114 * IXHEAACE_SQRT2PLUS1);
1116
1.47M
  arr5 = (var111 * IXHEAACE_SQRT2MINUS1) - (var115 * IXHEAACE_SQRT2PLUS1);
1117
1118
1.47M
  var18 = var18 + var112;
1119
1.47M
  var19 = var19 + var113;
1120
1.47M
  var110 = var110 + var114;
1121
1.47M
  var111 = var111 + var115;
1122
1123
1.47M
  arr6 = arr0 + var14;
1124
1.47M
  arr10 = arr0 - var14;
1125
1.47M
  arr7 = arr1 + var15;
1126
1.47M
  arr11 = arr1 - var15;
1127
1128
1.47M
  arr12 = var16 - arr9;
1129
1.47M
  arr14 = var16 + arr9;
1130
1.47M
  arr13 = arr8 + var17;
1131
1.47M
  arr15 = arr8 - var17;
1132
1133
1.47M
  var10 = arr6 - arr14;
1134
1.47M
  var12 = arr6 + arr14;
1135
1.47M
  var11 = arr7 + arr15;
1136
1.47M
  var13 = arr7 - arr15;
1137
1.47M
  var14 = arr10 + arr12;
1138
1.47M
  var16 = arr10 - arr12;
1139
1.47M
  var15 = arr11 + arr13;
1140
1.47M
  var17 = arr11 - arr13;
1141
1142
1.47M
  arr10 = var18 + var110;
1143
1.47M
  var110 = var18 - var110;
1144
1.47M
  arr11 = var19 + var111;
1145
1.47M
  var111 = var19 - var111;
1146
1147
1.47M
  var112 = (arr2 + arr4);
1148
1.47M
  var114 = (arr2 - arr4);
1149
1.47M
  var113 = (arr3 + arr5);
1150
1.47M
  var115 = (arr3 - arr5);
1151
1152
1.47M
  vector[0] = var20 + var22;
1153
1.47M
  vector[1] = var21 + var23;
1154
1.47M
  vector[2] = var12 + arr10;
1155
1.47M
  vector[3] = var13 + arr11;
1156
1.47M
  vector[4] = var210 + var212;
1157
1.47M
  vector[5] = var211 + var213;
1158
1.47M
  vector[6] = var10 + var112;
1159
1.47M
  vector[7] = var11 + var113;
1160
1.47M
  vector[8] = var24 - var26;
1161
1.47M
  vector[9] = var25 - var27;
1162
1.47M
  vector[10] = var16 + var114;
1163
1.47M
  vector[11] = var17 + var115;
1164
1.47M
  vector[12] = var28 + var214;
1165
1.47M
  vector[13] = var29 + var215;
1166
1.47M
  vector[14] = var14 + var110;
1167
1.47M
  vector[15] = var15 + var111;
1168
1.47M
  vector[16] = var20 - var22;
1169
1.47M
  vector[17] = var21 - var23;
1170
1.47M
  vector[18] = var12 - arr10;
1171
1.47M
  vector[19] = var13 - arr11;
1172
1.47M
  vector[20] = var210 - var212;
1173
1.47M
  vector[21] = var211 - var213;
1174
1.47M
  vector[22] = var10 - var112;
1175
1.47M
  vector[23] = var11 - var113;
1176
1.47M
  vector[24] = var24 + var26;
1177
1.47M
  vector[25] = var25 + var27;
1178
1.47M
  vector[26] = var16 - var114;
1179
1.47M
  vector[27] = var17 - var115;
1180
1.47M
  vector[28] = var28 - var214;
1181
1.47M
  vector[29] = var29 - var215;
1182
1.47M
  vector[30] = var14 - var110;
1183
1.47M
  vector[31] = var15 - var111;
1184
1.47M
}
1185
1186
static VOID ixheaace_cos_sim_mod(FLOAT32 *ptr_subband,
1187
735k
                                 ixheaace_pstr_sbr_qmf_filter_bank pstr_qmf_bank) {
1188
735k
  WORD32 i;
1189
735k
  FLOAT32 re1, im1, re2, im2, re3, im3;
1190
735k
  const FLOAT32 *ptr_cos_sin_tab = pstr_qmf_bank->ptr_flt_cos_twiddle;
1191
735k
  const FLOAT32 *ptr_cos_sin_tab2 = &pstr_qmf_bank->ptr_flt_cos_twiddle[31];
1192
735k
  const FLOAT32 *ptr_alt_sin_tab;
1193
735k
  FLOAT32 wim, wre;
1194
735k
  FLOAT32 *ptr_subband2 = ptr_subband + 32;
1195
1196
6.61M
  for (i = 0; i < 8; i++) {
1197
5.88M
    wre = *ptr_cos_sin_tab++;
1198
5.88M
    wim = *ptr_cos_sin_tab++;
1199
5.88M
    re1 = ptr_subband[2 * i];
1200
5.88M
    im1 = ptr_subband[31 - 2 * i];
1201
5.88M
    re3 = ptr_subband[30 - 2 * i];
1202
5.88M
    im3 = ptr_subband[2 * i + 1];
1203
5.88M
    ptr_subband[2 * i] = (im1 * wim) + (re1 * wre);
1204
5.88M
    ptr_subband[2 * i + 1] = (im1 * wre) - (re1 * wim);
1205
5.88M
    re1 = ptr_subband2[2 * i];
1206
5.88M
    im1 = ptr_subband2[31 - 2 * i];
1207
5.88M
    re2 = ptr_subband2[30 - 2 * i];
1208
5.88M
    im2 = ptr_subband2[2 * i + 1];
1209
5.88M
    ptr_subband2[2 * i + 1] = (im1 * wre) + (re1 * wim);
1210
5.88M
    ptr_subband2[2 * i] = (im1 * wim) - (re1 * wre);
1211
5.88M
    wim = *ptr_cos_sin_tab2--;
1212
5.88M
    wre = *ptr_cos_sin_tab2--;
1213
5.88M
    ptr_subband[30 - 2 * i] = (im3 * wim) + (re3 * wre);
1214
5.88M
    ptr_subband[31 - 2 * i] = (im3 * wre) - (re3 * wim);
1215
5.88M
    ptr_subband2[31 - 2 * i] = (im2 * wre) + (re2 * wim);
1216
5.88M
    ptr_subband2[30 - 2 * i] = (im2 * wim) - (re2 * wre);
1217
5.88M
  }
1218
1219
735k
  ixheaace_fft16(ptr_subband);
1220
735k
  ixheaace_fft16(ptr_subband2);
1221
1222
735k
  ptr_alt_sin_tab = &pstr_qmf_bank->ptr_flt_alt_sin_twiddle[0];
1223
735k
  wim = *ptr_alt_sin_tab++;
1224
735k
  wre = *ptr_alt_sin_tab++;
1225
6.61M
  for (i = 0; i < 8; i++) {
1226
5.88M
    re1 = ptr_subband[2 * i];
1227
5.88M
    im1 = ptr_subband[2 * i + 1];
1228
5.88M
    re3 = ptr_subband[30 - 2 * i];
1229
5.88M
    im3 = ptr_subband[31 - 2 * i];
1230
5.88M
    ptr_subband[2 * i] = (re1 * wre) + (im1 * wim);
1231
5.88M
    ptr_subband[31 - 2 * i] = (re1 * wim) - (im1 * wre);
1232
5.88M
    re1 = ptr_subband2[2 * i];
1233
5.88M
    im1 = ptr_subband2[2 * i + 1];
1234
5.88M
    re2 = ptr_subband2[30 - 2 * i];
1235
5.88M
    im2 = ptr_subband2[31 - 2 * i];
1236
5.88M
    ptr_subband2[31 - 2 * i] = -((re1 * wre) + (im1 * wim));
1237
5.88M
    ptr_subband2[2 * i] = -((re1 * wim) - (im1 * wre));
1238
5.88M
    wim = *ptr_alt_sin_tab++;
1239
5.88M
    wre = *ptr_alt_sin_tab++;
1240
5.88M
    ptr_subband[30 - 2 * i] = (re3 * wim) + (im3 * wre);
1241
5.88M
    ptr_subband[2 * i + 1] = (re3 * wre) - (im3 * wim);
1242
5.88M
    ptr_subband2[2 * i + 1] = -((re2 * wim) + (im2 * wre));
1243
5.88M
    ptr_subband2[30 - 2 * i] = -(re2 * wre) + (im2 * wim);
1244
5.88M
  }
1245
735k
}
1246
1247
static VOID ixheaace_inverse_modulation(const FLOAT32 *ptr_sbr_real, const FLOAT32 *ptr_sbr_imag,
1248
                                        FLOAT32 *ptr_time_out,
1249
735k
                                        ixheaace_pstr_sbr_qmf_filter_bank pstr_qmf_bank) {
1250
735k
  WORD32 i;
1251
735k
  FLOAT32 gain = 0.015625f;
1252
735k
  FLOAT32 r1, i1, r2, i2;
1253
735k
  FLOAT32 *ptr_time1, *ptr_time2;
1254
735k
  FLOAT32 *ptr_time3, *ptr_time4;
1255
735k
  const FLOAT32 *ptr_re;
1256
735k
  const FLOAT32 *ptr_im;
1257
1258
735k
  ptr_time1 = &ptr_time_out[0];
1259
735k
  ptr_time2 = &ptr_time_out[32];
1260
735k
  ptr_re = &ptr_sbr_real[0];
1261
735k
  ptr_im = &ptr_sbr_imag[0];
1262
1263
24.2M
  for (i = 31; i >= 0; i--) {
1264
23.5M
    r1 = *ptr_re++;
1265
23.5M
    i1 = *ptr_im++;
1266
1267
23.5M
    *ptr_time1++ = r1 * gain;
1268
23.5M
    *ptr_time2++ = i1 * gain;
1269
23.5M
  }
1270
1271
735k
  ixheaace_cos_sim_mod(ptr_time_out, pstr_qmf_bank);
1272
1273
735k
  ptr_time1 = &ptr_time_out[63];
1274
735k
  ptr_time2 = &ptr_time_out[31];
1275
735k
  ptr_time3 = &ptr_time_out[0];
1276
735k
  ptr_time4 = &ptr_time_out[32];
1277
12.4M
  for (i = 15; i >= 0; i--) {
1278
11.7M
    r1 = *ptr_time3;
1279
11.7M
    i2 = *ptr_time1;
1280
11.7M
    r2 = *ptr_time2;
1281
11.7M
    i1 = *ptr_time4;
1282
1283
11.7M
    *ptr_time3++ = r1 - i1;
1284
1285
11.7M
    *ptr_time1-- = -(r1 + i1);
1286
1287
11.7M
    *ptr_time2-- = r2 - i2;
1288
1289
11.7M
    *ptr_time4++ = -(r2 + i2);
1290
11.7M
  }
1291
735k
}
1292
1293
static VOID ixheaace_win_add(FLOAT32 *ptr_time_buf, FLOAT32 *ptr_work_buffer,
1294
735k
                             const FLOAT32 *ptr_filter) {
1295
735k
  WORD32 j, k;
1296
735k
  FLOAT32 *ptr_work_buf = &ptr_work_buffer[63];
1297
24.2M
  for (j = 0, k = 0; j < 64; j += 2, k++) {
1298
23.5M
    FLOAT32 tmp_var = *ptr_work_buf--;
1299
23.5M
    FLOAT32 temp_a = ptr_filter[2 * k];
1300
23.5M
    FLOAT32 temp_b = ptr_filter[2 * k + 1];
1301
23.5M
    FLOAT32 temp1 = *ptr_work_buf--;
1302
23.5M
    ptr_time_buf[j] += tmp_var * temp_a;
1303
23.5M
    ptr_time_buf[j + 1] += temp1 * temp_b;
1304
1305
23.5M
    temp_a = ptr_filter[64 + 2 * k];
1306
23.5M
    temp_b = ptr_filter[64 + 2 * k + 1];
1307
23.5M
    ptr_time_buf[64 + j] += tmp_var * temp_a;
1308
23.5M
    ptr_time_buf[64 + j + 1] += temp1 * temp_b;
1309
1310
23.5M
    temp_a = ptr_filter[128 + 2 * k];
1311
23.5M
    temp_b = ptr_filter[128 + 2 * k + 1];
1312
23.5M
    ptr_time_buf[128 + j] += tmp_var * temp_a;
1313
23.5M
    ptr_time_buf[128 + j + 1] += temp1 * temp_b;
1314
1315
23.5M
    temp_a = ptr_filter[192 + 2 * k];
1316
23.5M
    temp_b = ptr_filter[192 + 2 * k + 1];
1317
23.5M
    ptr_time_buf[192 + j] += tmp_var * temp_a;
1318
23.5M
    ptr_time_buf[192 + j + 1] += temp1 * temp_b;
1319
1320
23.5M
    temp_a = ptr_filter[256 + 2 * k];
1321
23.5M
    temp_b = ptr_filter[256 + 2 * k + 1];
1322
23.5M
    ptr_time_buf[256 + j] += tmp_var * temp_a;
1323
23.5M
    ptr_time_buf[256 + j + 1] += temp1 * temp_b;
1324
23.5M
  }
1325
735k
}
1326
1327
VOID ixheaace_enc_synthesis_qmf_filtering(FLOAT32 **ptr_sbr_re, FLOAT32 **ptr_sbr_im,
1328
                                          FLOAT32 *time_float,
1329
22.9k
                                          ixheaace_pstr_sbr_qmf_filter_bank pstr_qmf_bank) {
1330
22.9k
  WORD32 k, j;
1331
22.9k
  FLOAT32 *timeBuf_flt;
1332
22.9k
  const FLOAT32 *ptr_filter = pstr_qmf_bank->ptr_flt_filter;
1333
758k
  for (k = 0; k < 32; k++) {
1334
735k
    ixheaace_inverse_modulation(*(ptr_sbr_re + k), *(ptr_sbr_im + k),
1335
735k
                                pstr_qmf_bank->ptr_flt_work_buf, pstr_qmf_bank);
1336
735k
    ixheaace_win_add(pstr_qmf_bank->ptr_flt_time_buf, pstr_qmf_bank->ptr_flt_work_buf,
1337
735k
                     ptr_filter);
1338
735k
    timeBuf_flt = &pstr_qmf_bank->ptr_flt_time_buf[288];
1339
735k
    {
1340
735k
      FLOAT32 temp1_flt, temp2_flt;
1341
735k
      FLOAT32 *ptr_time_out_flt = &time_float[31], temp_out_flt;
1342
12.4M
      for (j = 15; j >= 0; j--) {
1343
11.7M
        temp1_flt = *timeBuf_flt++;
1344
11.7M
        temp2_flt = *timeBuf_flt++;
1345
11.7M
        temp_out_flt = temp1_flt;
1346
11.7M
        *ptr_time_out_flt-- = temp_out_flt * -1;
1347
11.7M
        temp_out_flt = temp2_flt;
1348
11.7M
        *ptr_time_out_flt-- = temp_out_flt * -1;
1349
11.7M
      }
1350
735k
    }
1351
735k
    time_float += 32;
1352
735k
    memmove(pstr_qmf_bank->ptr_flt_time_buf + 32, pstr_qmf_bank->ptr_flt_time_buf,
1353
735k
            288 * sizeof(pstr_qmf_bank->ptr_flt_time_buf[0]));
1354
735k
    memset(pstr_qmf_bank->ptr_flt_time_buf, 0, 32 * sizeof(pstr_qmf_bank->ptr_flt_time_buf[0]));
1355
735k
  }
1356
22.9k
}