/src/libxaac/decoder/ixheaacd_sbr_dec.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 <string.h> |
21 | | #include "ixheaacd_sbr_common.h" |
22 | | #include "ixheaac_type_def.h" |
23 | | |
24 | | #include "ixheaac_constants.h" |
25 | | #include "ixheaac_basic_ops32.h" |
26 | | #include "ixheaac_basic_ops16.h" |
27 | | #include "ixheaac_basic_ops40.h" |
28 | | #include "ixheaac_basic_ops.h" |
29 | | |
30 | | #include "ixheaac_basic_op.h" |
31 | | #include "ixheaacd_intrinsics.h" |
32 | | #include "ixheaacd_common_rom.h" |
33 | | #include "ixheaacd_basic_funcs.h" |
34 | | #include "ixheaacd_bitbuffer.h" |
35 | | #include "ixheaacd_defines.h" |
36 | | |
37 | | #include "ixheaacd_pns.h" |
38 | | |
39 | | #include "ixheaacd_aac_rom.h" |
40 | | #include "ixheaacd_pulsedata.h" |
41 | | |
42 | | #include "ixheaacd_drc_data_struct.h" |
43 | | #include "ixheaacd_lt_predict.h" |
44 | | #include "ixheaacd_cnst.h" |
45 | | #include "ixheaacd_ec_defines.h" |
46 | | #include "ixheaacd_ec_struct_def.h" |
47 | | #include "ixheaacd_channelinfo.h" |
48 | | #include "ixheaacd_drc_dec.h" |
49 | | #include "ixheaacd_sbrdecoder.h" |
50 | | |
51 | | #include "ixheaacd_defines.h" |
52 | | #include "ixheaacd_sbrdecoder.h" |
53 | | #include "ixheaacd_definitions.h" |
54 | | #include "ixheaacd_error_codes.h" |
55 | | |
56 | | #include "ixheaacd_pulsedata.h" |
57 | | |
58 | | #include "ixheaacd_sbrdecsettings.h" |
59 | | #include "ixheaacd_sbr_scale.h" |
60 | | #include "ixheaacd_lpp_tran.h" |
61 | | #include "ixheaacd_env_extr_part.h" |
62 | | #include "ixheaacd_sbr_rom.h" |
63 | | #include "ixheaacd_hybrid.h" |
64 | | #include "ixheaacd_ps_dec.h" |
65 | | #include "ixheaacd_env_extr.h" |
66 | | |
67 | | #include "ixheaacd_qmf_dec.h" |
68 | | |
69 | | #include "ixheaacd_env_calc.h" |
70 | | #include "ixheaac_sbr_const.h" |
71 | | |
72 | | #include "ixheaacd_pvc_dec.h" |
73 | | #include "ixheaacd_sbr_dec.h" |
74 | | #include "ixheaacd_env_extr.h" |
75 | | #include "ixheaacd_env_calc.h" |
76 | | #include "ixheaacd_ps_dec.h" |
77 | | #include "ixheaacd_function_selector.h" |
78 | | |
79 | | #include "ixheaacd_audioobjtypes.h" |
80 | | |
81 | | VOID ixheaacd_qmf_enrg_calc(ia_sbr_dec_struct *ptr_sbr_dec, |
82 | 135k | WORD32 upsample_ratio_idx, WORD32 low_pow_flag) { |
83 | 135k | WORD32 i, j; |
84 | 135k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
85 | 1.36M | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
86 | 22.7M | for (j = 0; j < 16; j++) { |
87 | 21.4M | ptr_sbr_dec->qmf_energy_buf[i][j] = |
88 | 21.4M | ptr_sbr_dec->qmf_buf_real[2 + i][j] * |
89 | 21.4M | ptr_sbr_dec->qmf_buf_real[2 + i][j]; |
90 | 21.4M | if (!low_pow_flag) |
91 | 21.4M | ptr_sbr_dec->qmf_energy_buf[i][j] += |
92 | 21.4M | (ptr_sbr_dec->qmf_buf_imag[2 + i][j] * |
93 | 21.4M | ptr_sbr_dec->qmf_buf_imag[2 + i][j]); |
94 | 21.4M | } |
95 | 1.34M | } |
96 | | |
97 | 356k | for (i = 0; i < 16; i++) { |
98 | 5.69M | for (j = 0; j < 16; j++) { |
99 | 5.36M | ptr_sbr_dec->pvc_qmf_enrg_arr[32 * i + j] = |
100 | 5.36M | (ptr_sbr_dec->qmf_energy_buf[4 * i + 0][j] + |
101 | 5.36M | ptr_sbr_dec->qmf_energy_buf[4 * i + 1][j] + |
102 | 5.36M | ptr_sbr_dec->qmf_energy_buf[4 * i + 2][j] + |
103 | 5.36M | ptr_sbr_dec->qmf_energy_buf[4 * i + 3][j]) * |
104 | 5.36M | 0.25f; |
105 | 5.36M | } |
106 | 335k | } |
107 | 114k | } else { |
108 | 3.78M | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
109 | 120M | for (j = 0; j < 32; j++) { |
110 | 117M | ptr_sbr_dec->qmf_energy_buf[i][j] = |
111 | 117M | ptr_sbr_dec->qmf_buf_real[2 + i][j] * |
112 | 117M | ptr_sbr_dec->qmf_buf_real[2 + i][j]; |
113 | 117M | if (!low_pow_flag) |
114 | 117M | ptr_sbr_dec->qmf_energy_buf[i][j] += |
115 | 117M | (ptr_sbr_dec->qmf_buf_imag[2 + i][j] * |
116 | 117M | ptr_sbr_dec->qmf_buf_imag[2 + i][j]); |
117 | 117M | } |
118 | 3.66M | } |
119 | | |
120 | 1.94M | for (i = 0; i < 16; i++) { |
121 | 60.4M | for (j = 0; j < 32; j++) { |
122 | 58.6M | ptr_sbr_dec->pvc_qmf_enrg_arr[32 * i + j] = |
123 | 58.6M | (ptr_sbr_dec->qmf_energy_buf[2 * i + 0][j] + |
124 | 58.6M | ptr_sbr_dec->qmf_energy_buf[2 * i + 1][j]) * |
125 | 58.6M | 0.5f; |
126 | 58.6M | } |
127 | 1.83M | } |
128 | 114k | } |
129 | 135k | } |
130 | | |
131 | | VOID ixheaacd_hbe_repl_spec(WORD32 x_over_qmf[MAX_NUM_PATCHES], |
132 | | FLOAT32 qmf_buf_real[][64], |
133 | | FLOAT32 qmf_buf_imag[][64], WORD32 no_bins, |
134 | 40.1k | WORD32 max_stretch) { |
135 | 40.1k | WORD32 patch_bands; |
136 | 40.1k | WORD32 patch, band, col, target, source_bands, i; |
137 | 40.1k | WORD32 num_patches = 0; |
138 | | |
139 | 240k | for (i = 1; i < MAX_NUM_PATCHES; i++) { |
140 | 200k | if (x_over_qmf[i] != 0) { |
141 | 95.5k | num_patches++; |
142 | 95.5k | } |
143 | 200k | } |
144 | | |
145 | 46.1k | for (patch = (max_stretch - 1); patch < num_patches; patch++) { |
146 | 6.00k | patch_bands = x_over_qmf[patch + 1] - x_over_qmf[patch]; |
147 | 6.00k | target = x_over_qmf[patch]; |
148 | 6.00k | source_bands = x_over_qmf[max_stretch - 1] - x_over_qmf[max_stretch - 2]; |
149 | 14.6k | while (patch_bands > 0) { |
150 | 8.62k | WORD32 ixheaacd_num_bands = source_bands; |
151 | 8.62k | WORD32 start_band = x_over_qmf[max_stretch - 1] - 1; |
152 | 8.62k | if (target + ixheaacd_num_bands >= x_over_qmf[patch + 1]) { |
153 | 6.84k | ixheaacd_num_bands = x_over_qmf[patch + 1] - target; |
154 | 6.84k | } |
155 | 8.62k | if ((((target + ixheaacd_num_bands - 1) & 1) + |
156 | 8.62k | ((x_over_qmf[max_stretch - 1] - 1) & 1)) & |
157 | 8.62k | 1) { |
158 | 4.61k | if (ixheaacd_num_bands == source_bands) { |
159 | 2.50k | ixheaacd_num_bands--; |
160 | 2.50k | } else { |
161 | 2.11k | start_band--; |
162 | 2.11k | } |
163 | 4.61k | } |
164 | 8.62k | if (!ixheaacd_num_bands) break; |
165 | 560k | for (col = 0; col < no_bins; col++) { |
166 | 551k | WORD32 i = 0; |
167 | 551k | band = target + ixheaacd_num_bands - 1; |
168 | 551k | if (64 <= band) { |
169 | 0 | band = 63; |
170 | 0 | } |
171 | 551k | if (x_over_qmf[patch + 1] <= band) { |
172 | 0 | band = x_over_qmf[patch + 1] - 1; |
173 | 0 | } |
174 | 3.12M | for (i = 0; i < ixheaacd_num_bands; i++, band--) { |
175 | 2.56M | qmf_buf_real[col][band] = qmf_buf_real[col][start_band - i]; |
176 | 2.56M | qmf_buf_imag[col][band] = qmf_buf_imag[col][start_band - i]; |
177 | 2.56M | } |
178 | 551k | } |
179 | 8.62k | target += ixheaacd_num_bands; |
180 | 8.62k | patch_bands -= ixheaacd_num_bands; |
181 | 8.62k | } |
182 | 6.00k | } |
183 | 40.1k | } |
184 | | |
185 | | VOID ixheaacd_esbr_analysis_filt_block(ia_sbr_dec_struct *ptr_sbr_dec, |
186 | | ia_sbr_tables_struct *sbr_tables_ptr, |
187 | 379k | WORD32 op_delay) { |
188 | 379k | FLOAT32 *core_coder_samples; |
189 | 379k | WORD32 *ptr_filt_states; |
190 | 379k | WORD32 *ptr_filt_states_1; |
191 | 379k | WORD32 *ptr_filt_states_2; |
192 | 379k | WORD32 *ptr_temp; |
193 | 379k | WORD32 *ptr_win_coeffs_1; |
194 | 379k | WORD32 *ptr_win_coeffs_2; |
195 | 379k | WORD32 *ptr_win_coeffs; |
196 | 379k | WORD32 *ploc_qmf_buf_real; |
197 | 379k | WORD32 *ploc_qmf_buf_imag; |
198 | 379k | WORD32 local_qmf_buffer[128] = {0}; |
199 | 379k | WORD32 anal_buf[2 * 32]; |
200 | 379k | WORD32 idx, z; |
201 | 379k | WORD32 core_syn_ch_index; |
202 | 379k | FLOAT32 gain; |
203 | 379k | WORD32 filt_offset; |
204 | 379k | WORD32 num_columns; |
205 | 379k | ia_qmf_dec_tables_struct *qmf_dec_tables_ptr = |
206 | 379k | sbr_tables_ptr->qmf_dec_tables_ptr; |
207 | 379k | ia_sbr_qmf_filter_bank_struct *pstr_qmf_anal_bank = |
208 | 379k | &ptr_sbr_dec->str_codec_qmf_bank; |
209 | 379k | core_coder_samples = ptr_sbr_dec->time_sample_buf; |
210 | 379k | ptr_filt_states = pstr_qmf_anal_bank->state_new_samples_pos_low_32; |
211 | 379k | ptr_win_coeffs_1 = pstr_qmf_anal_bank->filter_pos_32; |
212 | 379k | num_columns = pstr_qmf_anal_bank->no_channels; |
213 | | |
214 | 379k | switch (num_columns) { |
215 | 36.2k | case 16: |
216 | 36.2k | ptr_win_coeffs_2 = ptr_win_coeffs_1 + 64; |
217 | 36.2k | gain = 128.0f; |
218 | 36.2k | filt_offset = 64; |
219 | 36.2k | break; |
220 | 41.0k | case 24: |
221 | 41.0k | ptr_win_coeffs_2 = ptr_win_coeffs_1 + 24; |
222 | 41.0k | gain = 12.0f; |
223 | 41.0k | filt_offset = 24; |
224 | 41.0k | break; |
225 | 301k | case 32: |
226 | 301k | ptr_win_coeffs_2 = ptr_win_coeffs_1 + 64; |
227 | 301k | gain = 256.0f; |
228 | 301k | filt_offset = 64; |
229 | 301k | break; |
230 | 0 | default: |
231 | 0 | ptr_win_coeffs_2 = ptr_win_coeffs_1 + 64; |
232 | 0 | gain = 256.0f; |
233 | 0 | filt_offset = 64; |
234 | 0 | break; |
235 | 379k | } |
236 | 379k | gain = 1.0f / gain; |
237 | | |
238 | 379k | pstr_qmf_anal_bank->usb = num_columns; |
239 | | |
240 | 379k | ploc_qmf_buf_real = &local_qmf_buffer[0]; |
241 | 379k | ploc_qmf_buf_imag = &local_qmf_buffer[64]; |
242 | | |
243 | 379k | ptr_filt_states_1 = pstr_qmf_anal_bank->anal_filter_states_32; |
244 | 379k | ptr_filt_states_2 = pstr_qmf_anal_bank->anal_filter_states_32 + num_columns; |
245 | | |
246 | 13.6M | for (idx = 0; idx < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; idx++) { |
247 | 391M | for (z = 0; z < num_columns; z++) { |
248 | 377M | ptr_filt_states[num_columns - 1 - z] = |
249 | 377M | (WORD32)(core_coder_samples[z] * (1 << 15)); |
250 | 377M | } |
251 | 13.2M | ixheaacd_esbr_qmfanal32_winadd(ptr_filt_states_1, ptr_filt_states_2, |
252 | 13.2M | ptr_win_coeffs_1, ptr_win_coeffs_2, anal_buf, |
253 | 13.2M | num_columns); |
254 | | |
255 | 13.2M | core_coder_samples += num_columns; |
256 | | |
257 | 13.2M | ptr_filt_states -= num_columns; |
258 | 13.2M | if (ptr_filt_states < pstr_qmf_anal_bank->anal_filter_states_32) { |
259 | 1.33M | ptr_filt_states = pstr_qmf_anal_bank->anal_filter_states_32 + |
260 | 1.33M | 10 * num_columns - num_columns; |
261 | 1.33M | } |
262 | | |
263 | 13.2M | ptr_temp = ptr_filt_states_1; |
264 | 13.2M | ptr_filt_states_1 = ptr_filt_states_2; |
265 | 13.2M | ptr_filt_states_2 = ptr_temp; |
266 | | |
267 | 13.2M | ptr_win_coeffs_1 += filt_offset; |
268 | 13.2M | ptr_win_coeffs_2 += filt_offset; |
269 | | |
270 | 13.2M | ptr_win_coeffs = ptr_win_coeffs_1; |
271 | 13.2M | ptr_win_coeffs_1 = ptr_win_coeffs_2; |
272 | 13.2M | ptr_win_coeffs_2 = ptr_win_coeffs; |
273 | | |
274 | 13.2M | if (ptr_win_coeffs_2 > |
275 | 13.2M | (pstr_qmf_anal_bank->analy_win_coeff_32 + filt_offset * 10)) { |
276 | 1.32M | ptr_win_coeffs_1 = pstr_qmf_anal_bank->analy_win_coeff_32; |
277 | 1.32M | ptr_win_coeffs_2 = pstr_qmf_anal_bank->analy_win_coeff_32 + filt_offset; |
278 | 1.32M | } |
279 | | |
280 | 13.2M | ixheaacd_esbr_fwd_modulation(anal_buf, &ploc_qmf_buf_real[0], |
281 | 13.2M | &ploc_qmf_buf_imag[0], pstr_qmf_anal_bank, |
282 | 13.2M | qmf_dec_tables_ptr); |
283 | 13.2M | core_syn_ch_index = num_columns; |
284 | | |
285 | 391M | for (z = 0; z < core_syn_ch_index; z++) { |
286 | 377M | ptr_sbr_dec->qmf_buf_real[op_delay + idx][z] = |
287 | 377M | ((FLOAT32)ploc_qmf_buf_real[z] * gain); |
288 | 377M | ptr_sbr_dec->qmf_buf_imag[op_delay + idx][z] = |
289 | 377M | ((FLOAT32)ploc_qmf_buf_imag[z] * gain); |
290 | 377M | } |
291 | 13.2M | } |
292 | | |
293 | 379k | pstr_qmf_anal_bank->filter_pos_32 = ptr_win_coeffs_1; |
294 | 379k | pstr_qmf_anal_bank->state_new_samples_pos_low_32 = ptr_filt_states; |
295 | 379k | } |
296 | | |
297 | | VOID ixheaacd_esbr_synthesis_regrp( |
298 | | FLOAT32 *qmf_buf_real, FLOAT32 *qmf_buf_imag, |
299 | | ia_sbr_dec_struct *ptr_sbr_dec, |
300 | | ia_sbr_frame_info_data_struct *ptr_frame_data, |
301 | | ia_sbr_header_data_struct *ptr_header_data, WORD32 stereo_config_idx, |
302 | 272k | WORD32 apply_processing) { |
303 | 272k | WORD32 i, k; |
304 | 272k | WORD32 stop_border = 0; |
305 | 272k | WORD32 num_anal_bands = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
306 | 272k | WORD32 x_over_band = num_anal_bands; |
307 | | |
308 | 272k | if (apply_processing) { |
309 | 226k | if (ptr_header_data->sbr_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
310 | 11.1k | stop_border = 4 * ptr_frame_data->str_frame_info_details.border_vec[0]; |
311 | 215k | } else { |
312 | 215k | stop_border = 2 * ptr_frame_data->str_frame_info_details.border_vec[0]; |
313 | 215k | } |
314 | 226k | x_over_band = ptr_header_data->pstr_freq_band_data->qmf_sb_prev; |
315 | 226k | } |
316 | | |
317 | 272k | if (stereo_config_idx > 0) { |
318 | 119k | for (i = 0; i < stop_border; i++) { |
319 | 92.6k | for (k = 0; k < 3; k++) { |
320 | 69.4k | *qmf_buf_real++ = |
321 | 69.4k | ptr_sbr_dec->qmf_buf_real[(2) + i + HYBRID_FILTER_DELAY][k]; |
322 | 69.4k | *qmf_buf_imag++ = |
323 | 69.4k | ptr_sbr_dec->qmf_buf_imag[(2) + i + HYBRID_FILTER_DELAY][k]; |
324 | 69.4k | } |
325 | | |
326 | 427k | for (; k < x_over_band; k++) { |
327 | 404k | *qmf_buf_real++ = ptr_sbr_dec->qmf_buf_real[(2) + i][k]; |
328 | 404k | *qmf_buf_imag++ = ptr_sbr_dec->qmf_buf_imag[(2) + i][k]; |
329 | 404k | } |
330 | | |
331 | 1.03M | for (; k < 64; k++) { |
332 | 1.00M | *qmf_buf_real++ = ptr_sbr_dec->sbr_qmf_out_real[(2) + i][k]; |
333 | 1.00M | *qmf_buf_imag++ = ptr_sbr_dec->sbr_qmf_out_imag[(2) + i][k]; |
334 | 1.00M | } |
335 | | |
336 | 23.1k | qmf_buf_real += 14; |
337 | 23.1k | qmf_buf_imag += 14; |
338 | 23.1k | } |
339 | | |
340 | 96.1k | x_over_band = ptr_header_data->pstr_freq_band_data->sub_band_start; |
341 | | |
342 | 3.84M | for (; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
343 | 15.0M | for (k = 0; k < 3; k++) { |
344 | 11.2M | *qmf_buf_real++ = |
345 | 11.2M | ptr_sbr_dec->qmf_buf_real[(2) + i + HYBRID_FILTER_DELAY][k]; |
346 | 11.2M | *qmf_buf_imag++ = |
347 | 11.2M | ptr_sbr_dec->qmf_buf_imag[(2) + i + HYBRID_FILTER_DELAY][k]; |
348 | 11.2M | } |
349 | | |
350 | 119M | for (; k < x_over_band; k++) { |
351 | 116M | *qmf_buf_real++ = ptr_sbr_dec->qmf_buf_real[(2) + i][k]; |
352 | 116M | *qmf_buf_imag++ = ptr_sbr_dec->qmf_buf_imag[(2) + i][k]; |
353 | 116M | } |
354 | | |
355 | 116M | for (; k < 64; k++) { |
356 | 112M | *qmf_buf_real++ = ptr_sbr_dec->sbr_qmf_out_real[(2) + i][k]; |
357 | 112M | *qmf_buf_imag++ = ptr_sbr_dec->sbr_qmf_out_imag[(2) + i][k]; |
358 | 112M | } |
359 | | |
360 | 3.75M | qmf_buf_real += 14; |
361 | 3.75M | qmf_buf_imag += 14; |
362 | 3.75M | } |
363 | | |
364 | 176k | } else { |
365 | 265k | for (i = 0; i < stop_border; i++) { |
366 | 1.75M | for (k = 0; k < x_over_band; k++) { |
367 | 1.66M | *qmf_buf_real++ = ptr_sbr_dec->qmf_buf_real[(2) + i][k]; |
368 | 1.66M | *qmf_buf_imag++ = ptr_sbr_dec->qmf_buf_imag[(2) + i][k]; |
369 | 1.66M | } |
370 | | |
371 | 4.15M | for (; k < 64; k++) { |
372 | 4.06M | *qmf_buf_real++ = ptr_sbr_dec->sbr_qmf_out_real[(2) + i][k]; |
373 | 4.06M | *qmf_buf_imag++ = ptr_sbr_dec->sbr_qmf_out_imag[(2) + i][k]; |
374 | 4.06M | } |
375 | | |
376 | 89.5k | qmf_buf_real += 14; |
377 | 89.5k | qmf_buf_imag += 14; |
378 | 89.5k | } |
379 | | |
380 | 176k | x_over_band = ptr_header_data->pstr_freq_band_data->sub_band_start; |
381 | | |
382 | 5.72M | for (; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
383 | 84.7M | for (k = 0; k < x_over_band; k++) { |
384 | 79.2M | *qmf_buf_real++ = ptr_sbr_dec->qmf_buf_real[(2) + i][k]; |
385 | 79.2M | *qmf_buf_imag++ = ptr_sbr_dec->qmf_buf_imag[(2) + i][k]; |
386 | 79.2M | } |
387 | | |
388 | 281M | for (; k < 64; k++) { |
389 | 276M | *qmf_buf_real++ = ptr_sbr_dec->sbr_qmf_out_real[(2) + i][k]; |
390 | 276M | *qmf_buf_imag++ = ptr_sbr_dec->sbr_qmf_out_imag[(2) + i][k]; |
391 | 276M | } |
392 | | |
393 | 5.55M | qmf_buf_real += 14; |
394 | 5.55M | qmf_buf_imag += 14; |
395 | 5.55M | } |
396 | 176k | } |
397 | 272k | } |
398 | | |
399 | | VOID ixheaacd_mps_esbr_synthesis_regrp(FLOAT32 *qmf_buf_real, |
400 | | FLOAT32 *qmf_buf_imag, |
401 | | ia_sbr_dec_struct *ptr_sbr_dec, |
402 | 106k | WORD32 stereo_config_idx) { |
403 | 106k | WORD32 i, k; |
404 | 106k | WORD32 num_anal_bands = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
405 | 106k | WORD32 x_over_band = num_anal_bands; |
406 | | |
407 | 106k | if (stereo_config_idx > 0) { |
408 | 3.98M | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
409 | 15.4M | for (k = 0; k < 3; k++) { |
410 | 11.6M | *qmf_buf_real++ = |
411 | 11.6M | ptr_sbr_dec->qmf_buf_real[(2) + i + HYBRID_FILTER_DELAY][k]; |
412 | 11.6M | *qmf_buf_imag++ = |
413 | 11.6M | ptr_sbr_dec->qmf_buf_imag[(2) + i + HYBRID_FILTER_DELAY][k]; |
414 | 11.6M | } |
415 | | |
416 | 100M | for (; k < x_over_band; k++) { |
417 | 96.6M | *qmf_buf_real++ = ptr_sbr_dec->qmf_buf_real[(2) + i][k]; |
418 | 96.6M | *qmf_buf_imag++ = ptr_sbr_dec->qmf_buf_imag[(2) + i][k]; |
419 | 96.6M | } |
420 | | |
421 | 143M | for (; k < 64; k++) { |
422 | 139M | *qmf_buf_real++ = 0; |
423 | 139M | *qmf_buf_imag++ = 0; |
424 | 139M | } |
425 | | |
426 | 3.87M | qmf_buf_real += 14; |
427 | 3.87M | qmf_buf_imag += 14; |
428 | 3.87M | } |
429 | 106k | } else { |
430 | 0 | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
431 | 0 | for (k = 0; k < x_over_band; k++) { |
432 | 0 | *qmf_buf_real++ = ptr_sbr_dec->qmf_buf_real[(2) + i][k]; |
433 | 0 | *qmf_buf_imag++ = ptr_sbr_dec->qmf_buf_imag[(2) + i][k]; |
434 | 0 | } |
435 | |
|
436 | 0 | for (; k < 64; k++) { |
437 | 0 | *qmf_buf_real++ = 0.0f; |
438 | 0 | *qmf_buf_imag++ = 0.0f; |
439 | 0 | } |
440 | |
|
441 | 0 | qmf_buf_real += 14; |
442 | 0 | qmf_buf_imag += 14; |
443 | 0 | } |
444 | 0 | } |
445 | 106k | } |
446 | | |
447 | | VOID ixheaacd_esbr_synthesis_filt_block( |
448 | | ia_sbr_dec_struct *ptr_sbr_dec, ia_sbr_header_data_struct *ptr_header_data, |
449 | | ia_sbr_frame_info_data_struct *ptr_frame_data, WORD32 apply_processing, |
450 | | FLOAT32 **qmf_buf_real, FLOAT32 **qmf_buf_imag, WORD32 stereo_config_idx, |
451 | | ia_sbr_tables_struct *sbr_tables_ptr, WORD32 mps_sbr_flag, WORD32 ch_fac, |
452 | | WORD32 ps_enable, WORD32 skip_re_grouping, ia_ps_dec_struct *ptr_ps_dec, |
453 | 394k | FLAG drc_on, WORD32 drc_sbr_factors[][64]) { |
454 | | |
455 | 394k | WORD32 i, k; |
456 | 394k | WORD32 *ptr_filt_states; |
457 | 394k | WORD32 *ptr_filt_states_1; |
458 | 394k | WORD32 *ptr_filt_states_2; |
459 | 394k | WORD32 *filter_l; |
460 | 394k | WORD32 *ploc_qmf_buf_real; |
461 | 394k | WORD32 *ploc_qmf_buf_imag; |
462 | 394k | WORD32 out_scalefactor; |
463 | 394k | WORD32 sixty4, thrity2; |
464 | 394k | WORD32 no_synthesis_channels; |
465 | 394k | WORD32 ixheaacd_drc_offset; |
466 | 394k | FLOAT32 *syn_buffer; |
467 | 394k | WORD32 *local_qmf_buffer = ptr_sbr_dec->sbr_scratch_local; |
468 | 394k | WORD32 *time_out = &(ptr_sbr_dec->sbr_scratch_local[128]); |
469 | 394k | FLOAT32 *time_sample_buf; |
470 | 394k | if (ps_enable) { |
471 | 30.2k | time_sample_buf = ptr_ps_dec->time_sample_buf[0]; |
472 | 363k | } else { |
473 | 363k | time_sample_buf = ptr_sbr_dec->time_sample_buf; |
474 | 363k | } |
475 | 394k | ia_sbr_qmf_filter_bank_struct *qmf_bank = |
476 | 394k | &ptr_sbr_dec->str_synthesis_qmf_bank; |
477 | 394k | ia_qmf_dec_tables_struct *qmf_dec_tables_ptr = |
478 | 394k | sbr_tables_ptr->qmf_dec_tables_ptr; |
479 | | |
480 | 394k | if (!skip_re_grouping) { |
481 | 379k | if (!mps_sbr_flag) { |
482 | 272k | ixheaacd_esbr_synthesis_regrp(&qmf_buf_real[0][0], &qmf_buf_imag[0][0], |
483 | 272k | ptr_sbr_dec, ptr_frame_data, ptr_header_data, |
484 | 272k | stereo_config_idx, apply_processing); |
485 | 272k | if (ps_enable) { |
486 | 15.1k | FLOAT32 factor = 1.0f; |
487 | 105k | for (i = ptr_ps_dec->num_sub_samples;i < (WORD32)ptr_ps_dec->num_sub_samples + 6;i++) { |
488 | 544k | for (k = 0; k < 5; k++) |
489 | 453k | { |
490 | 453k | if (drc_on) |
491 | 453k | { |
492 | 453k | if (ptr_sbr_dec->str_codec_qmf_bank.num_time_slots == 30) |
493 | 0 | { |
494 | 0 | factor = (FLOAT32)drc_sbr_factors[i + 30 - 25][k] / Q25; |
495 | 0 | } |
496 | 453k | else |
497 | 453k | { |
498 | 453k | factor = (FLOAT32)drc_sbr_factors[i + 32 - 26][k] / Q25; |
499 | 453k | } |
500 | 453k | } |
501 | 453k | ptr_ps_dec->pp_qmf_buf_real[0][i][k] = |
502 | 453k | factor * ptr_sbr_dec->qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k]; |
503 | 453k | ptr_ps_dec->pp_qmf_buf_imag[0][i][k] = |
504 | 453k | factor * ptr_sbr_dec->qmf_buf_imag[SBR_HF_ADJ_OFFSET + i][k]; |
505 | 453k | } |
506 | 90.7k | } |
507 | 15.1k | } |
508 | 272k | if (ps_enable && apply_processing) { |
509 | 14.9k | WORD32 usb = ptr_header_data->pstr_freq_band_data->sub_band_end; |
510 | | |
511 | 14.9k | ixheaacd_esbr_apply_ps(ptr_ps_dec, |
512 | 14.9k | ptr_ps_dec->pp_qmf_buf_real[0], |
513 | 14.9k | ptr_ps_dec->pp_qmf_buf_imag[0], |
514 | 14.9k | ptr_ps_dec->pp_qmf_buf_real[1], |
515 | 14.9k | ptr_ps_dec->pp_qmf_buf_imag[1], |
516 | 14.9k | usb, sbr_tables_ptr->ps_tables_ptr, |
517 | 14.9k | ptr_header_data->num_time_slots); |
518 | 257k | } else if (ps_enable) { |
519 | 6.40k | for (i = 0; i < (ptr_header_data->num_time_slots * 2); i++) { |
520 | 403k | for (k = 0; k < 64; k++) { |
521 | 397k | ptr_ps_dec->pp_qmf_buf_real[1][i][k] = ptr_ps_dec->pp_qmf_buf_real[0][i][k]; |
522 | 397k | ptr_ps_dec->pp_qmf_buf_imag[1][i][k] = ptr_ps_dec->pp_qmf_buf_imag[0][i][k]; |
523 | 397k | } |
524 | 6.20k | } |
525 | 194 | } |
526 | 272k | } else { |
527 | 106k | ixheaacd_mps_esbr_synthesis_regrp(&qmf_buf_real[0][0], &qmf_buf_imag[0][0], |
528 | 106k | ptr_sbr_dec, stereo_config_idx); |
529 | 106k | } |
530 | 379k | } else { |
531 | 15.1k | if (ps_enable) { |
532 | 15.1k | time_sample_buf = ptr_ps_dec->time_sample_buf[1]; |
533 | 15.1k | } |
534 | 15.1k | } |
535 | | |
536 | 394k | if (drc_on) |
537 | 37.9k | { |
538 | 37.9k | FLOAT32 factor = 1.0f; |
539 | 1.25M | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) |
540 | 1.21M | { |
541 | 78.9M | for (k = 0; k < 64; k++) |
542 | 77.7M | { |
543 | 77.7M | if (ptr_sbr_dec->str_codec_qmf_bank.num_time_slots == 30) |
544 | 34.5k | { |
545 | 34.5k | factor = (FLOAT32)drc_sbr_factors[i + 30 - 25][k] / Q25; |
546 | 34.5k | } |
547 | 77.7M | else |
548 | 77.7M | { |
549 | 77.7M | factor = (FLOAT32)drc_sbr_factors[i + 32 - 26][k] / Q25; |
550 | 77.7M | } |
551 | 77.7M | qmf_buf_real[i][k] *= factor; |
552 | 77.7M | qmf_buf_imag[i][k] *= factor; |
553 | 77.7M | } |
554 | 1.21M | } |
555 | 37.9k | } |
556 | | |
557 | 394k | if (stereo_config_idx <= 0) { |
558 | 191k | out_scalefactor = 5; |
559 | 191k | no_synthesis_channels = qmf_bank->no_channels; |
560 | 191k | sixty4 = NO_SYNTHESIS_CHANNELS; |
561 | 191k | thrity2 = qmf_bank->no_channels; |
562 | | |
563 | 191k | if (no_synthesis_channels == NO_SYNTHESIS_CHANNELS_DOWN_SAMPLED) |
564 | 325 | { |
565 | 325 | qmf_bank->esbr_cos_twiddle = |
566 | 325 | (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l32; |
567 | 325 | qmf_bank->esbr_alt_sin_twiddle = |
568 | 325 | (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l32; |
569 | 325 | } |
570 | 190k | else |
571 | 190k | { |
572 | 190k | qmf_bank->esbr_cos_twiddle = |
573 | 190k | (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l64; |
574 | 190k | qmf_bank->esbr_alt_sin_twiddle = |
575 | 190k | (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l64; |
576 | 190k | } |
577 | | |
578 | 191k | qmf_bank->filter_pos_syn_32 += |
579 | 191k | qmf_dec_tables_ptr->esbr_qmf_c - qmf_bank->p_filter_32; |
580 | 191k | qmf_bank->p_filter_32 = qmf_dec_tables_ptr->esbr_qmf_c; |
581 | | |
582 | 191k | ptr_filt_states = qmf_bank->filter_states_32; |
583 | | |
584 | 191k | ptr_filt_states_1 = &ptr_filt_states[0]; |
585 | 191k | ptr_filt_states_2 = ptr_filt_states_1 + no_synthesis_channels; |
586 | | |
587 | 191k | filter_l = qmf_bank->filter_pos_syn_32; |
588 | | |
589 | 191k | ixheaacd_drc_offset = qmf_bank->ixheaacd_drc_offset; |
590 | | |
591 | 6.31M | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
592 | 398M | for (k = 0; k < 64; k++) { |
593 | 392M | local_qmf_buffer[k + 0] = (WORD32)(qmf_buf_real[i][k] * 64); |
594 | 392M | local_qmf_buffer[k + 64] = (WORD32)(qmf_buf_imag[i][k] * 64); |
595 | 392M | } |
596 | 6.12M | ploc_qmf_buf_real = local_qmf_buffer; |
597 | 6.12M | ploc_qmf_buf_imag = local_qmf_buffer + 64; |
598 | | |
599 | 6.12M | ixheaacd_esbr_inv_modulation(ploc_qmf_buf_real, |
600 | 6.12M | &ptr_sbr_dec->str_synthesis_qmf_bank, |
601 | 6.12M | sbr_tables_ptr->qmf_dec_tables_ptr, |
602 | 6.12M | no_synthesis_channels); |
603 | | |
604 | 6.12M | ixheaacd_shiftrountine_with_rnd_hq(ploc_qmf_buf_real, ploc_qmf_buf_imag, |
605 | 6.12M | &ptr_filt_states[ixheaacd_drc_offset], |
606 | 6.12M | no_synthesis_channels, |
607 | 6.12M | out_scalefactor + 1); |
608 | | |
609 | 6.12M | if (no_synthesis_channels == NO_SYNTHESIS_CHANNELS_DOWN_SAMPLED) { |
610 | 10.4k | ixheaacd_esbr_qmfsyn32_winadd(ptr_filt_states_1, ptr_filt_states_2, |
611 | 10.4k | filter_l, &time_out[0], ch_fac); |
612 | | |
613 | 10.4k | if (!mps_sbr_flag) { |
614 | 10.4k | syn_buffer = time_sample_buf + i * 32; |
615 | 10.4k | } else { |
616 | 0 | syn_buffer = ptr_sbr_dec->time_sample_buf + i * 32; |
617 | 0 | } |
618 | 343k | for (k = 0; k < 32; k++) { |
619 | 332k | syn_buffer[k] = (FLOAT32)time_out[k] / (1 << 16); |
620 | 332k | } |
621 | | |
622 | 10.4k | ptr_filt_states_1 += thrity2; |
623 | 10.4k | ptr_filt_states_2 -= thrity2; |
624 | 10.4k | thrity2 = -thrity2; |
625 | 10.4k | ixheaacd_drc_offset -= 64; |
626 | | |
627 | 10.4k | if (ixheaacd_drc_offset < 0) ixheaacd_drc_offset += 640; |
628 | 6.11M | } else { |
629 | 6.11M | ixheaacd_esbr_qmfsyn64_winadd(ptr_filt_states_1, ptr_filt_states_2, |
630 | 6.11M | filter_l, &time_out[0], ch_fac); |
631 | | |
632 | 6.11M | if (!mps_sbr_flag) { |
633 | 6.11M | syn_buffer = time_sample_buf + i * 64; |
634 | 6.11M | } else { |
635 | 0 | syn_buffer = ptr_sbr_dec->time_sample_buf + i * 64; |
636 | 0 | } |
637 | 397M | for (k = 0; k < 64; k++) { |
638 | 391M | syn_buffer[k] = (FLOAT32)time_out[k] / (1 << 16); |
639 | 391M | } |
640 | | |
641 | 6.11M | ptr_filt_states_1 += sixty4; |
642 | 6.11M | ptr_filt_states_2 -= sixty4; |
643 | 6.11M | sixty4 = -sixty4; |
644 | 6.11M | ixheaacd_drc_offset -= 128; |
645 | | |
646 | 6.11M | if (ixheaacd_drc_offset < 0) ixheaacd_drc_offset += 1280; |
647 | 6.11M | } |
648 | | |
649 | 6.12M | filter_l += 64; |
650 | | |
651 | 6.12M | if (filter_l == qmf_bank->p_filter_32 + 640) |
652 | 611k | filter_l = (WORD32 *)qmf_bank->p_filter_32; |
653 | 6.12M | } |
654 | | |
655 | 191k | qmf_bank->filter_pos_syn_32 = filter_l; |
656 | 191k | qmf_bank->ixheaacd_drc_offset = ixheaacd_drc_offset; |
657 | 191k | } |
658 | | |
659 | 394k | if (!mps_sbr_flag) ptr_frame_data->reset_flag = 0; |
660 | 394k | } |
661 | | |
662 | | WORD32 ixheaacd_sbr_dec( |
663 | | ia_sbr_dec_struct *ptr_sbr_dec, WORD16 *ptr_time_data, |
664 | | ia_sbr_header_data_struct *ptr_header_data, ia_sbr_frame_info_data_struct *ptr_frame_data, |
665 | | ia_sbr_prev_frame_data_struct *ptr_frame_data_prev, ia_ps_dec_struct *ptr_ps_dec, |
666 | | ia_sbr_qmf_filter_bank_struct *ptr_qmf_synth_bank_r, ia_sbr_scale_fact_struct *ptr_sbr_sf_r, |
667 | | FLAG apply_processing, FLAG low_pow_flag, WORD32 *ptr_work_buf_core, |
668 | | ia_sbr_tables_struct *sbr_tables_ptr, ixheaacd_misc_tables *pstr_common_tables, WORD ch_fac, |
669 | | ia_pvc_data_struct *ptr_pvc_data, FLAG drc_on, WORD32 drc_sbr_factors[][64], |
670 | | WORD32 audio_object_type, WORD32 ldmps_present, VOID *self, WORD32 heaac_mps_present, |
671 | 409k | WORD32 ec_flag) { |
672 | 409k | WORD i, j, k; |
673 | 409k | WORD slot, reserve; |
674 | 409k | WORD save_lb_scale; |
675 | 409k | WORD op_delay; |
676 | 409k | IA_ERRORCODE err_code = IA_NO_ERROR; |
677 | | |
678 | 409k | WORD32 *p_arr_qmf_buf_real[MAX_ENV_COLS] = {0}; |
679 | 409k | WORD32 *p_arr_qmf_buf_imag[MAX_ENV_COLS] = {0}; |
680 | 409k | WORD32 *ptr; |
681 | 409k | WORD hbe_flag = ptr_header_data->hbe_flag; |
682 | | |
683 | 409k | FLOAT32 **pp_qmf_buf_real = NULL; |
684 | 409k | FLOAT32 **pp_qmf_buf_imag = NULL; |
685 | 409k | FLOAT32 pvc_dec_out_buf[16 * 64]; |
686 | | |
687 | 409k | WORD upsample_ratio_idx = ptr_header_data->sbr_ratio_idx; |
688 | 409k | WORD no_bins; |
689 | 409k | WORD mps_sbr_flag = ptr_frame_data->mps_sbr_flag; |
690 | 409k | WORD stereo_config_idx = ptr_frame_data->stereo_config_idx; |
691 | 409k | WORD sbr_mode = ptr_frame_data->sbr_mode; |
692 | 409k | WORD usac_flag = ptr_header_data->usac_flag; |
693 | 409k | WORD add_slot = 0; |
694 | | |
695 | 409k | FLOAT32 *pvc_qmf_enrg_arr = (FLOAT32 *)ptr_sbr_dec->pvc_qmf_enrg_arr; |
696 | | |
697 | 409k | WORD32 dft_hbe_flag = ptr_header_data->esbr_hq; |
698 | 409k | WORD32 esbr_hbe_delay_offsets; |
699 | 409k | if (ptr_header_data->num_time_slots == 15) |
700 | 22.4k | esbr_hbe_delay_offsets = ESBR_HBE_DELAY_OFFSET_960; |
701 | 386k | else |
702 | 386k | esbr_hbe_delay_offsets = ESBR_HBE_DELAY_OFFSET; |
703 | | |
704 | 409k | memset(pvc_dec_out_buf, 0, 1024 * sizeof(FLOAT32)); |
705 | 409k | memset(pvc_qmf_enrg_arr, 0, 512 * sizeof(FLOAT32)); |
706 | 409k | if (audio_object_type == AOT_ER_AAC_ELD) { |
707 | 64.2k | op_delay = 0; |
708 | 345k | } else { |
709 | 345k | op_delay = 6; |
710 | 345k | } |
711 | | |
712 | 409k | if (ldmps_present == 1) add_slot = SBR_HF_ADJ_OFFSET; |
713 | | |
714 | 409k | if (!((audio_object_type == AOT_ER_AAC_ELD) || (audio_object_type == AOT_ER_AAC_LD)) |
715 | 345k | && ptr_header_data->enh_sbr) { |
716 | 345k | ch_fac = 1; |
717 | 345k | pp_qmf_buf_real = ptr_sbr_dec->pp_qmf_buf_real; |
718 | 345k | pp_qmf_buf_imag = ptr_sbr_dec->pp_qmf_buf_imag; |
719 | 345k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
720 | 25.3k | op_delay = 2 * 6; |
721 | 25.3k | } |
722 | 345k | } |
723 | | |
724 | 409k | no_bins = (ptr_header_data->num_time_slots * ptr_header_data->time_step); |
725 | | |
726 | 409k | if ((audio_object_type == AOT_ER_AAC_ELD) || |
727 | 345k | (audio_object_type == AOT_ER_AAC_LD) || |
728 | 345k | !ptr_header_data->enh_sbr) { |
729 | 64.2k | WORD32 num = op_delay; |
730 | 64.2k | WORD32 *ptr_pers_qmf_real = ptr_sbr_dec->ptr_sbr_overlap_buf; |
731 | 64.2k | WORD32 *p_scr_qmf_real = ptr_work_buf_core + (2 << (6 + !low_pow_flag)); |
732 | | |
733 | 64.2k | if (ptr_header_data->num_time_slots != 15) { |
734 | 41.7k | if ((no_bins < LPC_ORDER) || ((no_bins + op_delay) > MAX_ENV_COLS)) { |
735 | 0 | if (ec_flag) |
736 | 0 | no_bins = LPC_ORDER; |
737 | 0 | else |
738 | 0 | return -1; |
739 | 0 | } |
740 | 41.7k | } else { |
741 | 22.4k | if ((no_bins < LPC_ORDER) || ((no_bins + op_delay) > MAX_ENV_COLS_960)) { |
742 | 0 | if (ec_flag) |
743 | 0 | no_bins = LPC_ORDER; |
744 | 0 | else |
745 | 0 | return -1; |
746 | 0 | } |
747 | 22.4k | } |
748 | | |
749 | 64.2k | if (!low_pow_flag) { |
750 | 64.2k | num = num << 1; |
751 | 64.2k | } |
752 | 64.2k | if (audio_object_type != AOT_ER_AAC_ELD) { |
753 | 0 | memcpy(p_scr_qmf_real, ptr_pers_qmf_real, |
754 | 0 | sizeof(WORD32) * NO_SYNTHESIS_CHANNELS * num); |
755 | 0 | } |
756 | 64.2k | ptr = p_scr_qmf_real; |
757 | | |
758 | 1.07M | for (slot = 0; slot < op_delay + no_bins + add_slot; slot++) { |
759 | 1.01M | p_arr_qmf_buf_real[slot] = ptr; |
760 | 1.01M | ptr += NO_SYNTHESIS_CHANNELS; |
761 | | |
762 | 1.01M | if (!low_pow_flag) { |
763 | 1.01M | p_arr_qmf_buf_imag[slot] = ptr; |
764 | 1.01M | ptr += NO_SYNTHESIS_CHANNELS; |
765 | 1.01M | } |
766 | 1.01M | } |
767 | | |
768 | 64.2k | ptr_sbr_dec->str_sbr_scale_fact.lb_scale = 0; |
769 | | |
770 | 64.2k | if (apply_processing) { |
771 | 64.2k | ixheaacd_rescale_x_overlap(ptr_sbr_dec, ptr_header_data, ptr_frame_data, |
772 | 64.2k | ptr_frame_data_prev, p_arr_qmf_buf_real, |
773 | 64.2k | p_arr_qmf_buf_imag, low_pow_flag); |
774 | 64.2k | } |
775 | 64.2k | } |
776 | | |
777 | 409k | if ((audio_object_type == AOT_AAC_LC) && (heaac_mps_present == 1) && ptr_header_data->enh_sbr) { |
778 | 752 | WORD32 num_anal_bands = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
779 | 752 | WORD32 frame_move = 9 * num_anal_bands; |
780 | 752 | WORD32 core_frame_size = ptr_header_data->core_frame_size; |
781 | | |
782 | 752 | memcpy(&ptr_sbr_dec->core_sample_buf[core_frame_size], |
783 | 752 | &ptr_sbr_dec->time_sample_buf[core_frame_size - frame_move], |
784 | 752 | frame_move * sizeof(FLOAT32)); |
785 | | |
786 | 752 | memmove(&ptr_sbr_dec->time_sample_buf[frame_move], &ptr_sbr_dec->time_sample_buf[0], |
787 | 752 | (core_frame_size - frame_move)); |
788 | | |
789 | 752 | memcpy(&ptr_sbr_dec->time_sample_buf[0], &ptr_sbr_dec->core_sample_buf[0], |
790 | 752 | frame_move * sizeof(FLOAT32)); |
791 | | |
792 | 752 | memcpy(&ptr_sbr_dec->core_sample_buf[0], &ptr_sbr_dec->core_sample_buf[core_frame_size], |
793 | 752 | frame_move * sizeof(FLOAT32)); |
794 | 752 | } |
795 | 409k | if ((audio_object_type == AOT_AAC_LC) && (heaac_mps_present == 1) && |
796 | 752 | !ptr_header_data->enh_sbr) { |
797 | 0 | WORD32 num_anal_bands = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
798 | 0 | WORD32 frame_move = 9 * num_anal_bands; |
799 | 0 | WORD32 core_frame_size = ptr_header_data->core_frame_size; |
800 | |
|
801 | 0 | memcpy(&ptr_sbr_dec->core_sample_buf_sbr[core_frame_size], |
802 | 0 | &ptr_time_data[core_frame_size - frame_move], |
803 | 0 | frame_move * sizeof(WORD16)); |
804 | |
|
805 | 0 | memmove(&ptr_time_data[frame_move], &ptr_time_data[0], |
806 | 0 | (core_frame_size - frame_move)); |
807 | |
|
808 | 0 | memcpy(&ptr_time_data[0], &ptr_sbr_dec->core_sample_buf_sbr[0], |
809 | 0 | frame_move * sizeof(WORD16)); |
810 | |
|
811 | 0 | memcpy(&ptr_sbr_dec->core_sample_buf_sbr[0], |
812 | 0 | &ptr_sbr_dec->core_sample_buf_sbr[core_frame_size], |
813 | 0 | frame_move * sizeof(WORD16)); |
814 | 0 | } |
815 | | |
816 | 409k | if ((audio_object_type != AOT_ER_AAC_ELD) && |
817 | 345k | (audio_object_type != AOT_ER_AAC_LD) && |
818 | 345k | ptr_header_data->enh_sbr) { |
819 | 345k | WORD32 codec_x_delay = 0; |
820 | | |
821 | 345k | if (hbe_flag || !usac_flag) { |
822 | 217k | codec_x_delay = esbr_hbe_delay_offsets; |
823 | 217k | } |
824 | 345k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
825 | 25.3k | codec_x_delay = 2 * codec_x_delay; |
826 | 25.3k | } |
827 | | /* fixed decoder delay for bitstreams with SBR 4:1 and stereoConfigIndex 3 |
828 | | */ |
829 | 345k | if (ptr_header_data->num_time_slots != 15) { |
830 | 345k | if (mps_sbr_flag) op_delay = MPS_SBR_DELAY; |
831 | 345k | } else { |
832 | 44 | if (mps_sbr_flag) op_delay = MPS_SBR_DELAY_960; |
833 | 44 | } |
834 | | |
835 | 345k | { |
836 | 345k | memmove( |
837 | 345k | &ptr_sbr_dec->qmf_buf_real[0][0], |
838 | 345k | &ptr_sbr_dec |
839 | 345k | ->qmf_buf_real[ptr_sbr_dec->str_codec_qmf_bank.num_time_slots][0], |
840 | 345k | (op_delay + SBR_HF_ADJ_OFFSET + codec_x_delay) * sizeof(FLOAT32) * 64); |
841 | | |
842 | 345k | memmove( |
843 | 345k | &ptr_sbr_dec->qmf_buf_imag[0][0], |
844 | 345k | &ptr_sbr_dec |
845 | 345k | ->qmf_buf_imag[ptr_sbr_dec->str_codec_qmf_bank.num_time_slots][0], |
846 | 345k | (op_delay + SBR_HF_ADJ_OFFSET + codec_x_delay) * sizeof(FLOAT32) * 64); |
847 | | |
848 | 345k | memmove(&ptr_sbr_dec->sbr_qmf_out_real[0][0], |
849 | 345k | &ptr_sbr_dec->sbr_qmf_out_real[ptr_sbr_dec->str_codec_qmf_bank |
850 | 345k | .num_time_slots][0], |
851 | 345k | (op_delay + SBR_HF_ADJ_OFFSET) * sizeof(FLOAT32) * 64); |
852 | | |
853 | 345k | memmove(&ptr_sbr_dec->sbr_qmf_out_imag[0][0], |
854 | 345k | &ptr_sbr_dec->sbr_qmf_out_imag[ptr_sbr_dec->str_codec_qmf_bank |
855 | 345k | .num_time_slots][0], |
856 | 345k | (op_delay + SBR_HF_ADJ_OFFSET) * sizeof(FLOAT32) * 64); |
857 | | |
858 | 345k | if (hbe_flag) { |
859 | 217k | memmove(&ptr_sbr_dec->ph_vocod_qmf_real[0][0], |
860 | 217k | &ptr_sbr_dec->ph_vocod_qmf_real[ptr_sbr_dec->str_codec_qmf_bank |
861 | 217k | .num_time_slots][0], |
862 | 217k | 64 * sizeof(FLOAT32) * (op_delay + SBR_HF_ADJ_OFFSET)); |
863 | | |
864 | 217k | memmove(ptr_sbr_dec->ph_vocod_qmf_imag, |
865 | 217k | ptr_sbr_dec->ph_vocod_qmf_imag + |
866 | 217k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
867 | 217k | 64 * sizeof(FLOAT32) * (op_delay + SBR_HF_ADJ_OFFSET)); |
868 | 217k | if (!usac_flag) { |
869 | 23.5k | WORD32 qmf_sb_prev = ptr_header_data->pstr_freq_band_data->qmf_sb_prev; |
870 | 164k | for (i = SBR_HF_ADJ_OFFSET; i < op_delay + SBR_HF_ADJ_OFFSET; ++i) { |
871 | 141k | memset(&ptr_sbr_dec->qmf_buf_real[i][qmf_sb_prev], 0, (64 - qmf_sb_prev)); |
872 | 141k | memset(&ptr_sbr_dec->qmf_buf_imag[i][qmf_sb_prev], 0, (64 - qmf_sb_prev)); |
873 | 141k | } |
874 | 23.5k | } |
875 | 217k | } |
876 | 345k | } |
877 | 345k | ixheaacd_esbr_analysis_filt_block( |
878 | 345k | ptr_sbr_dec, sbr_tables_ptr, |
879 | 345k | op_delay + codec_x_delay + SBR_HF_ADJ_OFFSET); |
880 | | |
881 | 345k | if (hbe_flag && apply_processing) { |
882 | 207k | if (dft_hbe_flag == 1) { |
883 | 0 | WORD32 err_code = 0; |
884 | 0 | ptr_sbr_dec->p_hbe_txposer->oversampling_flag = |
885 | 0 | ptr_frame_data->over_sampling_flag; |
886 | 0 | err_code = ixheaacd_dft_hbe_apply( |
887 | 0 | ptr_sbr_dec->p_hbe_txposer, |
888 | 0 | ptr_sbr_dec->qmf_buf_real + (op_delay + SBR_HF_ADJ_OFFSET) + |
889 | 0 | esbr_hbe_delay_offsets, |
890 | 0 | ptr_sbr_dec->qmf_buf_imag + (op_delay + SBR_HF_ADJ_OFFSET) + |
891 | 0 | esbr_hbe_delay_offsets, |
892 | 0 | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
893 | 0 | ptr_sbr_dec->ph_vocod_qmf_real + (op_delay + SBR_HF_ADJ_OFFSET), |
894 | 0 | ptr_sbr_dec->ph_vocod_qmf_imag + (op_delay + SBR_HF_ADJ_OFFSET), |
895 | 0 | ptr_frame_data->pitch_in_bins, (FLOAT32 *)ptr_work_buf_core); |
896 | 0 | if (err_code) return err_code; |
897 | 207k | } else { |
898 | 207k | WORD32 err_code = ixheaacd_qmf_hbe_apply( |
899 | 207k | ptr_sbr_dec->p_hbe_txposer, |
900 | 207k | ptr_sbr_dec->qmf_buf_real + (op_delay + SBR_HF_ADJ_OFFSET) + |
901 | 207k | esbr_hbe_delay_offsets, |
902 | 207k | ptr_sbr_dec->qmf_buf_imag + (op_delay + SBR_HF_ADJ_OFFSET) + |
903 | 207k | esbr_hbe_delay_offsets, |
904 | 207k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
905 | 207k | ptr_sbr_dec->ph_vocod_qmf_real + (op_delay + SBR_HF_ADJ_OFFSET), |
906 | 207k | ptr_sbr_dec->ph_vocod_qmf_imag + (op_delay + SBR_HF_ADJ_OFFSET), |
907 | 207k | ptr_frame_data->pitch_in_bins, ptr_header_data); |
908 | 207k | if (err_code) return err_code; |
909 | | |
910 | 207k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
911 | 25.1k | ixheaacd_hbe_repl_spec( |
912 | 25.1k | &ptr_sbr_dec->p_hbe_txposer->x_over_qmf[0], |
913 | 25.1k | ptr_sbr_dec->ph_vocod_qmf_real + (op_delay + SBR_HF_ADJ_OFFSET), |
914 | 25.1k | ptr_sbr_dec->ph_vocod_qmf_imag + (op_delay + SBR_HF_ADJ_OFFSET), |
915 | 25.1k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
916 | 25.1k | ptr_sbr_dec->p_hbe_txposer->max_stretch); |
917 | 25.1k | } |
918 | 207k | } |
919 | 207k | } |
920 | 345k | if (!mps_sbr_flag && apply_processing) { |
921 | 226k | err_code = ixheaacd_generate_hf(ptr_sbr_dec->qmf_buf_real + (SBR_HF_ADJ_OFFSET), |
922 | 226k | ptr_sbr_dec->qmf_buf_imag + (SBR_HF_ADJ_OFFSET), |
923 | 226k | ptr_sbr_dec->ph_vocod_qmf_real + (SBR_HF_ADJ_OFFSET), |
924 | 226k | ptr_sbr_dec->ph_vocod_qmf_imag + (SBR_HF_ADJ_OFFSET), |
925 | 226k | ptr_sbr_dec->sbr_qmf_out_real + (SBR_HF_ADJ_OFFSET), |
926 | 226k | ptr_sbr_dec->sbr_qmf_out_imag + (SBR_HF_ADJ_OFFSET), |
927 | 226k | ptr_frame_data, ptr_header_data, ldmps_present, |
928 | 226k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, ec_flag); |
929 | 226k | if (err_code) return err_code; |
930 | | |
931 | 226k | ptr_pvc_data->pvc_rate = ptr_header_data->upsamp_fac; |
932 | | |
933 | 226k | if (sbr_mode == PVC_SBR) { |
934 | 101k | ixheaacd_qmf_enrg_calc(ptr_sbr_dec, upsample_ratio_idx, low_pow_flag); |
935 | 101k | if (ec_flag) { |
936 | 0 | ptr_pvc_data->pvc_mode = 1; |
937 | 0 | } |
938 | 101k | err_code = ixheaacd_pvc_process( |
939 | 101k | ptr_pvc_data, ptr_header_data->pstr_freq_band_data->sub_band_start, |
940 | 101k | ptr_frame_data->str_pvc_frame_info.border_vec[0], |
941 | 101k | &pvc_qmf_enrg_arr[0], &pvc_dec_out_buf[0]); |
942 | | |
943 | 101k | if (err_code) return err_code; |
944 | | |
945 | 101k | ptr_pvc_data->prev_pvc_flg = 1; |
946 | 125k | } else { |
947 | 125k | memset(pvc_dec_out_buf, 0, 1024 * sizeof(FLOAT32)); |
948 | 125k | ptr_pvc_data->prev_pvc_flg = 0; |
949 | 125k | } |
950 | | |
951 | 226k | ptr_pvc_data->prev_first_bnd_idx = |
952 | 226k | ptr_header_data->pstr_freq_band_data->sub_band_start; |
953 | 226k | ptr_pvc_data->prev_pvc_rate = ptr_pvc_data->pvc_rate; |
954 | | |
955 | 226k | ptr_frame_data->pstr_sbr_header = ptr_header_data; |
956 | 226k | err_code = ixheaacd_sbr_env_calc( |
957 | 226k | ptr_frame_data, ptr_sbr_dec->sbr_qmf_out_real + (SBR_HF_ADJ_OFFSET), |
958 | 226k | ptr_sbr_dec->sbr_qmf_out_imag + (SBR_HF_ADJ_OFFSET), |
959 | 226k | ptr_sbr_dec->qmf_buf_real + (SBR_HF_ADJ_OFFSET), |
960 | 226k | ptr_sbr_dec->qmf_buf_imag + (SBR_HF_ADJ_OFFSET), |
961 | 226k | (ptr_header_data->hbe_flag == 0) ? NULL : ptr_sbr_dec->p_hbe_txposer->x_over_qmf, |
962 | 226k | ptr_sbr_dec->scratch_buff, pvc_dec_out_buf, ldmps_present, ec_flag); |
963 | | |
964 | 226k | if (err_code) return err_code; |
965 | | |
966 | 226k | } else { |
967 | 7.70M | for (i = 0; i < 64; i++) { |
968 | 7.58M | memset(ptr_sbr_dec->sbr_qmf_out_real[i], 0, 64 * sizeof(FLOAT32)); |
969 | 7.58M | memset(ptr_sbr_dec->sbr_qmf_out_imag[i], 0, 64 * sizeof(FLOAT32)); |
970 | 7.58M | } |
971 | 118k | } |
972 | | |
973 | 345k | if (!mps_sbr_flag) { |
974 | 238k | ptr_sbr_dec->band_count = |
975 | 238k | ptr_header_data->pstr_freq_band_data->sub_band_end; |
976 | 238k | } else |
977 | 106k | ptr_sbr_dec->band_count = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
978 | | |
979 | 345k | ixheaacd_esbr_synthesis_filt_block( |
980 | 345k | ptr_sbr_dec, ptr_header_data, ptr_frame_data, apply_processing, |
981 | 345k | pp_qmf_buf_real, pp_qmf_buf_imag, stereo_config_idx, sbr_tables_ptr, |
982 | 345k | mps_sbr_flag, ch_fac, |
983 | 345k | ((ptr_header_data->channel_mode == PS_STEREO) || ptr_header_data->enh_sbr_ps), |
984 | 345k | 0, ptr_ps_dec, drc_on, drc_sbr_factors); |
985 | | |
986 | 345k | if (ptr_header_data->enh_sbr_ps || ptr_header_data->channel_mode == PS_STEREO) { |
987 | 15.1k | pp_qmf_buf_real = ptr_ps_dec->pp_qmf_buf_real[1]; |
988 | 15.1k | pp_qmf_buf_imag = ptr_ps_dec->pp_qmf_buf_imag[1]; |
989 | 15.1k | ixheaacd_esbr_synthesis_filt_block( |
990 | 15.1k | (ia_sbr_dec_struct *) |
991 | 15.1k | (&(((ia_handle_sbr_dec_inst_struct)self)->pstr_sbr_channel[1]->str_sbr_dec)), |
992 | 15.1k | (ia_sbr_header_data_struct *) |
993 | 15.1k | (&(((ia_handle_sbr_dec_inst_struct)self)->pstr_sbr_header[1])), |
994 | 15.1k | (ia_sbr_frame_info_data_struct *) |
995 | 15.1k | (&(((ia_handle_sbr_dec_inst_struct)self)->frame_buffer[1])), apply_processing, |
996 | 15.1k | pp_qmf_buf_real, pp_qmf_buf_imag, stereo_config_idx, sbr_tables_ptr, |
997 | 15.1k | mps_sbr_flag, ch_fac, |
998 | 15.1k | ((ptr_header_data->channel_mode == PS_STEREO) || ptr_header_data->enh_sbr_ps), |
999 | 15.1k | 1, ptr_ps_dec, drc_on, drc_sbr_factors); |
1000 | 15.1k | } |
1001 | 345k | if (apply_processing && ec_flag) { |
1002 | 0 | WORD16 *border_vec = ptr_frame_data->str_frame_info_details.border_vec; |
1003 | 0 | ptr_frame_data_prev->end_position = |
1004 | 0 | border_vec[ptr_frame_data->str_frame_info_details.num_env]; |
1005 | 0 | } |
1006 | 345k | ptr_frame_data->prev_sbr_mode = sbr_mode; |
1007 | | |
1008 | 345k | return 0; |
1009 | 345k | } |
1010 | | |
1011 | 64.2k | if (ldmps_present) { |
1012 | 5.05k | if (ptr_sbr_dec->str_codec_qmf_bank.no_channels > 32) { |
1013 | 30 | if (ec_flag) { |
1014 | 0 | ptr_sbr_dec->str_codec_qmf_bank.no_channels = 32; |
1015 | 30 | } else { |
1016 | 30 | return IA_FATAL_ERROR; |
1017 | 30 | } |
1018 | 30 | } |
1019 | 5.02k | ixheaacd_cplx_anal_qmffilt_32( |
1020 | 5.02k | (WORD32 *)ptr_time_data, &ptr_sbr_dec->str_sbr_scale_fact, |
1021 | 5.02k | &p_arr_qmf_buf_real[op_delay], &p_arr_qmf_buf_imag[op_delay], |
1022 | 5.02k | &ptr_sbr_dec->str_codec_qmf_bank, sbr_tables_ptr->qmf_dec_tables_ptr, |
1023 | 5.02k | ch_fac, 1); |
1024 | 59.1k | } else { |
1025 | 59.1k | ixheaacd_cplx_anal_qmffilt( |
1026 | 59.1k | ptr_time_data, &ptr_sbr_dec->str_sbr_scale_fact, &p_arr_qmf_buf_real[op_delay], |
1027 | 59.1k | &p_arr_qmf_buf_imag[op_delay], &ptr_sbr_dec->str_codec_qmf_bank, |
1028 | 59.1k | sbr_tables_ptr->qmf_dec_tables_ptr, ch_fac, low_pow_flag, audio_object_type); |
1029 | 59.1k | } |
1030 | | |
1031 | 64.1k | if (ldmps_present == 1) { |
1032 | 5.02k | for (j = SBR_HF_ADJ_OFFSET; |
1033 | 84.4k | j < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots + SBR_HF_ADJ_OFFSET; |
1034 | 79.3k | j++) { |
1035 | 5.16M | for (k = 0; k < 64; k++) { |
1036 | 5.08M | WORD32 scale = 7; |
1037 | 5.08M | ptr_sbr_dec->mps_qmf_buf_real[j][k] = 0.0f; |
1038 | 5.08M | ptr_sbr_dec->mps_qmf_buf_imag[j][k] = 0.0f; |
1039 | 5.08M | if (k < ptr_sbr_dec->str_codec_qmf_bank.usb) { |
1040 | 1.93M | ptr_sbr_dec->mps_qmf_buf_real[j][k] += |
1041 | 1.93M | (FLOAT32)(p_arr_qmf_buf_real[j][k] / (FLOAT32)(1 << scale)); |
1042 | 1.93M | ptr_sbr_dec->mps_qmf_buf_imag[j][k] += |
1043 | 1.93M | (FLOAT32)(p_arr_qmf_buf_imag[j][k] / (FLOAT32)(1 << scale)); |
1044 | 1.93M | } |
1045 | 5.08M | } |
1046 | 79.3k | } |
1047 | 5.02k | } |
1048 | | /*ITTIAM : the size of real and img coeff are not same as that of the mps |
1049 | | * analysis.*/ |
1050 | 64.1k | { |
1051 | 64.1k | WORD shift1, shift2; |
1052 | 64.1k | WORD min_shift; |
1053 | 64.1k | WORD shift_over; |
1054 | 64.1k | WORD reserve_ov1, reserve_ov2; |
1055 | 64.1k | WORD reservea[2]; |
1056 | 64.1k | WORD i = 0; |
1057 | 64.1k | WORD usb = ptr_sbr_dec->str_codec_qmf_bank.usb; |
1058 | 64.1k | WORD iter_val = 1; |
1059 | 64.1k | if (audio_object_type == AOT_ER_AAC_ELD || |
1060 | 64.1k | audio_object_type == AOT_ER_AAC_LD) { |
1061 | 64.1k | iter_val = 0; |
1062 | 64.1k | } |
1063 | 64.1k | do { |
1064 | 64.1k | WORD t1 = op_delay; |
1065 | 64.1k | WORD t2 = no_bins + op_delay; |
1066 | 64.1k | if (i) { |
1067 | 0 | t1 = 0; |
1068 | 0 | t2 = op_delay; |
1069 | 0 | } |
1070 | 64.1k | reservea[i] = (*ixheaacd_ixheaacd_expsubbandsamples)( |
1071 | 64.1k | p_arr_qmf_buf_real, p_arr_qmf_buf_imag, 0, usb, t1, t2, low_pow_flag); |
1072 | 64.1k | i++; |
1073 | 64.1k | } while (i <= iter_val); |
1074 | 64.1k | ; |
1075 | | |
1076 | 64.1k | reserve = reservea[0]; |
1077 | 64.1k | if (audio_object_type != AOT_ER_AAC_ELD && |
1078 | 0 | audio_object_type != AOT_ER_AAC_LD) |
1079 | 0 | reserve_ov1 = reservea[1]; |
1080 | 64.1k | else |
1081 | 64.1k | reserve_ov1 = reserve; |
1082 | 64.1k | ptr_sbr_dec->max_samp_val = ixheaac_min32(reserve, reserve_ov1); |
1083 | | |
1084 | 64.1k | reserve_ov2 = (*ixheaacd_ixheaacd_expsubbandsamples)( |
1085 | 64.1k | ptr_sbr_dec->str_hf_generator.lpc_filt_states_real, |
1086 | 64.1k | ptr_sbr_dec->str_hf_generator.lpc_filt_states_imag, 0, usb, 0, |
1087 | 64.1k | LPC_ORDER, low_pow_flag); |
1088 | | |
1089 | 64.1k | reserve_ov1 = ixheaac_min32(reserve_ov1, reserve_ov2); |
1090 | | |
1091 | 64.1k | shift1 = ptr_sbr_dec->str_sbr_scale_fact.lb_scale + reserve; |
1092 | | |
1093 | 64.1k | shift2 = ptr_sbr_dec->str_sbr_scale_fact.ov_lb_scale + reserve_ov1; |
1094 | 64.1k | min_shift = ixheaac_min32(shift1, shift2); |
1095 | 64.1k | shift_over = (shift2 - min_shift); |
1096 | 64.1k | reserve -= (shift1 - min_shift); |
1097 | | |
1098 | 64.1k | ptr_sbr_dec->str_sbr_scale_fact.ov_lb_scale += (reserve_ov1 - shift_over); |
1099 | | |
1100 | 64.1k | (*ixheaacd_adjust_scale)(p_arr_qmf_buf_real, p_arr_qmf_buf_imag, 0, usb, 0, |
1101 | 64.1k | op_delay, reserve_ov1 - shift_over, low_pow_flag); |
1102 | | |
1103 | 64.1k | (*ixheaacd_adjust_scale)(p_arr_qmf_buf_real, p_arr_qmf_buf_imag, 0, usb, |
1104 | 64.1k | op_delay, (no_bins + op_delay), reserve, |
1105 | 64.1k | low_pow_flag); |
1106 | | |
1107 | 64.1k | (*ixheaacd_adjust_scale)(ptr_sbr_dec->str_hf_generator.lpc_filt_states_real, |
1108 | 64.1k | ptr_sbr_dec->str_hf_generator.lpc_filt_states_imag, |
1109 | 64.1k | 0, usb, 0, LPC_ORDER, reserve_ov1 - shift_over, |
1110 | 64.1k | low_pow_flag); |
1111 | | |
1112 | 64.1k | ptr_sbr_dec->str_sbr_scale_fact.lb_scale += reserve; |
1113 | | |
1114 | 64.1k | save_lb_scale = ptr_sbr_dec->str_sbr_scale_fact.lb_scale; |
1115 | 64.1k | } |
1116 | | |
1117 | 64.1k | { |
1118 | 64.1k | WORD32 num = no_bins; |
1119 | 64.1k | WORD32 *p_loc_qmf_real = |
1120 | 64.1k | &p_arr_qmf_buf_real[op_delay][NO_ANALYSIS_CHANNELS]; |
1121 | | |
1122 | 64.1k | if (!low_pow_flag) { |
1123 | 64.1k | num = num << 1; |
1124 | 64.1k | } |
1125 | | |
1126 | 64.1k | ixheaacd_clr_subsamples(p_loc_qmf_real, num - 1, (NO_SYN_ANA_CHANNELS)); |
1127 | 64.1k | } |
1128 | | |
1129 | 64.1k | if (apply_processing) { |
1130 | 64.1k | WORD16 degree_alias[NO_SYNTHESIS_CHANNELS]; |
1131 | 64.1k | WORD16 *border_vec = ptr_frame_data->str_frame_info_details.border_vec; |
1132 | | |
1133 | 64.1k | if (low_pow_flag) { |
1134 | 0 | memset(degree_alias, 0, NO_SYNTHESIS_CHANNELS * sizeof(WORD16)); |
1135 | 0 | } |
1136 | | |
1137 | 64.1k | if (low_pow_flag) { |
1138 | 0 | WORD32 com_low_band_scale; |
1139 | 0 | ixheaacd_low_pow_hf_generator( |
1140 | 0 | &ptr_sbr_dec->str_hf_generator, p_arr_qmf_buf_real, degree_alias, |
1141 | 0 | border_vec[0] * ptr_header_data->time_step, |
1142 | 0 | ptr_header_data->time_step * |
1143 | 0 | ixheaac_sub16_sat( |
1144 | 0 | border_vec[ptr_frame_data->str_frame_info_details.num_env], |
1145 | 0 | ptr_header_data->num_time_slots), |
1146 | 0 | ptr_header_data->pstr_freq_band_data->num_if_bands, |
1147 | 0 | ptr_frame_data->max_qmf_subband_aac, ptr_frame_data->sbr_invf_mode, |
1148 | 0 | ptr_frame_data_prev->sbr_invf_mode, ptr_sbr_dec->max_samp_val, |
1149 | 0 | ptr_work_buf_core); |
1150 | |
|
1151 | 0 | com_low_band_scale = |
1152 | 0 | ixheaac_min32(ptr_sbr_dec->str_sbr_scale_fact.ov_lb_scale, |
1153 | 0 | ptr_sbr_dec->str_sbr_scale_fact.lb_scale); |
1154 | |
|
1155 | 0 | ptr_sbr_dec->str_sbr_scale_fact.hb_scale = |
1156 | 0 | (WORD16)(com_low_band_scale - 2); |
1157 | 64.1k | } else { |
1158 | 64.1k | if (ldmps_present == 1) { |
1159 | 5.02k | err_code = ixheaacd_generate_hf(ptr_sbr_dec->mps_qmf_buf_real + (SBR_HF_ADJ_OFFSET), |
1160 | 5.02k | ptr_sbr_dec->mps_qmf_buf_imag + (SBR_HF_ADJ_OFFSET), |
1161 | 5.02k | ptr_sbr_dec->ph_vocod_qmf_real + (SBR_HF_ADJ_OFFSET), |
1162 | 5.02k | ptr_sbr_dec->ph_vocod_qmf_imag + (SBR_HF_ADJ_OFFSET), |
1163 | 5.02k | ptr_sbr_dec->sbr_qmf_out_real + (SBR_HF_ADJ_OFFSET), |
1164 | 5.02k | ptr_sbr_dec->sbr_qmf_out_imag + (SBR_HF_ADJ_OFFSET), |
1165 | 5.02k | ptr_frame_data, ptr_header_data, ldmps_present, |
1166 | 5.02k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, ec_flag); |
1167 | 5.02k | if (err_code) return err_code; |
1168 | 59.1k | } else { |
1169 | 59.1k | ixheaacd_hf_generator( |
1170 | 59.1k | &ptr_sbr_dec->str_hf_generator, &ptr_sbr_dec->str_sbr_scale_fact, |
1171 | 59.1k | p_arr_qmf_buf_real, p_arr_qmf_buf_imag, ptr_header_data->time_step, |
1172 | 59.1k | border_vec[0], |
1173 | 59.1k | ixheaac_sub16_sat( |
1174 | 59.1k | border_vec[ptr_frame_data->str_frame_info_details.num_env], |
1175 | 59.1k | ptr_header_data->num_time_slots), |
1176 | 59.1k | ptr_header_data->pstr_freq_band_data->num_if_bands, |
1177 | 59.1k | ptr_frame_data->max_qmf_subband_aac, ptr_frame_data->sbr_invf_mode, |
1178 | 59.1k | ptr_frame_data_prev->sbr_invf_mode, ptr_work_buf_core, |
1179 | 59.1k | audio_object_type); |
1180 | 59.1k | } |
1181 | 64.1k | } |
1182 | 64.1k | if (ldmps_present == 1) { |
1183 | 5.01k | ptr_frame_data->pstr_sbr_header = ptr_header_data; |
1184 | 5.01k | err_code = ixheaacd_sbr_env_calc( |
1185 | 5.01k | ptr_frame_data, ptr_sbr_dec->sbr_qmf_out_real + (SBR_HF_ADJ_OFFSET), |
1186 | 5.01k | ptr_sbr_dec->sbr_qmf_out_imag + (SBR_HF_ADJ_OFFSET), |
1187 | 5.01k | ptr_sbr_dec->qmf_buf_real + (SBR_HF_ADJ_OFFSET), |
1188 | 5.01k | ptr_sbr_dec->qmf_buf_imag + (SBR_HF_ADJ_OFFSET), NULL, ptr_sbr_dec->scratch_buff, |
1189 | 5.01k | pvc_dec_out_buf, ldmps_present, ec_flag); |
1190 | | |
1191 | 94.4k | for (j = 0; j < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots + 2; j++) { |
1192 | 3.62M | for (k = ptr_sbr_dec->str_codec_qmf_bank.usb; k < 64; k++) { |
1193 | 3.53M | ptr_sbr_dec->mps_qmf_buf_real[j][k] += |
1194 | 3.53M | ptr_sbr_dec->sbr_qmf_out_real[j][k]; |
1195 | 3.53M | ptr_sbr_dec->mps_qmf_buf_imag[j][k] += |
1196 | 3.53M | ptr_sbr_dec->sbr_qmf_out_imag[j][k]; |
1197 | 3.53M | } |
1198 | 89.3k | } |
1199 | 59.1k | } else { |
1200 | 59.1k | err_code = ixheaacd_calc_sbrenvelope( |
1201 | 59.1k | &ptr_sbr_dec->str_sbr_scale_fact, &ptr_sbr_dec->str_sbr_calc_env, |
1202 | 59.1k | ptr_header_data, ptr_frame_data, ptr_frame_data_prev, |
1203 | 59.1k | p_arr_qmf_buf_real, p_arr_qmf_buf_imag, degree_alias, low_pow_flag, |
1204 | 59.1k | sbr_tables_ptr, pstr_common_tables, |
1205 | 59.1k | ptr_work_buf_core + (LPC_ORDER << (6 + !low_pow_flag)), |
1206 | 59.1k | audio_object_type); |
1207 | 59.1k | if (err_code) return err_code; |
1208 | 59.1k | } |
1209 | | |
1210 | 64.1k | memcpy(ptr_frame_data_prev->sbr_invf_mode, ptr_frame_data->sbr_invf_mode, |
1211 | 64.1k | ptr_header_data->pstr_freq_band_data->num_if_bands * sizeof(WORD32)); |
1212 | | |
1213 | 64.1k | ptr_frame_data_prev->coupling_mode = ptr_frame_data->coupling_mode; |
1214 | 64.1k | ptr_frame_data_prev->max_qmf_subband_aac = |
1215 | 64.1k | ptr_frame_data->max_qmf_subband_aac; |
1216 | 64.1k | ptr_frame_data_prev->end_position = |
1217 | 64.1k | border_vec[ptr_frame_data->str_frame_info_details.num_env]; |
1218 | 64.1k | ptr_frame_data_prev->amp_res = ptr_frame_data->amp_res; |
1219 | 64.1k | } else { |
1220 | 0 | ptr_sbr_dec->str_sbr_scale_fact.hb_scale = save_lb_scale; |
1221 | 0 | } |
1222 | | |
1223 | 64.1k | if (!low_pow_flag) { |
1224 | 192k | for (i = 0; i < LPC_ORDER; i++) { |
1225 | 128k | WORD32 *p_loc_qmf_real = &p_arr_qmf_buf_real[no_bins - LPC_ORDER + i][0]; |
1226 | 128k | WORD32 *p_loc_qmf_imag = &p_arr_qmf_buf_imag[no_bins - LPC_ORDER + i][0]; |
1227 | 128k | WORD32 *plpc_filt_states_real = |
1228 | 128k | &ptr_sbr_dec->str_hf_generator.lpc_filt_states_real[i][0]; |
1229 | 128k | WORD32 *plpc_filt_states_imag = |
1230 | 128k | &ptr_sbr_dec->str_hf_generator.lpc_filt_states_imag[i][0]; |
1231 | | |
1232 | 128k | memcpy(plpc_filt_states_real, p_loc_qmf_real, |
1233 | 128k | sizeof(WORD32) * (ptr_sbr_dec->str_codec_qmf_bank.usb)); |
1234 | 128k | memcpy(plpc_filt_states_imag, p_loc_qmf_imag, |
1235 | 128k | sizeof(WORD32) * (ptr_sbr_dec->str_codec_qmf_bank.usb)); |
1236 | 128k | } |
1237 | 64.1k | } else { |
1238 | 0 | for (i = 0; i < LPC_ORDER; i++) { |
1239 | 0 | WORD32 *p_loc_qmf_real = &p_arr_qmf_buf_real[no_bins - LPC_ORDER + i][0]; |
1240 | 0 | WORD32 *plpc_filt_states_real = |
1241 | 0 | &ptr_sbr_dec->str_hf_generator.lpc_filt_states_real[i][0]; |
1242 | 0 | memcpy(plpc_filt_states_real, p_loc_qmf_real, |
1243 | 0 | sizeof(WORD32) * (ptr_sbr_dec->str_codec_qmf_bank.usb)); |
1244 | 0 | } |
1245 | 0 | } |
1246 | | |
1247 | 64.1k | if (apply_processing && ptr_header_data->channel_mode == PS_STEREO && |
1248 | 1.70k | ((audio_object_type != AOT_ER_AAC_ELD) && |
1249 | 0 | (audio_object_type != AOT_ER_AAC_LD))) { |
1250 | 0 | WORD32 ps_scale; |
1251 | |
|
1252 | 0 | ixheaacd_init_ps_scale(ptr_ps_dec, &ptr_sbr_dec->str_sbr_scale_fact); |
1253 | |
|
1254 | 0 | ixheaacd_cplx_synt_qmffilt(p_arr_qmf_buf_real, p_arr_qmf_buf_imag, op_delay, |
1255 | 0 | ptr_sbr_dec->p_arr_qmf_buf_real, ptr_sbr_dec->p_arr_qmf_buf_imag, |
1256 | 0 | &ptr_sbr_dec->str_sbr_scale_fact, ptr_time_data, |
1257 | 0 | &ptr_sbr_dec->str_synthesis_qmf_bank, ptr_ps_dec, |
1258 | 0 | 1, 0, sbr_tables_ptr, pstr_common_tables, ch_fac, |
1259 | 0 | drc_on, drc_sbr_factors, audio_object_type); |
1260 | |
|
1261 | 0 | ps_scale = ptr_sbr_dec->str_sbr_scale_fact.ps_scale; |
1262 | 0 | ptr_sbr_sf_r->ov_lb_scale = ps_scale; |
1263 | 0 | ptr_sbr_sf_r->lb_scale = ps_scale; |
1264 | 0 | ptr_sbr_sf_r->hb_scale = ps_scale; |
1265 | |
|
1266 | 0 | ixheaacd_cplx_synt_qmffilt(p_arr_qmf_buf_real, p_arr_qmf_buf_imag, op_delay, |
1267 | 0 | ptr_sbr_dec->p_arr_qmf_buf_real, ptr_sbr_dec->p_arr_qmf_buf_imag, |
1268 | 0 | ptr_sbr_sf_r, ptr_time_data + 1, |
1269 | 0 | ptr_qmf_synth_bank_r, ptr_ps_dec, 0, 0, |
1270 | 0 | sbr_tables_ptr, pstr_common_tables, ch_fac, |
1271 | 0 | drc_on, drc_sbr_factors, audio_object_type); |
1272 | 64.1k | } else { |
1273 | 64.1k | ixheaacd_cplx_synt_qmffilt(p_arr_qmf_buf_real, p_arr_qmf_buf_imag, op_delay, |
1274 | 64.1k | ptr_sbr_dec->p_arr_qmf_buf_real, ptr_sbr_dec->p_arr_qmf_buf_imag, |
1275 | 64.1k | &ptr_sbr_dec->str_sbr_scale_fact, ptr_time_data, |
1276 | 64.1k | &ptr_sbr_dec->str_synthesis_qmf_bank, ptr_ps_dec, |
1277 | 64.1k | 0, low_pow_flag, sbr_tables_ptr, |
1278 | 64.1k | pstr_common_tables, ch_fac, drc_on, |
1279 | 64.1k | drc_sbr_factors, audio_object_type); |
1280 | 64.1k | } |
1281 | | |
1282 | 64.1k | { |
1283 | 64.1k | WORD32 num = op_delay; |
1284 | 64.1k | if (audio_object_type != AOT_ER_AAC_ELD) { |
1285 | 0 | WORD32 *p_loc_qmf_real = ptr_sbr_dec->ptr_sbr_overlap_buf; |
1286 | 0 | WORD32 *p_loc_qmf_real_1 = &p_arr_qmf_buf_real[no_bins][0]; |
1287 | 0 | memcpy(p_loc_qmf_real, p_loc_qmf_real_1, |
1288 | 0 | sizeof(WORD32) * NO_SYNTHESIS_CHANNELS * num); |
1289 | 0 | } |
1290 | | |
1291 | 64.1k | if (!low_pow_flag) { |
1292 | 64.1k | num = num << 1; |
1293 | 64.1k | } |
1294 | | |
1295 | 64.1k | if (ldmps_present == 1) { |
1296 | 5.01k | memmove(&ptr_sbr_dec->mps_qmf_buf_real[0][0], |
1297 | 5.01k | &ptr_sbr_dec->mps_qmf_buf_real[ptr_sbr_dec->str_codec_qmf_bank |
1298 | 5.01k | .num_time_slots][0], |
1299 | 5.01k | SBR_HF_ADJ_OFFSET * sizeof(FLOAT32) * 64); |
1300 | | |
1301 | 5.01k | memmove(&ptr_sbr_dec->mps_qmf_buf_imag[0][0], |
1302 | 5.01k | &ptr_sbr_dec->mps_qmf_buf_imag[ptr_sbr_dec->str_codec_qmf_bank |
1303 | 5.01k | .num_time_slots][0], |
1304 | 5.01k | SBR_HF_ADJ_OFFSET * sizeof(FLOAT32) * 64); |
1305 | 5.01k | } |
1306 | 64.1k | } |
1307 | | |
1308 | 64.1k | ptr_sbr_dec->str_sbr_scale_fact.ov_lb_scale = save_lb_scale; |
1309 | 64.1k | return 0; |
1310 | 64.1k | } |
1311 | | |
1312 | | WORD32 ixheaacd_esbr_dec(ia_sbr_dec_struct *ptr_sbr_dec, |
1313 | | ia_sbr_header_data_struct *ptr_header_data, |
1314 | | ia_sbr_frame_info_data_struct *ptr_frame_data, |
1315 | | FLAG apply_processing, FLAG low_pow_flag, |
1316 | 33.9k | ia_sbr_tables_struct *ptr_sbr_tables, WORD ch_fac) { |
1317 | 33.9k | WORD32 i; |
1318 | 33.9k | WORD32 op_delay; |
1319 | | |
1320 | 33.9k | WORD32 codec_x_delay = 0; |
1321 | | |
1322 | 33.9k | FLOAT32 **pp_qmf_buf_real = ptr_sbr_dec->pp_qmf_buf_real; |
1323 | 33.9k | FLOAT32 **pp_qmf_buf_imag = ptr_sbr_dec->pp_qmf_buf_imag; |
1324 | | |
1325 | 33.9k | WORD32 upsample_ratio_idx = ptr_header_data->sbr_ratio_idx; |
1326 | | |
1327 | 33.9k | WORD32 mps_sbr_flag = ptr_frame_data->mps_sbr_flag; |
1328 | 33.9k | WORD32 stereo_config_idx = ptr_frame_data->stereo_config_idx; |
1329 | 33.9k | WORD32 hbe_flag = ptr_header_data->hbe_flag; |
1330 | 33.9k | WORD32 sbr_mode = ptr_frame_data->sbr_mode; |
1331 | | |
1332 | 33.9k | op_delay = 6; |
1333 | 33.9k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
1334 | 10.9k | op_delay = 2 * 6; |
1335 | 10.9k | } |
1336 | | |
1337 | 33.9k | ptr_sbr_dec->str_sbr_scale_fact.lb_scale = 0; |
1338 | 33.9k | { |
1339 | 33.9k | if (hbe_flag) { |
1340 | 14.0k | codec_x_delay = 32; |
1341 | 14.0k | } |
1342 | 33.9k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
1343 | 10.9k | codec_x_delay = 2 * codec_x_delay; |
1344 | 10.9k | } |
1345 | | |
1346 | 33.9k | memmove( |
1347 | 33.9k | &ptr_sbr_dec->qmf_buf_real[0][0], |
1348 | 33.9k | &ptr_sbr_dec |
1349 | 33.9k | ->qmf_buf_real[ptr_sbr_dec->str_codec_qmf_bank.num_time_slots][0], |
1350 | 33.9k | (op_delay + SBR_HF_ADJ_OFFSET + codec_x_delay) * sizeof(FLOAT32) * 64); |
1351 | 33.9k | memmove( |
1352 | 33.9k | &ptr_sbr_dec->qmf_buf_imag[0][0], |
1353 | 33.9k | &ptr_sbr_dec |
1354 | 33.9k | ->qmf_buf_imag[ptr_sbr_dec->str_codec_qmf_bank.num_time_slots][0], |
1355 | 33.9k | (op_delay + SBR_HF_ADJ_OFFSET + codec_x_delay) * sizeof(FLOAT32) * 64); |
1356 | | |
1357 | 33.9k | memmove(&ptr_sbr_dec->sbr_qmf_out_real[0][0], |
1358 | 33.9k | &ptr_sbr_dec->sbr_qmf_out_real[ptr_sbr_dec->str_codec_qmf_bank |
1359 | 33.9k | .num_time_slots][0], |
1360 | 33.9k | (op_delay + SBR_HF_ADJ_OFFSET) * sizeof(FLOAT32) * 64); |
1361 | 33.9k | memmove(&ptr_sbr_dec->sbr_qmf_out_imag[0][0], |
1362 | 33.9k | &ptr_sbr_dec->sbr_qmf_out_imag[ptr_sbr_dec->str_codec_qmf_bank |
1363 | 33.9k | .num_time_slots][0], |
1364 | 33.9k | (op_delay + SBR_HF_ADJ_OFFSET) * sizeof(FLOAT32) * 64); |
1365 | | |
1366 | 33.9k | if (hbe_flag) { |
1367 | 14.0k | memmove(&ptr_sbr_dec->ph_vocod_qmf_real[0][0], |
1368 | 14.0k | &ptr_sbr_dec->ph_vocod_qmf_real[ptr_sbr_dec->str_codec_qmf_bank |
1369 | 14.0k | .num_time_slots][0], |
1370 | 14.0k | 64 * sizeof(FLOAT32) * (op_delay + SBR_HF_ADJ_OFFSET)); |
1371 | 14.0k | memmove(ptr_sbr_dec->ph_vocod_qmf_imag, |
1372 | 14.0k | ptr_sbr_dec->ph_vocod_qmf_imag + |
1373 | 14.0k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
1374 | 14.0k | 64 * sizeof(FLOAT32) * (op_delay + SBR_HF_ADJ_OFFSET)); |
1375 | 14.0k | } |
1376 | 33.9k | } |
1377 | | |
1378 | 33.9k | ixheaacd_esbr_analysis_filt_block( |
1379 | 33.9k | ptr_sbr_dec, ptr_sbr_tables, |
1380 | 33.9k | op_delay + codec_x_delay + SBR_HF_ADJ_OFFSET); |
1381 | | |
1382 | 33.9k | if (hbe_flag) { |
1383 | 14.0k | WORD32 err = ixheaacd_qmf_hbe_apply( |
1384 | 14.0k | ptr_sbr_dec->p_hbe_txposer, |
1385 | 14.0k | ptr_sbr_dec->qmf_buf_real + (op_delay + SBR_HF_ADJ_OFFSET) + |
1386 | 14.0k | ESBR_HBE_DELAY_OFFSET, |
1387 | 14.0k | ptr_sbr_dec->qmf_buf_imag + (op_delay + SBR_HF_ADJ_OFFSET) + |
1388 | 14.0k | ESBR_HBE_DELAY_OFFSET, |
1389 | 14.0k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
1390 | 14.0k | ptr_sbr_dec->ph_vocod_qmf_real + (op_delay + SBR_HF_ADJ_OFFSET), |
1391 | 14.0k | ptr_sbr_dec->ph_vocod_qmf_imag + (op_delay + SBR_HF_ADJ_OFFSET), |
1392 | 14.0k | ptr_frame_data->pitch_in_bins, ptr_header_data); |
1393 | 14.0k | if (err) return err; |
1394 | | |
1395 | 14.0k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
1396 | 10.9k | ixheaacd_hbe_repl_spec( |
1397 | 10.9k | &ptr_sbr_dec->p_hbe_txposer->x_over_qmf[0], |
1398 | 10.9k | ptr_sbr_dec->ph_vocod_qmf_real + (op_delay + SBR_HF_ADJ_OFFSET), |
1399 | 10.9k | ptr_sbr_dec->ph_vocod_qmf_imag + (op_delay + SBR_HF_ADJ_OFFSET), |
1400 | 10.9k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
1401 | 10.9k | ptr_sbr_dec->p_hbe_txposer->max_stretch); |
1402 | 10.9k | } |
1403 | 14.0k | } |
1404 | 33.9k | ixheaacd_qmf_enrg_calc(ptr_sbr_dec, upsample_ratio_idx, low_pow_flag); |
1405 | | |
1406 | 2.20M | for (i = 0; i < 64; i++) { |
1407 | 2.17M | memset(ptr_sbr_dec->sbr_qmf_out_real[i], 0, 64 * sizeof(FLOAT32)); |
1408 | 2.17M | memset(ptr_sbr_dec->sbr_qmf_out_imag[i], 0, 64 * sizeof(FLOAT32)); |
1409 | 2.17M | } |
1410 | | |
1411 | 33.9k | ptr_sbr_dec->band_count = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
1412 | | |
1413 | 33.9k | ixheaacd_esbr_synthesis_filt_block( |
1414 | 33.9k | ptr_sbr_dec, ptr_header_data, ptr_frame_data, apply_processing, |
1415 | 33.9k | pp_qmf_buf_real, pp_qmf_buf_imag, stereo_config_idx, ptr_sbr_tables, |
1416 | 33.9k | mps_sbr_flag, ch_fac, 0, 0, NULL, 0, NULL); |
1417 | | |
1418 | 33.9k | ptr_frame_data->prev_sbr_mode = sbr_mode; |
1419 | 33.9k | return 0; |
1420 | 33.9k | } |
1421 | | |
1422 | | WORD32 ixheaacd_sbr_dec_from_mps(FLOAT32 *p_mps_qmf_output, VOID *p_sbr_dec, VOID *p_sbr_frame, |
1423 | 230k | VOID *p_sbr_header, WORD32 ec_flag) { |
1424 | 230k | WORD32 i, k; |
1425 | 230k | ia_sbr_frame_info_data_struct *ptr_frame_data = |
1426 | 230k | (ia_sbr_frame_info_data_struct *)p_sbr_frame; |
1427 | 230k | ia_sbr_header_data_struct *ptr_header_data = |
1428 | 230k | (ia_sbr_header_data_struct *)p_sbr_header; |
1429 | 230k | ia_sbr_dec_struct *ptr_sbr_dec = (ia_sbr_dec_struct *)p_sbr_dec; |
1430 | 230k | ia_frame_info_struct *p_frame_info = &ptr_frame_data->str_frame_info_details; |
1431 | 230k | WORD32 no_bins; |
1432 | 230k | WORD32 upsample_ratio_idx = ptr_header_data->sbr_ratio_idx; |
1433 | 230k | WORD32 op_delay = 6 + SBR_HF_ADJ_OFFSET; |
1434 | 230k | WORD32 num_anal_bands = 40; |
1435 | 230k | WORD32 mps_sbr_flag = ptr_frame_data->mps_sbr_flag; |
1436 | 230k | WORD32 err = 0; |
1437 | | |
1438 | 230k | if (ptr_header_data->is_usf_4) { |
1439 | 35.9k | op_delay += 6; |
1440 | 35.9k | } |
1441 | | |
1442 | 230k | num_anal_bands = num_anal_bands - (upsample_ratio_idx << 3); |
1443 | | |
1444 | 230k | if (!mps_sbr_flag) { |
1445 | 123k | return 0; |
1446 | 123k | } else { |
1447 | 106k | ptr_frame_data->cov_count = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
1448 | 106k | } |
1449 | | |
1450 | 106k | no_bins = ptr_header_data->output_framesize / 64; |
1451 | | |
1452 | 3.97M | for (i = 0; i < no_bins; i++) { |
1453 | 3.86M | FLOAT32 *p_loc_mps_qmf_output = |
1454 | 3.86M | p_mps_qmf_output + i * (MAX_NUM_QMF_BANDS_ESBR * 2); |
1455 | 76.9M | for (k = 0; k < ptr_header_data->pstr_freq_band_data->sub_band_start; k++) { |
1456 | 73.0M | ptr_sbr_dec->mps_qmf_buf_real[op_delay + i][k] = *p_loc_mps_qmf_output++; |
1457 | 73.0M | ptr_sbr_dec->mps_qmf_buf_imag[op_delay + i][k] = *p_loc_mps_qmf_output++; |
1458 | | |
1459 | 73.0M | ptr_sbr_dec->mps_sbr_qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k] = |
1460 | 73.0M | ptr_sbr_dec->qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k]; |
1461 | 73.0M | ptr_sbr_dec->mps_sbr_qmf_buf_imag[SBR_HF_ADJ_OFFSET + i][k] = |
1462 | 73.0M | ptr_sbr_dec->qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k]; |
1463 | 73.0M | } |
1464 | 3.86M | } |
1465 | | |
1466 | 106k | if (ptr_frame_data->reset_flag) { |
1467 | 16.2k | WORD32 l; |
1468 | 16.2k | WORD32 start_band = ptr_header_data->pstr_freq_band_data->qmf_sb_prev; |
1469 | 16.2k | WORD32 end_band = num_anal_bands; |
1470 | 16.2k | WORD32 start_slot = |
1471 | 16.2k | SBR_HF_ADJ_OFFSET + ptr_frame_data->rate * p_frame_info->border_vec[0]; |
1472 | | |
1473 | 128k | for (l = start_slot; l < op_delay; l++) { |
1474 | 1.01M | for (k = start_band; k < end_band; k++) { |
1475 | 901k | ptr_sbr_dec->mps_qmf_buf_real[l][k] = 0.0; |
1476 | 901k | ptr_sbr_dec->mps_qmf_buf_imag[l][k] = 0.0; |
1477 | 901k | } |
1478 | 112k | } |
1479 | | |
1480 | 48.8k | for (l = 0; l < SBR_HF_ADJ_OFFSET; l++) { |
1481 | 294k | for (k = start_band; k < end_band; k++) { |
1482 | 262k | ptr_sbr_dec->mps_qmf_buf_real[l][k] = 0.0; |
1483 | 262k | ptr_sbr_dec->mps_qmf_buf_imag[l][k] = 0.0; |
1484 | 262k | } |
1485 | 32.5k | } |
1486 | 16.2k | } |
1487 | 106k | ptr_header_data->pstr_freq_band_data->qmf_sb_prev = |
1488 | 106k | ptr_header_data->pstr_freq_band_data->sub_band_start; |
1489 | | |
1490 | 106k | err = ixheaacd_generate_hf(ptr_sbr_dec->mps_qmf_buf_real + SBR_HF_ADJ_OFFSET, |
1491 | 106k | ptr_sbr_dec->mps_qmf_buf_imag + SBR_HF_ADJ_OFFSET, NULL, NULL, |
1492 | 106k | ptr_sbr_dec->mps_sbr_qmf_buf_real + SBR_HF_ADJ_OFFSET, |
1493 | 106k | ptr_sbr_dec->mps_sbr_qmf_buf_imag + SBR_HF_ADJ_OFFSET, |
1494 | 106k | ptr_frame_data, ptr_header_data, 0, |
1495 | 106k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, ec_flag); |
1496 | 106k | if (err) return err; |
1497 | | |
1498 | 106k | ptr_frame_data->pstr_sbr_header = ptr_header_data; |
1499 | 106k | ptr_frame_data->sbr_mode = ORIG_SBR; |
1500 | 106k | ptr_frame_data->prev_sbr_mode = ORIG_SBR; |
1501 | 106k | err = ixheaacd_sbr_env_calc( |
1502 | 106k | ptr_frame_data, ptr_sbr_dec->mps_sbr_qmf_buf_real + SBR_HF_ADJ_OFFSET, |
1503 | 106k | ptr_sbr_dec->mps_sbr_qmf_buf_imag + SBR_HF_ADJ_OFFSET, |
1504 | 106k | ptr_sbr_dec->mps_qmf_buf_real + SBR_HF_ADJ_OFFSET, |
1505 | 106k | ptr_sbr_dec->mps_qmf_buf_imag + SBR_HF_ADJ_OFFSET, |
1506 | 106k | (ptr_header_data->hbe_flag == 0) ? NULL : ptr_sbr_dec->p_hbe_txposer->x_over_qmf, |
1507 | 106k | ptr_sbr_dec->scratch_buff, NULL, 0, ec_flag); |
1508 | | |
1509 | 106k | if (err) return err; |
1510 | 3.97M | for (i = 0; i < no_bins; i++) { |
1511 | 3.86M | FLOAT32 *p_loc_mps_qmf_output = |
1512 | 3.86M | p_mps_qmf_output + i * (MAX_NUM_QMF_BANDS_ESBR * 2); |
1513 | 76.8M | for (k = 0; k < ptr_header_data->pstr_freq_band_data->sub_band_start; k++) { |
1514 | 73.0M | *p_loc_mps_qmf_output++ = |
1515 | 73.0M | ptr_sbr_dec->mps_qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k]; |
1516 | 73.0M | *p_loc_mps_qmf_output++ = |
1517 | 73.0M | ptr_sbr_dec->mps_qmf_buf_imag[SBR_HF_ADJ_OFFSET + i][k]; |
1518 | 73.0M | } |
1519 | 178M | for (k = ptr_header_data->pstr_freq_band_data->sub_band_start; k < 64; |
1520 | 174M | k++) { |
1521 | 174M | *p_loc_mps_qmf_output++ = |
1522 | 174M | ptr_sbr_dec->mps_sbr_qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k]; |
1523 | 174M | *p_loc_mps_qmf_output++ = |
1524 | 174M | ptr_sbr_dec->mps_sbr_qmf_buf_imag[SBR_HF_ADJ_OFFSET + i][k]; |
1525 | 174M | } |
1526 | 3.86M | } |
1527 | | |
1528 | 1.04M | for (i = 0; i < op_delay; i++) { |
1529 | 938k | memmove(ptr_sbr_dec->mps_qmf_buf_real[i], |
1530 | 938k | ptr_sbr_dec->mps_qmf_buf_real[no_bins + i], 64 * sizeof(FLOAT32)); |
1531 | | |
1532 | 938k | memmove(ptr_sbr_dec->mps_qmf_buf_imag[i], |
1533 | 938k | ptr_sbr_dec->mps_qmf_buf_imag[no_bins + i], 64 * sizeof(FLOAT32)); |
1534 | | |
1535 | 938k | memmove(ptr_sbr_dec->mps_sbr_qmf_buf_real[i], |
1536 | 938k | ptr_sbr_dec->mps_sbr_qmf_buf_real[no_bins + i], |
1537 | 938k | 64 * sizeof(FLOAT32)); |
1538 | | |
1539 | 938k | memmove(ptr_sbr_dec->mps_sbr_qmf_buf_imag[i], |
1540 | 938k | ptr_sbr_dec->mps_sbr_qmf_buf_imag[no_bins + i], |
1541 | 938k | 64 * sizeof(FLOAT32)); |
1542 | 938k | } |
1543 | | |
1544 | 106k | ptr_frame_data->reset_flag = 0; |
1545 | 106k | return err; |
1546 | 106k | } |