/src/libxaac/decoder/ixheaacd_sbr_dec.c
Line | Count | Source (jump to first uncovered line) |
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 | 131k | WORD32 upsample_ratio_idx, WORD32 low_pow_flag) { |
83 | 131k | WORD32 i, j; |
84 | 131k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
85 | 1.87M | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
86 | 31.4M | for (j = 0; j < 16; j++) { |
87 | 29.5M | ptr_sbr_dec->qmf_energy_buf[i][j] = |
88 | 29.5M | ptr_sbr_dec->qmf_buf_real[2 + i][j] * |
89 | 29.5M | ptr_sbr_dec->qmf_buf_real[2 + i][j]; |
90 | 29.5M | if (!low_pow_flag) |
91 | 29.5M | ptr_sbr_dec->qmf_energy_buf[i][j] += |
92 | 29.5M | (ptr_sbr_dec->qmf_buf_imag[2 + i][j] * |
93 | 29.5M | ptr_sbr_dec->qmf_buf_imag[2 + i][j]); |
94 | 29.5M | } |
95 | 1.84M | } |
96 | | |
97 | 490k | for (i = 0; i < 16; i++) { |
98 | 7.85M | for (j = 0; j < 16; j++) { |
99 | 7.39M | ptr_sbr_dec->pvc_qmf_enrg_arr[32 * i + j] = |
100 | 7.39M | (ptr_sbr_dec->qmf_energy_buf[4 * i + 0][j] + |
101 | 7.39M | ptr_sbr_dec->qmf_energy_buf[4 * i + 1][j] + |
102 | 7.39M | ptr_sbr_dec->qmf_energy_buf[4 * i + 2][j] + |
103 | 7.39M | ptr_sbr_dec->qmf_energy_buf[4 * i + 3][j]) * |
104 | 7.39M | 0.25f; |
105 | 7.39M | } |
106 | 462k | } |
107 | 102k | } else { |
108 | 3.39M | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
109 | 108M | for (j = 0; j < 32; j++) { |
110 | 105M | ptr_sbr_dec->qmf_energy_buf[i][j] = |
111 | 105M | ptr_sbr_dec->qmf_buf_real[2 + i][j] * |
112 | 105M | ptr_sbr_dec->qmf_buf_real[2 + i][j]; |
113 | 105M | if (!low_pow_flag) |
114 | 105M | ptr_sbr_dec->qmf_energy_buf[i][j] += |
115 | 105M | (ptr_sbr_dec->qmf_buf_imag[2 + i][j] * |
116 | 105M | ptr_sbr_dec->qmf_buf_imag[2 + i][j]); |
117 | 105M | } |
118 | 3.28M | } |
119 | | |
120 | 1.74M | for (i = 0; i < 16; i++) { |
121 | 54.2M | for (j = 0; j < 32; j++) { |
122 | 52.6M | ptr_sbr_dec->pvc_qmf_enrg_arr[32 * i + j] = |
123 | 52.6M | (ptr_sbr_dec->qmf_energy_buf[2 * i + 0][j] + |
124 | 52.6M | ptr_sbr_dec->qmf_energy_buf[2 * i + 1][j]) * |
125 | 52.6M | 0.5f; |
126 | 52.6M | } |
127 | 1.64M | } |
128 | 102k | } |
129 | 131k | } |
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 | 51.1k | WORD32 max_stretch) { |
135 | 51.1k | WORD32 patch_bands; |
136 | 51.1k | WORD32 patch, band, col, target, source_bands, i; |
137 | 51.1k | WORD32 num_patches = 0; |
138 | | |
139 | 307k | for (i = 1; i < MAX_NUM_PATCHES; i++) { |
140 | 255k | if (x_over_qmf[i] != 0) { |
141 | 128k | num_patches++; |
142 | 128k | } |
143 | 255k | } |
144 | | |
145 | 57.5k | for (patch = (max_stretch - 1); patch < num_patches; patch++) { |
146 | 6.35k | patch_bands = x_over_qmf[patch + 1] - x_over_qmf[patch]; |
147 | 6.35k | target = x_over_qmf[patch]; |
148 | 6.35k | source_bands = x_over_qmf[max_stretch - 1] - x_over_qmf[max_stretch - 2]; |
149 | 14.8k | while (patch_bands > 0) { |
150 | 8.45k | WORD32 ixheaacd_num_bands = source_bands; |
151 | 8.45k | WORD32 start_band = x_over_qmf[max_stretch - 1] - 1; |
152 | 8.45k | if (target + ixheaacd_num_bands >= x_over_qmf[patch + 1]) { |
153 | 6.77k | ixheaacd_num_bands = x_over_qmf[patch + 1] - target; |
154 | 6.77k | } |
155 | 8.45k | if ((((target + ixheaacd_num_bands - 1) & 1) + |
156 | 8.45k | ((x_over_qmf[max_stretch - 1] - 1) & 1)) & |
157 | 8.45k | 1) { |
158 | 3.46k | if (ixheaacd_num_bands == source_bands) { |
159 | 1.26k | ixheaacd_num_bands--; |
160 | 2.19k | } else { |
161 | 2.19k | start_band--; |
162 | 2.19k | } |
163 | 3.46k | } |
164 | 8.45k | if (!ixheaacd_num_bands) break; |
165 | 549k | for (col = 0; col < no_bins; col++) { |
166 | 541k | WORD32 i = 0; |
167 | 541k | band = target + ixheaacd_num_bands - 1; |
168 | 541k | if (64 <= band) { |
169 | 0 | band = 63; |
170 | 0 | } |
171 | 541k | if (x_over_qmf[patch + 1] <= band) { |
172 | 0 | band = x_over_qmf[patch + 1] - 1; |
173 | 0 | } |
174 | 3.47M | for (i = 0; i < ixheaacd_num_bands; i++, band--) { |
175 | 2.93M | qmf_buf_real[col][band] = qmf_buf_real[col][start_band - i]; |
176 | 2.93M | qmf_buf_imag[col][band] = qmf_buf_imag[col][start_band - i]; |
177 | 2.93M | } |
178 | 541k | } |
179 | 8.45k | target += ixheaacd_num_bands; |
180 | 8.45k | patch_bands -= ixheaacd_num_bands; |
181 | 8.45k | } |
182 | 6.35k | } |
183 | 51.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 | 347k | WORD32 op_delay) { |
188 | 347k | FLOAT32 *core_coder_samples; |
189 | 347k | WORD32 *ptr_filt_states; |
190 | 347k | WORD32 *ptr_filt_states_1; |
191 | 347k | WORD32 *ptr_filt_states_2; |
192 | 347k | WORD32 *ptr_temp; |
193 | 347k | WORD32 *ptr_win_coeffs_1; |
194 | 347k | WORD32 *ptr_win_coeffs_2; |
195 | 347k | WORD32 *ptr_win_coeffs; |
196 | 347k | WORD32 *ploc_qmf_buf_real; |
197 | 347k | WORD32 *ploc_qmf_buf_imag; |
198 | 347k | WORD32 local_qmf_buffer[128] = {0}; |
199 | 347k | WORD32 anal_buf[2 * 32]; |
200 | 347k | WORD32 idx, z; |
201 | 347k | WORD32 core_syn_ch_index; |
202 | 347k | FLOAT32 gain; |
203 | 347k | WORD32 filt_offset; |
204 | 347k | WORD32 num_columns; |
205 | 347k | ia_qmf_dec_tables_struct *qmf_dec_tables_ptr = |
206 | 347k | sbr_tables_ptr->qmf_dec_tables_ptr; |
207 | 347k | ia_sbr_qmf_filter_bank_struct *pstr_qmf_anal_bank = |
208 | 347k | &ptr_sbr_dec->str_codec_qmf_bank; |
209 | 347k | core_coder_samples = ptr_sbr_dec->time_sample_buf; |
210 | 347k | ptr_filt_states = pstr_qmf_anal_bank->state_new_samples_pos_low_32; |
211 | 347k | ptr_win_coeffs_1 = pstr_qmf_anal_bank->filter_pos_32; |
212 | 347k | num_columns = pstr_qmf_anal_bank->no_channels; |
213 | | |
214 | 347k | switch (num_columns) { |
215 | 46.7k | case 16: |
216 | 46.7k | ptr_win_coeffs_2 = ptr_win_coeffs_1 + 64; |
217 | 46.7k | gain = 128.0f; |
218 | 46.7k | filt_offset = 64; |
219 | 46.7k | break; |
220 | 35.2k | case 24: |
221 | 35.2k | ptr_win_coeffs_2 = ptr_win_coeffs_1 + 24; |
222 | 35.2k | gain = 12.0f; |
223 | 35.2k | filt_offset = 24; |
224 | 35.2k | break; |
225 | 265k | case 32: |
226 | 265k | ptr_win_coeffs_2 = ptr_win_coeffs_1 + 64; |
227 | 265k | gain = 256.0f; |
228 | 265k | filt_offset = 64; |
229 | 265k | 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 | 347k | } |
236 | 347k | gain = 1.0f / gain; |
237 | | |
238 | 347k | pstr_qmf_anal_bank->usb = num_columns; |
239 | | |
240 | 347k | ploc_qmf_buf_real = &local_qmf_buffer[0]; |
241 | 347k | ploc_qmf_buf_imag = &local_qmf_buffer[64]; |
242 | | |
243 | 347k | ptr_filt_states_1 = pstr_qmf_anal_bank->anal_filter_states_32; |
244 | 347k | ptr_filt_states_2 = pstr_qmf_anal_bank->anal_filter_states_32 + num_columns; |
245 | | |
246 | 12.9M | for (idx = 0; idx < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; idx++) { |
247 | 359M | for (z = 0; z < num_columns; z++) { |
248 | 347M | ptr_filt_states[num_columns - 1 - z] = |
249 | 347M | (WORD32)(core_coder_samples[z] * (1 << 15)); |
250 | 347M | } |
251 | 12.6M | ixheaacd_esbr_qmfanal32_winadd(ptr_filt_states_1, ptr_filt_states_2, |
252 | 12.6M | ptr_win_coeffs_1, ptr_win_coeffs_2, anal_buf, |
253 | 12.6M | num_columns); |
254 | | |
255 | 12.6M | core_coder_samples += num_columns; |
256 | | |
257 | 12.6M | ptr_filt_states -= num_columns; |
258 | 12.6M | if (ptr_filt_states < pstr_qmf_anal_bank->anal_filter_states_32) { |
259 | 1.26M | ptr_filt_states = pstr_qmf_anal_bank->anal_filter_states_32 + |
260 | 1.26M | 10 * num_columns - num_columns; |
261 | 1.26M | } |
262 | | |
263 | 12.6M | ptr_temp = ptr_filt_states_1; |
264 | 12.6M | ptr_filt_states_1 = ptr_filt_states_2; |
265 | 12.6M | ptr_filt_states_2 = ptr_temp; |
266 | | |
267 | 12.6M | ptr_win_coeffs_1 += filt_offset; |
268 | 12.6M | ptr_win_coeffs_2 += filt_offset; |
269 | | |
270 | 12.6M | ptr_win_coeffs = ptr_win_coeffs_1; |
271 | 12.6M | ptr_win_coeffs_1 = ptr_win_coeffs_2; |
272 | 12.6M | ptr_win_coeffs_2 = ptr_win_coeffs; |
273 | | |
274 | 12.6M | if (ptr_win_coeffs_2 > |
275 | 12.6M | (pstr_qmf_anal_bank->analy_win_coeff_32 + filt_offset * 10)) { |
276 | 1.26M | ptr_win_coeffs_1 = pstr_qmf_anal_bank->analy_win_coeff_32; |
277 | 1.26M | ptr_win_coeffs_2 = pstr_qmf_anal_bank->analy_win_coeff_32 + filt_offset; |
278 | 1.26M | } |
279 | | |
280 | 12.6M | ixheaacd_esbr_fwd_modulation(anal_buf, &ploc_qmf_buf_real[0], |
281 | 12.6M | &ploc_qmf_buf_imag[0], pstr_qmf_anal_bank, |
282 | 12.6M | qmf_dec_tables_ptr); |
283 | 12.6M | core_syn_ch_index = num_columns; |
284 | | |
285 | 359M | for (z = 0; z < core_syn_ch_index; z++) { |
286 | 347M | ptr_sbr_dec->qmf_buf_real[op_delay + idx][z] = |
287 | 347M | ((FLOAT32)ploc_qmf_buf_real[z] * gain); |
288 | 347M | ptr_sbr_dec->qmf_buf_imag[op_delay + idx][z] = |
289 | 347M | ((FLOAT32)ploc_qmf_buf_imag[z] * gain); |
290 | 347M | } |
291 | 12.6M | } |
292 | | |
293 | 347k | pstr_qmf_anal_bank->filter_pos_32 = ptr_win_coeffs_1; |
294 | 347k | pstr_qmf_anal_bank->state_new_samples_pos_low_32 = ptr_filt_states; |
295 | 347k | } |
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 | 267k | WORD32 apply_processing) { |
303 | 267k | WORD32 i, k; |
304 | 267k | WORD32 stop_border = 0; |
305 | 267k | WORD32 num_anal_bands = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
306 | 267k | WORD32 x_over_band = num_anal_bands; |
307 | | |
308 | 267k | if (apply_processing) { |
309 | 222k | if (ptr_header_data->sbr_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
310 | 18.0k | stop_border = 4 * ptr_frame_data->str_frame_info_details.border_vec[0]; |
311 | 204k | } else { |
312 | 204k | stop_border = 2 * ptr_frame_data->str_frame_info_details.border_vec[0]; |
313 | 204k | } |
314 | 222k | x_over_band = ptr_header_data->pstr_freq_band_data->qmf_sb_prev; |
315 | 222k | } |
316 | | |
317 | 267k | if (stereo_config_idx > 0) { |
318 | 100k | for (i = 0; i < stop_border; i++) { |
319 | 98.1k | for (k = 0; k < 3; k++) { |
320 | 73.5k | *qmf_buf_real++ = |
321 | 73.5k | ptr_sbr_dec->qmf_buf_real[(2) + i + HYBRID_FILTER_DELAY][k]; |
322 | 73.5k | *qmf_buf_imag++ = |
323 | 73.5k | ptr_sbr_dec->qmf_buf_imag[(2) + i + HYBRID_FILTER_DELAY][k]; |
324 | 73.5k | } |
325 | | |
326 | 370k | for (; k < x_over_band; k++) { |
327 | 346k | *qmf_buf_real++ = ptr_sbr_dec->qmf_buf_real[(2) + i][k]; |
328 | 346k | *qmf_buf_imag++ = ptr_sbr_dec->qmf_buf_imag[(2) + i][k]; |
329 | 346k | } |
330 | | |
331 | 1.17M | for (; k < 64; k++) { |
332 | 1.14M | *qmf_buf_real++ = ptr_sbr_dec->sbr_qmf_out_real[(2) + i][k]; |
333 | 1.14M | *qmf_buf_imag++ = ptr_sbr_dec->sbr_qmf_out_imag[(2) + i][k]; |
334 | 1.14M | } |
335 | | |
336 | 24.5k | qmf_buf_real += 14; |
337 | 24.5k | qmf_buf_imag += 14; |
338 | 24.5k | } |
339 | | |
340 | 75.9k | x_over_band = ptr_header_data->pstr_freq_band_data->sub_band_start; |
341 | | |
342 | 3.49M | for (; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
343 | 13.6M | for (k = 0; k < 3; k++) { |
344 | 10.2M | *qmf_buf_real++ = |
345 | 10.2M | ptr_sbr_dec->qmf_buf_real[(2) + i + HYBRID_FILTER_DELAY][k]; |
346 | 10.2M | *qmf_buf_imag++ = |
347 | 10.2M | ptr_sbr_dec->qmf_buf_imag[(2) + i + HYBRID_FILTER_DELAY][k]; |
348 | 10.2M | } |
349 | | |
350 | 108M | for (; k < x_over_band; k++) { |
351 | 105M | *qmf_buf_real++ = ptr_sbr_dec->qmf_buf_real[(2) + i][k]; |
352 | 105M | *qmf_buf_imag++ = ptr_sbr_dec->qmf_buf_imag[(2) + i][k]; |
353 | 105M | } |
354 | | |
355 | 106M | for (; k < 64; k++) { |
356 | 103M | *qmf_buf_real++ = ptr_sbr_dec->sbr_qmf_out_real[(2) + i][k]; |
357 | 103M | *qmf_buf_imag++ = ptr_sbr_dec->sbr_qmf_out_imag[(2) + i][k]; |
358 | 103M | } |
359 | | |
360 | 3.41M | qmf_buf_real += 14; |
361 | 3.41M | qmf_buf_imag += 14; |
362 | 3.41M | } |
363 | | |
364 | 191k | } else { |
365 | 301k | for (i = 0; i < stop_border; i++) { |
366 | 1.77M | 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 | 5.52M | for (; k < 64; k++) { |
372 | 5.41M | *qmf_buf_real++ = ptr_sbr_dec->sbr_qmf_out_real[(2) + i][k]; |
373 | 5.41M | *qmf_buf_imag++ = ptr_sbr_dec->sbr_qmf_out_imag[(2) + i][k]; |
374 | 5.41M | } |
375 | | |
376 | 110k | qmf_buf_real += 14; |
377 | 110k | qmf_buf_imag += 14; |
378 | 110k | } |
379 | | |
380 | 191k | x_over_band = ptr_header_data->pstr_freq_band_data->sub_band_start; |
381 | | |
382 | 6.27M | for (; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
383 | 88.1M | for (k = 0; k < x_over_band; k++) { |
384 | 82.0M | *qmf_buf_real++ = ptr_sbr_dec->qmf_buf_real[(2) + i][k]; |
385 | 82.0M | *qmf_buf_imag++ = ptr_sbr_dec->qmf_buf_imag[(2) + i][k]; |
386 | 82.0M | } |
387 | | |
388 | 313M | for (; k < 64; k++) { |
389 | 307M | *qmf_buf_real++ = ptr_sbr_dec->sbr_qmf_out_real[(2) + i][k]; |
390 | 307M | *qmf_buf_imag++ = ptr_sbr_dec->sbr_qmf_out_imag[(2) + i][k]; |
391 | 307M | } |
392 | | |
393 | 6.08M | qmf_buf_real += 14; |
394 | 6.08M | qmf_buf_imag += 14; |
395 | 6.08M | } |
396 | 191k | } |
397 | 267k | } |
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 | 80.5k | WORD32 stereo_config_idx) { |
403 | 80.5k | WORD32 i, k; |
404 | 80.5k | WORD32 num_anal_bands = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
405 | 80.5k | WORD32 x_over_band = num_anal_bands; |
406 | | |
407 | 80.5k | if (stereo_config_idx > 0) { |
408 | 3.07M | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
409 | 11.9M | for (k = 0; k < 3; k++) { |
410 | 8.97M | *qmf_buf_real++ = |
411 | 8.97M | ptr_sbr_dec->qmf_buf_real[(2) + i + HYBRID_FILTER_DELAY][k]; |
412 | 8.97M | *qmf_buf_imag++ = |
413 | 8.97M | ptr_sbr_dec->qmf_buf_imag[(2) + i + HYBRID_FILTER_DELAY][k]; |
414 | 8.97M | } |
415 | | |
416 | 76.4M | for (; k < x_over_band; k++) { |
417 | 73.4M | *qmf_buf_real++ = ptr_sbr_dec->qmf_buf_real[(2) + i][k]; |
418 | 73.4M | *qmf_buf_imag++ = ptr_sbr_dec->qmf_buf_imag[(2) + i][k]; |
419 | 73.4M | } |
420 | | |
421 | 112M | for (; k < 64; k++) { |
422 | 109M | *qmf_buf_real++ = 0; |
423 | 109M | *qmf_buf_imag++ = 0; |
424 | 109M | } |
425 | | |
426 | 2.99M | qmf_buf_real += 14; |
427 | 2.99M | qmf_buf_imag += 14; |
428 | 2.99M | } |
429 | 80.5k | } 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 | 80.5k | } |
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 | 361k | FLAG drc_on, WORD32 drc_sbr_factors[][64]) { |
454 | | |
455 | 361k | WORD32 i, k; |
456 | 361k | WORD32 *ptr_filt_states; |
457 | 361k | WORD32 *ptr_filt_states_1; |
458 | 361k | WORD32 *ptr_filt_states_2; |
459 | 361k | WORD32 *filter_l; |
460 | 361k | WORD32 *ploc_qmf_buf_real; |
461 | 361k | WORD32 *ploc_qmf_buf_imag; |
462 | 361k | WORD32 out_scalefactor; |
463 | 361k | WORD32 sixty4, thrity2; |
464 | 361k | WORD32 no_synthesis_channels; |
465 | 361k | WORD32 ixheaacd_drc_offset; |
466 | 361k | FLOAT32 *syn_buffer; |
467 | 361k | WORD32 *local_qmf_buffer = ptr_sbr_dec->sbr_scratch_local; |
468 | 361k | WORD32 *time_out = &(ptr_sbr_dec->sbr_scratch_local[128]); |
469 | 361k | FLOAT32 *time_sample_buf; |
470 | 361k | if (ps_enable) { |
471 | 26.3k | time_sample_buf = ptr_ps_dec->time_sample_buf[0]; |
472 | 334k | } else { |
473 | 334k | time_sample_buf = ptr_sbr_dec->time_sample_buf; |
474 | 334k | } |
475 | 361k | ia_sbr_qmf_filter_bank_struct *qmf_bank = |
476 | 361k | &ptr_sbr_dec->str_synthesis_qmf_bank; |
477 | 361k | ia_qmf_dec_tables_struct *qmf_dec_tables_ptr = |
478 | 361k | sbr_tables_ptr->qmf_dec_tables_ptr; |
479 | | |
480 | 361k | if (!skip_re_grouping) { |
481 | 347k | if (!mps_sbr_flag) { |
482 | 267k | ixheaacd_esbr_synthesis_regrp(&qmf_buf_real[0][0], &qmf_buf_imag[0][0], |
483 | 267k | ptr_sbr_dec, ptr_frame_data, ptr_header_data, |
484 | 267k | stereo_config_idx, apply_processing); |
485 | 267k | if (ps_enable) { |
486 | 13.1k | FLOAT32 factor = 1.0f; |
487 | 92.2k | for (i = ptr_ps_dec->num_sub_samples;i < (WORD32)ptr_ps_dec->num_sub_samples + 6;i++) { |
488 | 474k | for (k = 0; k < 5; k++) |
489 | 395k | { |
490 | 395k | if (drc_on) |
491 | 395k | { |
492 | 395k | 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 | 395k | else |
497 | 395k | { |
498 | 395k | factor = (FLOAT32)drc_sbr_factors[i + 32 - 26][k] / Q25; |
499 | 395k | } |
500 | 395k | } |
501 | 395k | ptr_ps_dec->pp_qmf_buf_real[0][i][k] = |
502 | 395k | factor * ptr_sbr_dec->qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k]; |
503 | 395k | ptr_ps_dec->pp_qmf_buf_imag[0][i][k] = |
504 | 395k | factor * ptr_sbr_dec->qmf_buf_imag[SBR_HF_ADJ_OFFSET + i][k]; |
505 | 395k | } |
506 | 79.0k | } |
507 | 13.1k | } |
508 | 267k | if (ps_enable && apply_processing) { |
509 | 13.1k | WORD32 usb = ptr_header_data->pstr_freq_band_data->sub_band_end; |
510 | | |
511 | 13.1k | ixheaacd_esbr_apply_ps(ptr_ps_dec, |
512 | 13.1k | ptr_ps_dec->pp_qmf_buf_real[0], |
513 | 13.1k | ptr_ps_dec->pp_qmf_buf_imag[0], |
514 | 13.1k | ptr_ps_dec->pp_qmf_buf_real[1], |
515 | 13.1k | ptr_ps_dec->pp_qmf_buf_imag[1], |
516 | 13.1k | usb, sbr_tables_ptr->ps_tables_ptr, |
517 | 13.1k | ptr_header_data->num_time_slots); |
518 | 254k | } else if (ps_enable) { |
519 | 2.04k | for (i = 0; i < (ptr_header_data->num_time_slots * 2); i++) { |
520 | 128k | for (k = 0; k < 64; k++) { |
521 | 126k | ptr_ps_dec->pp_qmf_buf_real[1][i][k] = ptr_ps_dec->pp_qmf_buf_real[0][i][k]; |
522 | 126k | ptr_ps_dec->pp_qmf_buf_imag[1][i][k] = ptr_ps_dec->pp_qmf_buf_imag[0][i][k]; |
523 | 126k | } |
524 | 1.98k | } |
525 | 62 | } |
526 | 267k | } else { |
527 | 80.5k | ixheaacd_mps_esbr_synthesis_regrp(&qmf_buf_real[0][0], &qmf_buf_imag[0][0], |
528 | 80.5k | ptr_sbr_dec, stereo_config_idx); |
529 | 80.5k | } |
530 | 347k | } else { |
531 | 13.1k | if (ps_enable) { |
532 | 13.1k | time_sample_buf = ptr_ps_dec->time_sample_buf[1]; |
533 | 13.1k | } |
534 | 13.1k | } |
535 | | |
536 | 361k | if (drc_on) |
537 | 34.5k | { |
538 | 34.5k | FLOAT32 factor = 1.0f; |
539 | 1.13M | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) |
540 | 1.10M | { |
541 | 71.7M | for (k = 0; k < 64; k++) |
542 | 70.6M | { |
543 | 70.6M | if (ptr_sbr_dec->str_codec_qmf_bank.num_time_slots == 30) |
544 | 36.4k | { |
545 | 36.4k | factor = (FLOAT32)drc_sbr_factors[i + 30 - 25][k] / Q25; |
546 | 36.4k | } |
547 | 70.6M | else |
548 | 70.6M | { |
549 | 70.6M | factor = (FLOAT32)drc_sbr_factors[i + 32 - 26][k] / Q25; |
550 | 70.6M | } |
551 | 70.6M | qmf_buf_real[i][k] *= factor; |
552 | 70.6M | qmf_buf_imag[i][k] *= factor; |
553 | 70.6M | } |
554 | 1.10M | } |
555 | 34.5k | } |
556 | | |
557 | 361k | if (stereo_config_idx <= 0) { |
558 | 204k | out_scalefactor = 5; |
559 | 204k | no_synthesis_channels = qmf_bank->no_channels; |
560 | 204k | sixty4 = NO_SYNTHESIS_CHANNELS; |
561 | 204k | thrity2 = qmf_bank->no_channels; |
562 | | |
563 | 204k | if (no_synthesis_channels == NO_SYNTHESIS_CHANNELS_DOWN_SAMPLED) |
564 | 397 | { |
565 | 397 | qmf_bank->esbr_cos_twiddle = |
566 | 397 | (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l32; |
567 | 397 | qmf_bank->esbr_alt_sin_twiddle = |
568 | 397 | (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l32; |
569 | 397 | } |
570 | 204k | else |
571 | 204k | { |
572 | 204k | qmf_bank->esbr_cos_twiddle = |
573 | 204k | (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l64; |
574 | 204k | qmf_bank->esbr_alt_sin_twiddle = |
575 | 204k | (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l64; |
576 | 204k | } |
577 | | |
578 | 204k | qmf_bank->filter_pos_syn_32 += |
579 | 204k | qmf_dec_tables_ptr->esbr_qmf_c - qmf_bank->p_filter_32; |
580 | 204k | qmf_bank->p_filter_32 = qmf_dec_tables_ptr->esbr_qmf_c; |
581 | | |
582 | 204k | ptr_filt_states = qmf_bank->filter_states_32; |
583 | | |
584 | 204k | ptr_filt_states_1 = &ptr_filt_states[0]; |
585 | 204k | ptr_filt_states_2 = ptr_filt_states_1 + no_synthesis_channels; |
586 | | |
587 | 204k | filter_l = qmf_bank->filter_pos_syn_32; |
588 | | |
589 | 204k | ixheaacd_drc_offset = qmf_bank->ixheaacd_drc_offset; |
590 | | |
591 | 6.81M | for (i = 0; i < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots; i++) { |
592 | 430M | for (k = 0; k < 64; k++) { |
593 | 423M | local_qmf_buffer[k + 0] = (WORD32)(qmf_buf_real[i][k] * 64); |
594 | 423M | local_qmf_buffer[k + 64] = (WORD32)(qmf_buf_imag[i][k] * 64); |
595 | 423M | } |
596 | 6.61M | ploc_qmf_buf_real = local_qmf_buffer; |
597 | 6.61M | ploc_qmf_buf_imag = local_qmf_buffer + 64; |
598 | | |
599 | 6.61M | ixheaacd_esbr_inv_modulation(ploc_qmf_buf_real, |
600 | 6.61M | &ptr_sbr_dec->str_synthesis_qmf_bank, |
601 | 6.61M | sbr_tables_ptr->qmf_dec_tables_ptr, |
602 | 6.61M | no_synthesis_channels); |
603 | | |
604 | 6.61M | ixheaacd_shiftrountine_with_rnd_hq(ploc_qmf_buf_real, ploc_qmf_buf_imag, |
605 | 6.61M | &ptr_filt_states[ixheaacd_drc_offset], |
606 | 6.61M | no_synthesis_channels, |
607 | 6.61M | out_scalefactor + 1); |
608 | | |
609 | 6.61M | if (no_synthesis_channels == NO_SYNTHESIS_CHANNELS_DOWN_SAMPLED) { |
610 | 12.6k | ixheaacd_esbr_qmfsyn32_winadd(ptr_filt_states_1, ptr_filt_states_2, |
611 | 12.6k | filter_l, &time_out[0], ch_fac); |
612 | | |
613 | 12.6k | if (!mps_sbr_flag) { |
614 | 12.6k | syn_buffer = time_sample_buf + i * 32; |
615 | 12.6k | } else { |
616 | 0 | syn_buffer = ptr_sbr_dec->time_sample_buf + i * 32; |
617 | 0 | } |
618 | 418k | for (k = 0; k < 32; k++) { |
619 | 406k | syn_buffer[k] = (FLOAT32)time_out[k] / (1 << 16); |
620 | 406k | } |
621 | | |
622 | 12.6k | ptr_filt_states_1 += thrity2; |
623 | 12.6k | ptr_filt_states_2 -= thrity2; |
624 | 12.6k | thrity2 = -thrity2; |
625 | 12.6k | ixheaacd_drc_offset -= 64; |
626 | | |
627 | 12.6k | if (ixheaacd_drc_offset < 0) ixheaacd_drc_offset += 640; |
628 | 6.60M | } else { |
629 | 6.60M | ixheaacd_esbr_qmfsyn64_winadd(ptr_filt_states_1, ptr_filt_states_2, |
630 | 6.60M | filter_l, &time_out[0], ch_fac); |
631 | | |
632 | 6.60M | if (!mps_sbr_flag) { |
633 | 6.60M | syn_buffer = time_sample_buf + i * 64; |
634 | 6.60M | } else { |
635 | 0 | syn_buffer = ptr_sbr_dec->time_sample_buf + i * 64; |
636 | 0 | } |
637 | 429M | for (k = 0; k < 64; k++) { |
638 | 422M | syn_buffer[k] = (FLOAT32)time_out[k] / (1 << 16); |
639 | 422M | } |
640 | | |
641 | 6.60M | ptr_filt_states_1 += sixty4; |
642 | 6.60M | ptr_filt_states_2 -= sixty4; |
643 | 6.60M | sixty4 = -sixty4; |
644 | 6.60M | ixheaacd_drc_offset -= 128; |
645 | | |
646 | 6.60M | if (ixheaacd_drc_offset < 0) ixheaacd_drc_offset += 1280; |
647 | 6.60M | } |
648 | | |
649 | 6.61M | filter_l += 64; |
650 | | |
651 | 6.61M | if (filter_l == qmf_bank->p_filter_32 + 640) |
652 | 660k | filter_l = (WORD32 *)qmf_bank->p_filter_32; |
653 | 6.61M | } |
654 | | |
655 | 204k | qmf_bank->filter_pos_syn_32 = filter_l; |
656 | 204k | qmf_bank->ixheaacd_drc_offset = ixheaacd_drc_offset; |
657 | 204k | } |
658 | | |
659 | 361k | if (!mps_sbr_flag) ptr_frame_data->reset_flag = 0; |
660 | 361k | } |
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 | 380k | WORD32 ec_flag) { |
672 | 380k | WORD i, j, k; |
673 | 380k | WORD slot, reserve; |
674 | 380k | WORD save_lb_scale; |
675 | 380k | WORD op_delay; |
676 | 380k | IA_ERRORCODE err_code = IA_NO_ERROR; |
677 | | |
678 | 380k | WORD32 *p_arr_qmf_buf_real[MAX_ENV_COLS] = {0}; |
679 | 380k | WORD32 *p_arr_qmf_buf_imag[MAX_ENV_COLS] = {0}; |
680 | 380k | WORD32 *ptr; |
681 | 380k | WORD hbe_flag = ptr_header_data->hbe_flag; |
682 | | |
683 | 380k | FLOAT32 **pp_qmf_buf_real = NULL; |
684 | 380k | FLOAT32 **pp_qmf_buf_imag = NULL; |
685 | 380k | FLOAT32 pvc_dec_out_buf[16 * 64]; |
686 | | |
687 | 380k | WORD upsample_ratio_idx = ptr_header_data->sbr_ratio_idx; |
688 | 380k | WORD no_bins; |
689 | 380k | WORD mps_sbr_flag = ptr_frame_data->mps_sbr_flag; |
690 | 380k | WORD stereo_config_idx = ptr_frame_data->stereo_config_idx; |
691 | 380k | WORD sbr_mode = ptr_frame_data->sbr_mode; |
692 | 380k | WORD usac_flag = ptr_header_data->usac_flag; |
693 | 380k | WORD add_slot = 0; |
694 | | |
695 | 380k | FLOAT32 *pvc_qmf_enrg_arr = (FLOAT32 *)ptr_sbr_dec->pvc_qmf_enrg_arr; |
696 | | |
697 | 380k | WORD32 dft_hbe_flag = ptr_header_data->esbr_hq; |
698 | 380k | WORD32 esbr_hbe_delay_offsets; |
699 | 380k | if (ptr_header_data->num_time_slots == 15) |
700 | 27.5k | esbr_hbe_delay_offsets = ESBR_HBE_DELAY_OFFSET_960; |
701 | 352k | else |
702 | 352k | esbr_hbe_delay_offsets = ESBR_HBE_DELAY_OFFSET; |
703 | | |
704 | 380k | memset(pvc_dec_out_buf, 0, 1024 * sizeof(FLOAT32)); |
705 | 380k | memset(pvc_qmf_enrg_arr, 0, 512 * sizeof(FLOAT32)); |
706 | 380k | if (audio_object_type == AOT_ER_AAC_ELD) { |
707 | 59.2k | op_delay = 0; |
708 | 320k | } else { |
709 | 320k | op_delay = 6; |
710 | 320k | } |
711 | | |
712 | 380k | if (ldmps_present == 1) add_slot = SBR_HF_ADJ_OFFSET; |
713 | | |
714 | 380k | if (!((audio_object_type == AOT_ER_AAC_ELD) || (audio_object_type == AOT_ER_AAC_LD)) |
715 | 380k | && ptr_header_data->enh_sbr) { |
716 | 320k | ch_fac = 1; |
717 | 320k | pp_qmf_buf_real = ptr_sbr_dec->pp_qmf_buf_real; |
718 | 320k | pp_qmf_buf_imag = ptr_sbr_dec->pp_qmf_buf_imag; |
719 | 320k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
720 | 30.9k | op_delay = 2 * 6; |
721 | 30.9k | } |
722 | 320k | } |
723 | | |
724 | 380k | no_bins = (ptr_header_data->num_time_slots * ptr_header_data->time_step); |
725 | | |
726 | 380k | if ((audio_object_type == AOT_ER_AAC_ELD) || |
727 | 380k | (audio_object_type == AOT_ER_AAC_LD) || |
728 | 380k | !ptr_header_data->enh_sbr) { |
729 | 59.2k | WORD32 num = op_delay; |
730 | 59.2k | WORD32 *ptr_pers_qmf_real = ptr_sbr_dec->ptr_sbr_overlap_buf; |
731 | 59.2k | WORD32 *p_scr_qmf_real = ptr_work_buf_core + (2 << (6 + !low_pow_flag)); |
732 | | |
733 | 59.2k | if (ptr_header_data->num_time_slots != 15) { |
734 | 31.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 | 31.7k | } else { |
741 | 27.5k | 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 | 27.5k | } |
748 | | |
749 | 59.2k | if (!low_pow_flag) { |
750 | 59.2k | num = num << 1; |
751 | 59.2k | } |
752 | 59.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 | 59.2k | ptr = p_scr_qmf_real; |
757 | | |
758 | 989k | for (slot = 0; slot < op_delay + no_bins + add_slot; slot++) { |
759 | 929k | p_arr_qmf_buf_real[slot] = ptr; |
760 | 929k | ptr += NO_SYNTHESIS_CHANNELS; |
761 | | |
762 | 929k | if (!low_pow_flag) { |
763 | 929k | p_arr_qmf_buf_imag[slot] = ptr; |
764 | 929k | ptr += NO_SYNTHESIS_CHANNELS; |
765 | 929k | } |
766 | 929k | } |
767 | | |
768 | 59.2k | ptr_sbr_dec->str_sbr_scale_fact.lb_scale = 0; |
769 | | |
770 | 59.2k | if (apply_processing) { |
771 | 59.2k | ixheaacd_rescale_x_overlap(ptr_sbr_dec, ptr_header_data, ptr_frame_data, |
772 | 59.2k | ptr_frame_data_prev, p_arr_qmf_buf_real, |
773 | 59.2k | p_arr_qmf_buf_imag, low_pow_flag); |
774 | 59.2k | } |
775 | 59.2k | } |
776 | | |
777 | 380k | if ((audio_object_type == AOT_AAC_LC) && (heaac_mps_present == 1) && ptr_header_data->enh_sbr) { |
778 | 1.83k | WORD32 num_anal_bands = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
779 | 1.83k | WORD32 frame_move = 9 * num_anal_bands; |
780 | 1.83k | WORD32 core_frame_size = ptr_header_data->core_frame_size; |
781 | | |
782 | 1.83k | memcpy(&ptr_sbr_dec->core_sample_buf[core_frame_size], |
783 | 1.83k | &ptr_sbr_dec->time_sample_buf[core_frame_size - frame_move], |
784 | 1.83k | frame_move * sizeof(FLOAT32)); |
785 | | |
786 | 1.83k | memmove(&ptr_sbr_dec->time_sample_buf[frame_move], &ptr_sbr_dec->time_sample_buf[0], |
787 | 1.83k | (core_frame_size - frame_move)); |
788 | | |
789 | 1.83k | memcpy(&ptr_sbr_dec->time_sample_buf[0], &ptr_sbr_dec->core_sample_buf[0], |
790 | 1.83k | frame_move * sizeof(FLOAT32)); |
791 | | |
792 | 1.83k | memcpy(&ptr_sbr_dec->core_sample_buf[0], &ptr_sbr_dec->core_sample_buf[core_frame_size], |
793 | 1.83k | frame_move * sizeof(FLOAT32)); |
794 | 1.83k | } |
795 | 380k | if ((audio_object_type == AOT_AAC_LC) && (heaac_mps_present == 1) && |
796 | 380k | !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 | 380k | if ((audio_object_type != AOT_ER_AAC_ELD) && |
817 | 380k | (audio_object_type != AOT_ER_AAC_LD) && |
818 | 380k | ptr_header_data->enh_sbr) { |
819 | 320k | WORD32 codec_x_delay = 0; |
820 | | |
821 | 320k | if (hbe_flag || !usac_flag) { |
822 | 233k | codec_x_delay = esbr_hbe_delay_offsets; |
823 | 233k | } |
824 | 320k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
825 | 30.9k | codec_x_delay = 2 * codec_x_delay; |
826 | 30.9k | } |
827 | | /* fixed decoder delay for bitstreams with SBR 4:1 and stereoConfigIndex 3 |
828 | | */ |
829 | 320k | if (ptr_header_data->num_time_slots != 15) { |
830 | 320k | if (mps_sbr_flag) op_delay = MPS_SBR_DELAY; |
831 | 320k | } else { |
832 | 39 | if (mps_sbr_flag) op_delay = MPS_SBR_DELAY_960; |
833 | 39 | } |
834 | | |
835 | 320k | { |
836 | 320k | memmove( |
837 | 320k | &ptr_sbr_dec->qmf_buf_real[0][0], |
838 | 320k | &ptr_sbr_dec |
839 | 320k | ->qmf_buf_real[ptr_sbr_dec->str_codec_qmf_bank.num_time_slots][0], |
840 | 320k | (op_delay + SBR_HF_ADJ_OFFSET + codec_x_delay) * sizeof(FLOAT32) * 64); |
841 | | |
842 | 320k | memmove( |
843 | 320k | &ptr_sbr_dec->qmf_buf_imag[0][0], |
844 | 320k | &ptr_sbr_dec |
845 | 320k | ->qmf_buf_imag[ptr_sbr_dec->str_codec_qmf_bank.num_time_slots][0], |
846 | 320k | (op_delay + SBR_HF_ADJ_OFFSET + codec_x_delay) * sizeof(FLOAT32) * 64); |
847 | | |
848 | 320k | memmove(&ptr_sbr_dec->sbr_qmf_out_real[0][0], |
849 | 320k | &ptr_sbr_dec->sbr_qmf_out_real[ptr_sbr_dec->str_codec_qmf_bank |
850 | 320k | .num_time_slots][0], |
851 | 320k | (op_delay + SBR_HF_ADJ_OFFSET) * sizeof(FLOAT32) * 64); |
852 | | |
853 | 320k | memmove(&ptr_sbr_dec->sbr_qmf_out_imag[0][0], |
854 | 320k | &ptr_sbr_dec->sbr_qmf_out_imag[ptr_sbr_dec->str_codec_qmf_bank |
855 | 320k | .num_time_slots][0], |
856 | 320k | (op_delay + SBR_HF_ADJ_OFFSET) * sizeof(FLOAT32) * 64); |
857 | | |
858 | 320k | if (hbe_flag) { |
859 | 233k | memmove(&ptr_sbr_dec->ph_vocod_qmf_real[0][0], |
860 | 233k | &ptr_sbr_dec->ph_vocod_qmf_real[ptr_sbr_dec->str_codec_qmf_bank |
861 | 233k | .num_time_slots][0], |
862 | 233k | 64 * sizeof(FLOAT32) * (op_delay + SBR_HF_ADJ_OFFSET)); |
863 | | |
864 | 233k | memmove(ptr_sbr_dec->ph_vocod_qmf_imag, |
865 | 233k | ptr_sbr_dec->ph_vocod_qmf_imag + |
866 | 233k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
867 | 233k | 64 * sizeof(FLOAT32) * (op_delay + SBR_HF_ADJ_OFFSET)); |
868 | 233k | if (!usac_flag) { |
869 | 22.0k | WORD32 qmf_sb_prev = ptr_header_data->pstr_freq_band_data->qmf_sb_prev; |
870 | 154k | for (i = SBR_HF_ADJ_OFFSET; i < op_delay + SBR_HF_ADJ_OFFSET; ++i) { |
871 | 132k | memset(&ptr_sbr_dec->qmf_buf_real[i][qmf_sb_prev], 0, (64 - qmf_sb_prev)); |
872 | 132k | memset(&ptr_sbr_dec->qmf_buf_imag[i][qmf_sb_prev], 0, (64 - qmf_sb_prev)); |
873 | 132k | } |
874 | 22.0k | } |
875 | 233k | } |
876 | 320k | } |
877 | 320k | ixheaacd_esbr_analysis_filt_block( |
878 | 320k | ptr_sbr_dec, sbr_tables_ptr, |
879 | 320k | op_delay + codec_x_delay + SBR_HF_ADJ_OFFSET); |
880 | | |
881 | 320k | if (hbe_flag && apply_processing) { |
882 | 212k | 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 | 212k | } else { |
898 | 212k | WORD32 err_code = ixheaacd_qmf_hbe_apply( |
899 | 212k | ptr_sbr_dec->p_hbe_txposer, |
900 | 212k | ptr_sbr_dec->qmf_buf_real + (op_delay + SBR_HF_ADJ_OFFSET) + |
901 | 212k | esbr_hbe_delay_offsets, |
902 | 212k | ptr_sbr_dec->qmf_buf_imag + (op_delay + SBR_HF_ADJ_OFFSET) + |
903 | 212k | esbr_hbe_delay_offsets, |
904 | 212k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
905 | 212k | ptr_sbr_dec->ph_vocod_qmf_real + (op_delay + SBR_HF_ADJ_OFFSET), |
906 | 212k | ptr_sbr_dec->ph_vocod_qmf_imag + (op_delay + SBR_HF_ADJ_OFFSET), |
907 | 212k | ptr_frame_data->pitch_in_bins, ptr_header_data); |
908 | 212k | if (err_code) return err_code; |
909 | | |
910 | 212k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
911 | 29.9k | ixheaacd_hbe_repl_spec( |
912 | 29.9k | &ptr_sbr_dec->p_hbe_txposer->x_over_qmf[0], |
913 | 29.9k | ptr_sbr_dec->ph_vocod_qmf_real + (op_delay + SBR_HF_ADJ_OFFSET), |
914 | 29.9k | ptr_sbr_dec->ph_vocod_qmf_imag + (op_delay + SBR_HF_ADJ_OFFSET), |
915 | 29.9k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
916 | 29.9k | ptr_sbr_dec->p_hbe_txposer->max_stretch); |
917 | 29.9k | } |
918 | 212k | } |
919 | 212k | } |
920 | 320k | if (!mps_sbr_flag && apply_processing) { |
921 | 222k | err_code = ixheaacd_generate_hf(ptr_sbr_dec->qmf_buf_real + (SBR_HF_ADJ_OFFSET), |
922 | 222k | ptr_sbr_dec->qmf_buf_imag + (SBR_HF_ADJ_OFFSET), |
923 | 222k | ptr_sbr_dec->ph_vocod_qmf_real + (SBR_HF_ADJ_OFFSET), |
924 | 222k | ptr_sbr_dec->ph_vocod_qmf_imag + (SBR_HF_ADJ_OFFSET), |
925 | 222k | ptr_sbr_dec->sbr_qmf_out_real + (SBR_HF_ADJ_OFFSET), |
926 | 222k | ptr_sbr_dec->sbr_qmf_out_imag + (SBR_HF_ADJ_OFFSET), |
927 | 222k | ptr_frame_data, ptr_header_data, ldmps_present, |
928 | 222k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, ec_flag); |
929 | 222k | if (err_code) return err_code; |
930 | | |
931 | 222k | ptr_pvc_data->pvc_rate = ptr_header_data->upsamp_fac; |
932 | | |
933 | 222k | if (sbr_mode == PVC_SBR) { |
934 | 104k | ixheaacd_qmf_enrg_calc(ptr_sbr_dec, upsample_ratio_idx, low_pow_flag); |
935 | 104k | if (ec_flag) { |
936 | 0 | ptr_pvc_data->pvc_mode = 1; |
937 | 0 | } |
938 | 104k | err_code = ixheaacd_pvc_process( |
939 | 104k | ptr_pvc_data, ptr_header_data->pstr_freq_band_data->sub_band_start, |
940 | 104k | ptr_frame_data->str_pvc_frame_info.border_vec[0], |
941 | 104k | &pvc_qmf_enrg_arr[0], &pvc_dec_out_buf[0]); |
942 | | |
943 | 104k | if (err_code) return err_code; |
944 | | |
945 | 104k | ptr_pvc_data->prev_pvc_flg = 1; |
946 | 117k | } else { |
947 | 117k | memset(pvc_dec_out_buf, 0, 1024 * sizeof(FLOAT32)); |
948 | 117k | ptr_pvc_data->prev_pvc_flg = 0; |
949 | 117k | } |
950 | | |
951 | 222k | ptr_pvc_data->prev_first_bnd_idx = |
952 | 222k | ptr_header_data->pstr_freq_band_data->sub_band_start; |
953 | 222k | ptr_pvc_data->prev_pvc_rate = ptr_pvc_data->pvc_rate; |
954 | | |
955 | 222k | ptr_frame_data->pstr_sbr_header = ptr_header_data; |
956 | 222k | err_code = ixheaacd_sbr_env_calc( |
957 | 222k | ptr_frame_data, ptr_sbr_dec->sbr_qmf_out_real + (SBR_HF_ADJ_OFFSET), |
958 | 222k | ptr_sbr_dec->sbr_qmf_out_imag + (SBR_HF_ADJ_OFFSET), |
959 | 222k | ptr_sbr_dec->qmf_buf_real + (SBR_HF_ADJ_OFFSET), |
960 | 222k | ptr_sbr_dec->qmf_buf_imag + (SBR_HF_ADJ_OFFSET), |
961 | 222k | (ptr_header_data->hbe_flag == 0) ? NULL : ptr_sbr_dec->p_hbe_txposer->x_over_qmf, |
962 | 222k | ptr_sbr_dec->scratch_buff, pvc_dec_out_buf, ldmps_present, ec_flag); |
963 | | |
964 | 222k | if (err_code) return err_code; |
965 | | |
966 | 222k | } else { |
967 | 6.41M | for (i = 0; i < 64; i++) { |
968 | 6.31M | memset(ptr_sbr_dec->sbr_qmf_out_real[i], 0, 64 * sizeof(FLOAT32)); |
969 | 6.31M | memset(ptr_sbr_dec->sbr_qmf_out_imag[i], 0, 64 * sizeof(FLOAT32)); |
970 | 6.31M | } |
971 | 98.7k | } |
972 | | |
973 | 320k | if (!mps_sbr_flag) { |
974 | 240k | ptr_sbr_dec->band_count = |
975 | 240k | ptr_header_data->pstr_freq_band_data->sub_band_end; |
976 | 240k | } else |
977 | 80.5k | ptr_sbr_dec->band_count = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
978 | | |
979 | 320k | ixheaacd_esbr_synthesis_filt_block( |
980 | 320k | ptr_sbr_dec, ptr_header_data, ptr_frame_data, apply_processing, |
981 | 320k | pp_qmf_buf_real, pp_qmf_buf_imag, stereo_config_idx, sbr_tables_ptr, |
982 | 320k | mps_sbr_flag, ch_fac, |
983 | 320k | ((ptr_header_data->channel_mode == PS_STEREO) || ptr_header_data->enh_sbr_ps), |
984 | 320k | 0, ptr_ps_dec, drc_on, drc_sbr_factors); |
985 | | |
986 | 320k | if (ptr_header_data->enh_sbr_ps || ptr_header_data->channel_mode == PS_STEREO) { |
987 | 13.1k | pp_qmf_buf_real = ptr_ps_dec->pp_qmf_buf_real[1]; |
988 | 13.1k | pp_qmf_buf_imag = ptr_ps_dec->pp_qmf_buf_imag[1]; |
989 | 13.1k | ixheaacd_esbr_synthesis_filt_block( |
990 | 13.1k | (ia_sbr_dec_struct *) |
991 | 13.1k | (&(((ia_handle_sbr_dec_inst_struct)self)->pstr_sbr_channel[1]->str_sbr_dec)), |
992 | 13.1k | (ia_sbr_header_data_struct *) |
993 | 13.1k | (&(((ia_handle_sbr_dec_inst_struct)self)->pstr_sbr_header[1])), |
994 | 13.1k | (ia_sbr_frame_info_data_struct *) |
995 | 13.1k | (&(((ia_handle_sbr_dec_inst_struct)self)->frame_buffer[1])), apply_processing, |
996 | 13.1k | pp_qmf_buf_real, pp_qmf_buf_imag, stereo_config_idx, sbr_tables_ptr, |
997 | 13.1k | mps_sbr_flag, ch_fac, |
998 | 13.1k | ((ptr_header_data->channel_mode == PS_STEREO) || ptr_header_data->enh_sbr_ps), |
999 | 13.1k | 1, ptr_ps_dec, drc_on, drc_sbr_factors); |
1000 | 13.1k | } |
1001 | 320k | 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 | 320k | ptr_frame_data->prev_sbr_mode = sbr_mode; |
1007 | | |
1008 | 320k | return 0; |
1009 | 320k | } |
1010 | | |
1011 | 59.2k | if (ldmps_present) { |
1012 | 4.67k | if (ptr_sbr_dec->str_codec_qmf_bank.no_channels > 32) { |
1013 | 46 | if (ec_flag) { |
1014 | 0 | ptr_sbr_dec->str_codec_qmf_bank.no_channels = 32; |
1015 | 46 | } else { |
1016 | 46 | return IA_FATAL_ERROR; |
1017 | 46 | } |
1018 | 46 | } |
1019 | 4.62k | ixheaacd_cplx_anal_qmffilt_32( |
1020 | 4.62k | (WORD32 *)ptr_time_data, &ptr_sbr_dec->str_sbr_scale_fact, |
1021 | 4.62k | &p_arr_qmf_buf_real[op_delay], &p_arr_qmf_buf_imag[op_delay], |
1022 | 4.62k | &ptr_sbr_dec->str_codec_qmf_bank, sbr_tables_ptr->qmf_dec_tables_ptr, |
1023 | 4.62k | ch_fac, 1); |
1024 | 54.5k | } else { |
1025 | 54.5k | ixheaacd_cplx_anal_qmffilt( |
1026 | 54.5k | ptr_time_data, &ptr_sbr_dec->str_sbr_scale_fact, &p_arr_qmf_buf_real[op_delay], |
1027 | 54.5k | &p_arr_qmf_buf_imag[op_delay], &ptr_sbr_dec->str_codec_qmf_bank, |
1028 | 54.5k | sbr_tables_ptr->qmf_dec_tables_ptr, ch_fac, low_pow_flag, audio_object_type); |
1029 | 54.5k | } |
1030 | | |
1031 | 59.2k | if (ldmps_present == 1) { |
1032 | 4.62k | for (j = SBR_HF_ADJ_OFFSET; |
1033 | 77.8k | j < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots + SBR_HF_ADJ_OFFSET; |
1034 | 73.1k | j++) { |
1035 | 4.75M | for (k = 0; k < 64; k++) { |
1036 | 4.68M | WORD32 scale = 7; |
1037 | 4.68M | ptr_sbr_dec->mps_qmf_buf_real[j][k] = 0.0f; |
1038 | 4.68M | ptr_sbr_dec->mps_qmf_buf_imag[j][k] = 0.0f; |
1039 | 4.68M | if (k < ptr_sbr_dec->str_codec_qmf_bank.usb) { |
1040 | 1.79M | ptr_sbr_dec->mps_qmf_buf_real[j][k] += |
1041 | 1.79M | (FLOAT32)(p_arr_qmf_buf_real[j][k] / (FLOAT32)(1 << scale)); |
1042 | 1.79M | ptr_sbr_dec->mps_qmf_buf_imag[j][k] += |
1043 | 1.79M | (FLOAT32)(p_arr_qmf_buf_imag[j][k] / (FLOAT32)(1 << scale)); |
1044 | 1.79M | } |
1045 | 4.68M | } |
1046 | 73.1k | } |
1047 | 4.62k | } |
1048 | | /*ITTIAM : the size of real and img coeff are not same as that of the mps |
1049 | | * analysis.*/ |
1050 | 59.2k | { |
1051 | 59.2k | WORD shift1, shift2; |
1052 | 59.2k | WORD min_shift; |
1053 | 59.2k | WORD shift_over; |
1054 | 59.2k | WORD reserve_ov1, reserve_ov2; |
1055 | 59.2k | WORD reservea[2]; |
1056 | 59.2k | WORD i = 0; |
1057 | 59.2k | WORD usb = ptr_sbr_dec->str_codec_qmf_bank.usb; |
1058 | 59.2k | WORD iter_val = 1; |
1059 | 59.2k | if (audio_object_type == AOT_ER_AAC_ELD || |
1060 | 59.2k | audio_object_type == AOT_ER_AAC_LD) { |
1061 | 59.2k | iter_val = 0; |
1062 | 59.2k | } |
1063 | 59.2k | do { |
1064 | 59.2k | WORD t1 = op_delay; |
1065 | 59.2k | WORD t2 = no_bins + op_delay; |
1066 | 59.2k | if (i) { |
1067 | 0 | t1 = 0; |
1068 | 0 | t2 = op_delay; |
1069 | 0 | } |
1070 | 59.2k | reservea[i] = (*ixheaacd_ixheaacd_expsubbandsamples)( |
1071 | 59.2k | p_arr_qmf_buf_real, p_arr_qmf_buf_imag, 0, usb, t1, t2, low_pow_flag); |
1072 | 59.2k | i++; |
1073 | 59.2k | } while (i <= iter_val); |
1074 | 59.2k | ; |
1075 | | |
1076 | 59.2k | reserve = reservea[0]; |
1077 | 59.2k | if (audio_object_type != AOT_ER_AAC_ELD && |
1078 | 59.2k | audio_object_type != AOT_ER_AAC_LD) |
1079 | 0 | reserve_ov1 = reservea[1]; |
1080 | 59.2k | else |
1081 | 59.2k | reserve_ov1 = reserve; |
1082 | 59.2k | ptr_sbr_dec->max_samp_val = ixheaac_min32(reserve, reserve_ov1); |
1083 | | |
1084 | 59.2k | reserve_ov2 = (*ixheaacd_ixheaacd_expsubbandsamples)( |
1085 | 59.2k | ptr_sbr_dec->str_hf_generator.lpc_filt_states_real, |
1086 | 59.2k | ptr_sbr_dec->str_hf_generator.lpc_filt_states_imag, 0, usb, 0, |
1087 | 59.2k | LPC_ORDER, low_pow_flag); |
1088 | | |
1089 | 59.2k | reserve_ov1 = ixheaac_min32(reserve_ov1, reserve_ov2); |
1090 | | |
1091 | 59.2k | shift1 = ptr_sbr_dec->str_sbr_scale_fact.lb_scale + reserve; |
1092 | | |
1093 | 59.2k | shift2 = ptr_sbr_dec->str_sbr_scale_fact.ov_lb_scale + reserve_ov1; |
1094 | 59.2k | min_shift = ixheaac_min32(shift1, shift2); |
1095 | 59.2k | shift_over = (shift2 - min_shift); |
1096 | 59.2k | reserve -= (shift1 - min_shift); |
1097 | | |
1098 | 59.2k | ptr_sbr_dec->str_sbr_scale_fact.ov_lb_scale += (reserve_ov1 - shift_over); |
1099 | | |
1100 | 59.2k | (*ixheaacd_adjust_scale)(p_arr_qmf_buf_real, p_arr_qmf_buf_imag, 0, usb, 0, |
1101 | 59.2k | op_delay, reserve_ov1 - shift_over, low_pow_flag); |
1102 | | |
1103 | 59.2k | (*ixheaacd_adjust_scale)(p_arr_qmf_buf_real, p_arr_qmf_buf_imag, 0, usb, |
1104 | 59.2k | op_delay, (no_bins + op_delay), reserve, |
1105 | 59.2k | low_pow_flag); |
1106 | | |
1107 | 59.2k | (*ixheaacd_adjust_scale)(ptr_sbr_dec->str_hf_generator.lpc_filt_states_real, |
1108 | 59.2k | ptr_sbr_dec->str_hf_generator.lpc_filt_states_imag, |
1109 | 59.2k | 0, usb, 0, LPC_ORDER, reserve_ov1 - shift_over, |
1110 | 59.2k | low_pow_flag); |
1111 | | |
1112 | 59.2k | ptr_sbr_dec->str_sbr_scale_fact.lb_scale += reserve; |
1113 | | |
1114 | 59.2k | save_lb_scale = ptr_sbr_dec->str_sbr_scale_fact.lb_scale; |
1115 | 59.2k | } |
1116 | | |
1117 | 59.2k | { |
1118 | 59.2k | WORD32 num = no_bins; |
1119 | 59.2k | WORD32 *p_loc_qmf_real = |
1120 | 59.2k | &p_arr_qmf_buf_real[op_delay][NO_ANALYSIS_CHANNELS]; |
1121 | | |
1122 | 59.2k | if (!low_pow_flag) { |
1123 | 59.2k | num = num << 1; |
1124 | 59.2k | } |
1125 | | |
1126 | 59.2k | ixheaacd_clr_subsamples(p_loc_qmf_real, num - 1, (NO_SYN_ANA_CHANNELS)); |
1127 | 59.2k | } |
1128 | | |
1129 | 59.2k | if (apply_processing) { |
1130 | 59.2k | WORD16 degree_alias[NO_SYNTHESIS_CHANNELS]; |
1131 | 59.2k | WORD16 *border_vec = ptr_frame_data->str_frame_info_details.border_vec; |
1132 | | |
1133 | 59.2k | if (low_pow_flag) { |
1134 | 0 | memset(degree_alias, 0, NO_SYNTHESIS_CHANNELS * sizeof(WORD16)); |
1135 | 0 | } |
1136 | | |
1137 | 59.2k | 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 | 59.2k | } else { |
1158 | 59.2k | if (ldmps_present == 1) { |
1159 | 4.62k | err_code = ixheaacd_generate_hf(ptr_sbr_dec->mps_qmf_buf_real + (SBR_HF_ADJ_OFFSET), |
1160 | 4.62k | ptr_sbr_dec->mps_qmf_buf_imag + (SBR_HF_ADJ_OFFSET), |
1161 | 4.62k | ptr_sbr_dec->ph_vocod_qmf_real + (SBR_HF_ADJ_OFFSET), |
1162 | 4.62k | ptr_sbr_dec->ph_vocod_qmf_imag + (SBR_HF_ADJ_OFFSET), |
1163 | 4.62k | ptr_sbr_dec->sbr_qmf_out_real + (SBR_HF_ADJ_OFFSET), |
1164 | 4.62k | ptr_sbr_dec->sbr_qmf_out_imag + (SBR_HF_ADJ_OFFSET), |
1165 | 4.62k | ptr_frame_data, ptr_header_data, ldmps_present, |
1166 | 4.62k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, ec_flag); |
1167 | 4.62k | if (err_code) return err_code; |
1168 | 54.5k | } else { |
1169 | 54.5k | ixheaacd_hf_generator( |
1170 | 54.5k | &ptr_sbr_dec->str_hf_generator, &ptr_sbr_dec->str_sbr_scale_fact, |
1171 | 54.5k | p_arr_qmf_buf_real, p_arr_qmf_buf_imag, ptr_header_data->time_step, |
1172 | 54.5k | border_vec[0], |
1173 | 54.5k | ixheaac_sub16_sat( |
1174 | 54.5k | border_vec[ptr_frame_data->str_frame_info_details.num_env], |
1175 | 54.5k | ptr_header_data->num_time_slots), |
1176 | 54.5k | ptr_header_data->pstr_freq_band_data->num_if_bands, |
1177 | 54.5k | ptr_frame_data->max_qmf_subband_aac, ptr_frame_data->sbr_invf_mode, |
1178 | 54.5k | ptr_frame_data_prev->sbr_invf_mode, ptr_work_buf_core, |
1179 | 54.5k | audio_object_type); |
1180 | 54.5k | } |
1181 | 59.2k | } |
1182 | 59.2k | if (ldmps_present == 1) { |
1183 | 4.62k | ptr_frame_data->pstr_sbr_header = ptr_header_data; |
1184 | 4.62k | err_code = ixheaacd_sbr_env_calc( |
1185 | 4.62k | ptr_frame_data, ptr_sbr_dec->sbr_qmf_out_real + (SBR_HF_ADJ_OFFSET), |
1186 | 4.62k | ptr_sbr_dec->sbr_qmf_out_imag + (SBR_HF_ADJ_OFFSET), |
1187 | 4.62k | ptr_sbr_dec->qmf_buf_real + (SBR_HF_ADJ_OFFSET), |
1188 | 4.62k | ptr_sbr_dec->qmf_buf_imag + (SBR_HF_ADJ_OFFSET), NULL, ptr_sbr_dec->scratch_buff, |
1189 | 4.62k | pvc_dec_out_buf, ldmps_present, ec_flag); |
1190 | | |
1191 | 87.0k | for (j = 0; j < ptr_sbr_dec->str_codec_qmf_bank.num_time_slots + 2; j++) { |
1192 | 3.33M | for (k = ptr_sbr_dec->str_codec_qmf_bank.usb; k < 64; k++) { |
1193 | 3.25M | ptr_sbr_dec->mps_qmf_buf_real[j][k] += |
1194 | 3.25M | ptr_sbr_dec->sbr_qmf_out_real[j][k]; |
1195 | 3.25M | ptr_sbr_dec->mps_qmf_buf_imag[j][k] += |
1196 | 3.25M | ptr_sbr_dec->sbr_qmf_out_imag[j][k]; |
1197 | 3.25M | } |
1198 | 82.4k | } |
1199 | 54.5k | } else { |
1200 | 54.5k | err_code = ixheaacd_calc_sbrenvelope( |
1201 | 54.5k | &ptr_sbr_dec->str_sbr_scale_fact, &ptr_sbr_dec->str_sbr_calc_env, |
1202 | 54.5k | ptr_header_data, ptr_frame_data, ptr_frame_data_prev, |
1203 | 54.5k | p_arr_qmf_buf_real, p_arr_qmf_buf_imag, degree_alias, low_pow_flag, |
1204 | 54.5k | sbr_tables_ptr, pstr_common_tables, |
1205 | 54.5k | ptr_work_buf_core + (LPC_ORDER << (6 + !low_pow_flag)), |
1206 | 54.5k | audio_object_type); |
1207 | 54.5k | if (err_code) return err_code; |
1208 | 54.5k | } |
1209 | | |
1210 | 59.2k | memcpy(ptr_frame_data_prev->sbr_invf_mode, ptr_frame_data->sbr_invf_mode, |
1211 | 59.2k | ptr_header_data->pstr_freq_band_data->num_if_bands * sizeof(WORD32)); |
1212 | | |
1213 | 59.2k | ptr_frame_data_prev->coupling_mode = ptr_frame_data->coupling_mode; |
1214 | 59.2k | ptr_frame_data_prev->max_qmf_subband_aac = |
1215 | 59.2k | ptr_frame_data->max_qmf_subband_aac; |
1216 | 59.2k | ptr_frame_data_prev->end_position = |
1217 | 59.2k | border_vec[ptr_frame_data->str_frame_info_details.num_env]; |
1218 | 59.2k | ptr_frame_data_prev->amp_res = ptr_frame_data->amp_res; |
1219 | 59.2k | } else { |
1220 | 0 | ptr_sbr_dec->str_sbr_scale_fact.hb_scale = save_lb_scale; |
1221 | 0 | } |
1222 | | |
1223 | 59.2k | if (!low_pow_flag) { |
1224 | 177k | for (i = 0; i < LPC_ORDER; i++) { |
1225 | 118k | WORD32 *p_loc_qmf_real = &p_arr_qmf_buf_real[no_bins - LPC_ORDER + i][0]; |
1226 | 118k | WORD32 *p_loc_qmf_imag = &p_arr_qmf_buf_imag[no_bins - LPC_ORDER + i][0]; |
1227 | 118k | WORD32 *plpc_filt_states_real = |
1228 | 118k | &ptr_sbr_dec->str_hf_generator.lpc_filt_states_real[i][0]; |
1229 | 118k | WORD32 *plpc_filt_states_imag = |
1230 | 118k | &ptr_sbr_dec->str_hf_generator.lpc_filt_states_imag[i][0]; |
1231 | | |
1232 | 118k | memcpy(plpc_filt_states_real, p_loc_qmf_real, |
1233 | 118k | sizeof(WORD32) * (ptr_sbr_dec->str_codec_qmf_bank.usb)); |
1234 | 118k | memcpy(plpc_filt_states_imag, p_loc_qmf_imag, |
1235 | 118k | sizeof(WORD32) * (ptr_sbr_dec->str_codec_qmf_bank.usb)); |
1236 | 118k | } |
1237 | 59.2k | } 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 | 59.2k | if (apply_processing && ptr_header_data->channel_mode == PS_STEREO && |
1248 | 59.2k | ((audio_object_type != AOT_ER_AAC_ELD) && |
1249 | 1.77k | (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 | 59.2k | } else { |
1273 | 59.2k | ixheaacd_cplx_synt_qmffilt(p_arr_qmf_buf_real, p_arr_qmf_buf_imag, op_delay, |
1274 | 59.2k | ptr_sbr_dec->p_arr_qmf_buf_real, ptr_sbr_dec->p_arr_qmf_buf_imag, |
1275 | 59.2k | &ptr_sbr_dec->str_sbr_scale_fact, ptr_time_data, |
1276 | 59.2k | &ptr_sbr_dec->str_synthesis_qmf_bank, ptr_ps_dec, |
1277 | 59.2k | 0, low_pow_flag, sbr_tables_ptr, |
1278 | 59.2k | pstr_common_tables, ch_fac, drc_on, |
1279 | 59.2k | drc_sbr_factors, audio_object_type); |
1280 | 59.2k | } |
1281 | | |
1282 | 59.2k | { |
1283 | 59.2k | WORD32 num = op_delay; |
1284 | 59.2k | 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 | 59.2k | if (!low_pow_flag) { |
1292 | 59.2k | num = num << 1; |
1293 | 59.2k | } |
1294 | | |
1295 | 59.2k | if (ldmps_present == 1) { |
1296 | 4.62k | memmove(&ptr_sbr_dec->mps_qmf_buf_real[0][0], |
1297 | 4.62k | &ptr_sbr_dec->mps_qmf_buf_real[ptr_sbr_dec->str_codec_qmf_bank |
1298 | 4.62k | .num_time_slots][0], |
1299 | 4.62k | SBR_HF_ADJ_OFFSET * sizeof(FLOAT32) * 64); |
1300 | | |
1301 | 4.62k | memmove(&ptr_sbr_dec->mps_qmf_buf_imag[0][0], |
1302 | 4.62k | &ptr_sbr_dec->mps_qmf_buf_imag[ptr_sbr_dec->str_codec_qmf_bank |
1303 | 4.62k | .num_time_slots][0], |
1304 | 4.62k | SBR_HF_ADJ_OFFSET * sizeof(FLOAT32) * 64); |
1305 | 4.62k | } |
1306 | 59.2k | } |
1307 | | |
1308 | 59.2k | ptr_sbr_dec->str_sbr_scale_fact.ov_lb_scale = save_lb_scale; |
1309 | 59.2k | return 0; |
1310 | 59.2k | } |
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 | 27.0k | ia_sbr_tables_struct *ptr_sbr_tables, WORD ch_fac) { |
1317 | 27.0k | WORD32 i; |
1318 | 27.0k | WORD32 op_delay; |
1319 | | |
1320 | 27.0k | WORD32 codec_x_delay = 0; |
1321 | | |
1322 | 27.0k | FLOAT32 **pp_qmf_buf_real = ptr_sbr_dec->pp_qmf_buf_real; |
1323 | 27.0k | FLOAT32 **pp_qmf_buf_imag = ptr_sbr_dec->pp_qmf_buf_imag; |
1324 | | |
1325 | 27.0k | WORD32 upsample_ratio_idx = ptr_header_data->sbr_ratio_idx; |
1326 | | |
1327 | 27.0k | WORD32 mps_sbr_flag = ptr_frame_data->mps_sbr_flag; |
1328 | 27.0k | WORD32 stereo_config_idx = ptr_frame_data->stereo_config_idx; |
1329 | 27.0k | WORD32 hbe_flag = ptr_header_data->hbe_flag; |
1330 | 27.0k | WORD32 sbr_mode = ptr_frame_data->sbr_mode; |
1331 | | |
1332 | 27.0k | op_delay = 6; |
1333 | 27.0k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
1334 | 15.7k | op_delay = 2 * 6; |
1335 | 15.7k | } |
1336 | | |
1337 | 27.0k | ptr_sbr_dec->str_sbr_scale_fact.lb_scale = 0; |
1338 | 27.0k | { |
1339 | 27.0k | if (hbe_flag) { |
1340 | 18.2k | codec_x_delay = 32; |
1341 | 18.2k | } |
1342 | 27.0k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
1343 | 15.7k | codec_x_delay = 2 * codec_x_delay; |
1344 | 15.7k | } |
1345 | | |
1346 | 27.0k | memmove( |
1347 | 27.0k | &ptr_sbr_dec->qmf_buf_real[0][0], |
1348 | 27.0k | &ptr_sbr_dec |
1349 | 27.0k | ->qmf_buf_real[ptr_sbr_dec->str_codec_qmf_bank.num_time_slots][0], |
1350 | 27.0k | (op_delay + SBR_HF_ADJ_OFFSET + codec_x_delay) * sizeof(FLOAT32) * 64); |
1351 | 27.0k | memmove( |
1352 | 27.0k | &ptr_sbr_dec->qmf_buf_imag[0][0], |
1353 | 27.0k | &ptr_sbr_dec |
1354 | 27.0k | ->qmf_buf_imag[ptr_sbr_dec->str_codec_qmf_bank.num_time_slots][0], |
1355 | 27.0k | (op_delay + SBR_HF_ADJ_OFFSET + codec_x_delay) * sizeof(FLOAT32) * 64); |
1356 | | |
1357 | 27.0k | memmove(&ptr_sbr_dec->sbr_qmf_out_real[0][0], |
1358 | 27.0k | &ptr_sbr_dec->sbr_qmf_out_real[ptr_sbr_dec->str_codec_qmf_bank |
1359 | 27.0k | .num_time_slots][0], |
1360 | 27.0k | (op_delay + SBR_HF_ADJ_OFFSET) * sizeof(FLOAT32) * 64); |
1361 | 27.0k | memmove(&ptr_sbr_dec->sbr_qmf_out_imag[0][0], |
1362 | 27.0k | &ptr_sbr_dec->sbr_qmf_out_imag[ptr_sbr_dec->str_codec_qmf_bank |
1363 | 27.0k | .num_time_slots][0], |
1364 | 27.0k | (op_delay + SBR_HF_ADJ_OFFSET) * sizeof(FLOAT32) * 64); |
1365 | | |
1366 | 27.0k | if (hbe_flag) { |
1367 | 18.2k | memmove(&ptr_sbr_dec->ph_vocod_qmf_real[0][0], |
1368 | 18.2k | &ptr_sbr_dec->ph_vocod_qmf_real[ptr_sbr_dec->str_codec_qmf_bank |
1369 | 18.2k | .num_time_slots][0], |
1370 | 18.2k | 64 * sizeof(FLOAT32) * (op_delay + SBR_HF_ADJ_OFFSET)); |
1371 | 18.2k | memmove(ptr_sbr_dec->ph_vocod_qmf_imag, |
1372 | 18.2k | ptr_sbr_dec->ph_vocod_qmf_imag + |
1373 | 18.2k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
1374 | 18.2k | 64 * sizeof(FLOAT32) * (op_delay + SBR_HF_ADJ_OFFSET)); |
1375 | 18.2k | } |
1376 | 27.0k | } |
1377 | | |
1378 | 27.0k | ixheaacd_esbr_analysis_filt_block( |
1379 | 27.0k | ptr_sbr_dec, ptr_sbr_tables, |
1380 | 27.0k | op_delay + codec_x_delay + SBR_HF_ADJ_OFFSET); |
1381 | | |
1382 | 27.0k | if (hbe_flag) { |
1383 | 18.2k | WORD32 err = ixheaacd_qmf_hbe_apply( |
1384 | 18.2k | ptr_sbr_dec->p_hbe_txposer, |
1385 | 18.2k | ptr_sbr_dec->qmf_buf_real + (op_delay + SBR_HF_ADJ_OFFSET) + |
1386 | 18.2k | ESBR_HBE_DELAY_OFFSET, |
1387 | 18.2k | ptr_sbr_dec->qmf_buf_imag + (op_delay + SBR_HF_ADJ_OFFSET) + |
1388 | 18.2k | ESBR_HBE_DELAY_OFFSET, |
1389 | 18.2k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
1390 | 18.2k | ptr_sbr_dec->ph_vocod_qmf_real + (op_delay + SBR_HF_ADJ_OFFSET), |
1391 | 18.2k | ptr_sbr_dec->ph_vocod_qmf_imag + (op_delay + SBR_HF_ADJ_OFFSET), |
1392 | 18.2k | ptr_frame_data->pitch_in_bins, ptr_header_data); |
1393 | 18.2k | if (err) return err; |
1394 | | |
1395 | 18.2k | if (upsample_ratio_idx == SBR_UPSAMPLE_IDX_4_1) { |
1396 | 15.7k | ixheaacd_hbe_repl_spec( |
1397 | 15.7k | &ptr_sbr_dec->p_hbe_txposer->x_over_qmf[0], |
1398 | 15.7k | ptr_sbr_dec->ph_vocod_qmf_real + (op_delay + SBR_HF_ADJ_OFFSET), |
1399 | 15.7k | ptr_sbr_dec->ph_vocod_qmf_imag + (op_delay + SBR_HF_ADJ_OFFSET), |
1400 | 15.7k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, |
1401 | 15.7k | ptr_sbr_dec->p_hbe_txposer->max_stretch); |
1402 | 15.7k | } |
1403 | 18.2k | } |
1404 | 27.0k | ixheaacd_qmf_enrg_calc(ptr_sbr_dec, upsample_ratio_idx, low_pow_flag); |
1405 | | |
1406 | 1.75M | for (i = 0; i < 64; i++) { |
1407 | 1.72M | memset(ptr_sbr_dec->sbr_qmf_out_real[i], 0, 64 * sizeof(FLOAT32)); |
1408 | 1.72M | memset(ptr_sbr_dec->sbr_qmf_out_imag[i], 0, 64 * sizeof(FLOAT32)); |
1409 | 1.72M | } |
1410 | | |
1411 | 27.0k | ptr_sbr_dec->band_count = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
1412 | | |
1413 | 27.0k | ixheaacd_esbr_synthesis_filt_block( |
1414 | 27.0k | ptr_sbr_dec, ptr_header_data, ptr_frame_data, apply_processing, |
1415 | 27.0k | pp_qmf_buf_real, pp_qmf_buf_imag, stereo_config_idx, ptr_sbr_tables, |
1416 | 27.0k | mps_sbr_flag, ch_fac, 0, 0, NULL, 0, NULL); |
1417 | | |
1418 | 27.0k | ptr_frame_data->prev_sbr_mode = sbr_mode; |
1419 | 27.0k | return 0; |
1420 | 27.0k | } |
1421 | | |
1422 | | WORD32 ixheaacd_sbr_dec_from_mps(FLOAT32 *p_mps_qmf_output, VOID *p_sbr_dec, VOID *p_sbr_frame, |
1423 | 177k | VOID *p_sbr_header, WORD32 ec_flag) { |
1424 | 177k | WORD32 i, k; |
1425 | 177k | ia_sbr_frame_info_data_struct *ptr_frame_data = |
1426 | 177k | (ia_sbr_frame_info_data_struct *)p_sbr_frame; |
1427 | 177k | ia_sbr_header_data_struct *ptr_header_data = |
1428 | 177k | (ia_sbr_header_data_struct *)p_sbr_header; |
1429 | 177k | ia_sbr_dec_struct *ptr_sbr_dec = (ia_sbr_dec_struct *)p_sbr_dec; |
1430 | 177k | ia_frame_info_struct *p_frame_info = &ptr_frame_data->str_frame_info_details; |
1431 | 177k | WORD32 no_bins; |
1432 | 177k | WORD32 upsample_ratio_idx = ptr_header_data->sbr_ratio_idx; |
1433 | 177k | WORD32 op_delay = 6 + SBR_HF_ADJ_OFFSET; |
1434 | 177k | WORD32 num_anal_bands = 40; |
1435 | 177k | WORD32 mps_sbr_flag = ptr_frame_data->mps_sbr_flag; |
1436 | 177k | WORD32 err = 0; |
1437 | | |
1438 | 177k | if (ptr_header_data->is_usf_4) { |
1439 | 44.3k | op_delay += 6; |
1440 | 44.3k | } |
1441 | | |
1442 | 177k | num_anal_bands = num_anal_bands - (upsample_ratio_idx << 3); |
1443 | | |
1444 | 177k | if (!mps_sbr_flag) { |
1445 | 97.2k | return 0; |
1446 | 97.2k | } else { |
1447 | 80.4k | ptr_frame_data->cov_count = ptr_sbr_dec->str_codec_qmf_bank.no_channels; |
1448 | 80.4k | } |
1449 | | |
1450 | 80.4k | no_bins = ptr_header_data->output_framesize / 64; |
1451 | | |
1452 | 3.07M | for (i = 0; i < no_bins; i++) { |
1453 | 2.98M | FLOAT32 *p_loc_mps_qmf_output = |
1454 | 2.98M | p_mps_qmf_output + i * (MAX_NUM_QMF_BANDS_ESBR * 2); |
1455 | 58.7M | for (k = 0; k < ptr_header_data->pstr_freq_band_data->sub_band_start; k++) { |
1456 | 55.7M | ptr_sbr_dec->mps_qmf_buf_real[op_delay + i][k] = *p_loc_mps_qmf_output++; |
1457 | 55.7M | ptr_sbr_dec->mps_qmf_buf_imag[op_delay + i][k] = *p_loc_mps_qmf_output++; |
1458 | | |
1459 | 55.7M | ptr_sbr_dec->mps_sbr_qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k] = |
1460 | 55.7M | ptr_sbr_dec->qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k]; |
1461 | 55.7M | ptr_sbr_dec->mps_sbr_qmf_buf_imag[SBR_HF_ADJ_OFFSET + i][k] = |
1462 | 55.7M | ptr_sbr_dec->qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k]; |
1463 | 55.7M | } |
1464 | 2.98M | } |
1465 | | |
1466 | 80.4k | if (ptr_frame_data->reset_flag) { |
1467 | 15.8k | WORD32 l; |
1468 | 15.8k | WORD32 start_band = ptr_header_data->pstr_freq_band_data->qmf_sb_prev; |
1469 | 15.8k | WORD32 end_band = num_anal_bands; |
1470 | 15.8k | WORD32 start_slot = |
1471 | 15.8k | SBR_HF_ADJ_OFFSET + ptr_frame_data->rate * p_frame_info->border_vec[0]; |
1472 | | |
1473 | 126k | for (l = start_slot; l < op_delay; l++) { |
1474 | 1.01M | for (k = start_band; k < end_band; k++) { |
1475 | 907k | ptr_sbr_dec->mps_qmf_buf_real[l][k] = 0.0; |
1476 | 907k | ptr_sbr_dec->mps_qmf_buf_imag[l][k] = 0.0; |
1477 | 907k | } |
1478 | 110k | } |
1479 | | |
1480 | 47.4k | for (l = 0; l < SBR_HF_ADJ_OFFSET; l++) { |
1481 | 293k | 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 | 31.6k | } |
1486 | 15.8k | } |
1487 | 80.4k | ptr_header_data->pstr_freq_band_data->qmf_sb_prev = |
1488 | 80.4k | ptr_header_data->pstr_freq_band_data->sub_band_start; |
1489 | | |
1490 | 80.4k | err = ixheaacd_generate_hf(ptr_sbr_dec->mps_qmf_buf_real + SBR_HF_ADJ_OFFSET, |
1491 | 80.4k | ptr_sbr_dec->mps_qmf_buf_imag + SBR_HF_ADJ_OFFSET, NULL, NULL, |
1492 | 80.4k | ptr_sbr_dec->mps_sbr_qmf_buf_real + SBR_HF_ADJ_OFFSET, |
1493 | 80.4k | ptr_sbr_dec->mps_sbr_qmf_buf_imag + SBR_HF_ADJ_OFFSET, |
1494 | 80.4k | ptr_frame_data, ptr_header_data, 0, |
1495 | 80.4k | ptr_sbr_dec->str_codec_qmf_bank.num_time_slots, ec_flag); |
1496 | 80.4k | if (err) return err; |
1497 | | |
1498 | 80.4k | ptr_frame_data->pstr_sbr_header = ptr_header_data; |
1499 | 80.4k | ptr_frame_data->sbr_mode = ORIG_SBR; |
1500 | 80.4k | ptr_frame_data->prev_sbr_mode = ORIG_SBR; |
1501 | 80.4k | err = ixheaacd_sbr_env_calc( |
1502 | 80.4k | ptr_frame_data, ptr_sbr_dec->mps_sbr_qmf_buf_real + SBR_HF_ADJ_OFFSET, |
1503 | 80.4k | ptr_sbr_dec->mps_sbr_qmf_buf_imag + SBR_HF_ADJ_OFFSET, |
1504 | 80.4k | ptr_sbr_dec->mps_qmf_buf_real + SBR_HF_ADJ_OFFSET, |
1505 | 80.4k | ptr_sbr_dec->mps_qmf_buf_imag + SBR_HF_ADJ_OFFSET, |
1506 | 80.4k | (ptr_header_data->hbe_flag == 0) ? NULL : ptr_sbr_dec->p_hbe_txposer->x_over_qmf, |
1507 | 80.4k | ptr_sbr_dec->scratch_buff, NULL, 0, ec_flag); |
1508 | | |
1509 | 80.4k | if (err) return err; |
1510 | 3.06M | for (i = 0; i < no_bins; i++) { |
1511 | 2.98M | FLOAT32 *p_loc_mps_qmf_output = |
1512 | 2.98M | p_mps_qmf_output + i * (MAX_NUM_QMF_BANDS_ESBR * 2); |
1513 | 58.7M | for (k = 0; k < ptr_header_data->pstr_freq_band_data->sub_band_start; k++) { |
1514 | 55.7M | *p_loc_mps_qmf_output++ = |
1515 | 55.7M | ptr_sbr_dec->mps_qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k]; |
1516 | 55.7M | *p_loc_mps_qmf_output++ = |
1517 | 55.7M | ptr_sbr_dec->mps_qmf_buf_imag[SBR_HF_ADJ_OFFSET + i][k]; |
1518 | 55.7M | } |
1519 | 138M | for (k = ptr_header_data->pstr_freq_band_data->sub_band_start; k < 64; |
1520 | 135M | k++) { |
1521 | 135M | *p_loc_mps_qmf_output++ = |
1522 | 135M | ptr_sbr_dec->mps_sbr_qmf_buf_real[SBR_HF_ADJ_OFFSET + i][k]; |
1523 | 135M | *p_loc_mps_qmf_output++ = |
1524 | 135M | ptr_sbr_dec->mps_sbr_qmf_buf_imag[SBR_HF_ADJ_OFFSET + i][k]; |
1525 | 135M | } |
1526 | 2.98M | } |
1527 | | |
1528 | 801k | for (i = 0; i < op_delay; i++) { |
1529 | 721k | memmove(ptr_sbr_dec->mps_qmf_buf_real[i], |
1530 | 721k | ptr_sbr_dec->mps_qmf_buf_real[no_bins + i], 64 * sizeof(FLOAT32)); |
1531 | | |
1532 | 721k | memmove(ptr_sbr_dec->mps_qmf_buf_imag[i], |
1533 | 721k | ptr_sbr_dec->mps_qmf_buf_imag[no_bins + i], 64 * sizeof(FLOAT32)); |
1534 | | |
1535 | 721k | memmove(ptr_sbr_dec->mps_sbr_qmf_buf_real[i], |
1536 | 721k | ptr_sbr_dec->mps_sbr_qmf_buf_real[no_bins + i], |
1537 | 721k | 64 * sizeof(FLOAT32)); |
1538 | | |
1539 | 721k | memmove(ptr_sbr_dec->mps_sbr_qmf_buf_imag[i], |
1540 | 721k | ptr_sbr_dec->mps_sbr_qmf_buf_imag[no_bins + i], |
1541 | 721k | 64 * sizeof(FLOAT32)); |
1542 | 721k | } |
1543 | | |
1544 | 80.4k | ptr_frame_data->reset_flag = 0; |
1545 | 80.4k | return err; |
1546 | 80.4k | } |