Coverage Report

Created: 2026-02-07 06:17

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libxaac/encoder/ixheaace_mps_enc.c
Line
Count
Source
1
/******************************************************************************
2
 *                                                                            *
3
 * Copyright (C) 2023 The Android Open Source Project
4
 *
5
 * Licensed under the Apache License, Version 2.0 (the "License");
6
 * you may not use this file except in compliance with the License.
7
 * You may obtain a copy of the License at:
8
 *
9
 * http://www.apache.org/licenses/LICENSE-2.0
10
 *
11
 * Unless required by applicable law or agreed to in writing, software
12
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 * See the License for the specific language governing permissions and
15
 * limitations under the License.
16
 *
17
 *****************************************************************************
18
 * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19
 */
20
21
#include <stdlib.h>
22
#include <string.h>
23
#include <math.h>
24
#include "ixheaac_type_def.h"
25
#include "impd_drc_common_enc.h"
26
#include "impd_drc_uni_drc.h"
27
#include "impd_drc_tables.h"
28
#include "impd_drc_api.h"
29
#include "ixheaace_api.h"
30
#include "ixheaac_error_standards.h"
31
#include "ixheaace_error_codes.h"
32
#include "ixheaace_mps_common_fix.h"
33
#include "ixheaace_mps_defines.h"
34
#include "ixheaace_mps_common_define.h"
35
#include "ixheaac_constants.h"
36
#include "ixheaace_bitbuffer.h"
37
#include "ixheaace_sbr_def.h"
38
#include "ixheaace_mps_buf.h"
39
#include "ixheaace_mps_lib.h"
40
#include "ixheaace_mps_main_structure.h"
41
#include "ixheaace_mps_bitstream.h"
42
#include "ixheaace_mps_onset_detect.h"
43
#include "ixheaace_mps_filter.h"
44
#include "ixheaace_mps_param_extract.h"
45
#include "ixheaace_mps_static_gain.h"
46
47
#include "ixheaace_mps_dmx_tdom_enh.h"
48
#include "ixheaace_mps_tools_rom.h"
49
#include "ixheaace_mps_qmf.h"
50
#include "ixheaace_mps_struct_def.h"
51
#include "ixheaace_mps_sac_polyphase.h"
52
#include "ixheaace_mps_sac_hybfilter.h"
53
#include "ixheaace_mps_spatial_bitstream.h"
54
#include "ixheaace_mps_tree.h"
55
#include "ixheaace_mps_rom.h"
56
#include "ixheaace_mps_delay.h"
57
#include "ixheaace_mps_frame_windowing.h"
58
#include "ixheaace_mps_structure.h"
59
#include "ixheaace_mps_memory.h"
60
#include "ixheaace_mps_enc.h"
61
#include "ixheaac_basic_ops32.h"
62
#include "ixheaac_basic_ops40.h"
63
#include "ixheaac_basic_ops.h"
64
65
2.77k
static UWORD8 ixheaace_mps_212_space_get_num_qmf_bands(const UWORD32 num_sample_rate) {
66
2.77k
  UWORD8 num_qmf_bands = 0;
67
2.77k
  if (num_sample_rate < 27713)
68
0
    num_qmf_bands = 32;
69
2.77k
  else if (num_sample_rate < 55426)
70
2.77k
    num_qmf_bands = 64;
71
72
2.77k
  return num_qmf_bands;
73
2.77k
}
74
75
static VOID ixheaace_mps_212_space_tree_open(ixheaace_mps_pstr_space_tree *pstr_ph_space_tree,
76
1.40k
                                             ixheaace_mps_212_memory_struct *pstr_mps_memory) {
77
1.40k
  ixheaace_mps_pstr_space_tree pstr_space_tree = NULL;
78
1.40k
  WORD32 box;
79
80
1.40k
  pstr_space_tree = &pstr_mps_memory->spacce_tree;
81
82
2.81k
  for (box = 0; box < IXHEAACE_MPS_MAX_NUM_BOXES; box++) {
83
1.40k
    ixheaace_mps_pstr_tto_box pstr_tto_box = NULL;
84
1.40k
    pstr_tto_box = &pstr_mps_memory->tto_box;
85
86
1.40k
    if (NULL != pstr_space_tree) {
87
1.40k
      pstr_space_tree->pstr_tto_box[box] = pstr_tto_box;
88
1.40k
    }
89
1.40k
  }
90
1.40k
  *pstr_ph_space_tree = pstr_space_tree;
91
1.40k
}
92
93
static VOID ixheaace_mps_212_init_num_param_bands(
94
1.37k
    ixheaace_mps_pstr_space_structure pstr_space_enc, const WORD32 num_param_bands) {
95
1.37k
  WORD32 k = 0;
96
1.37k
  const WORD32 n = sizeof(valid_bands_ld) / sizeof(UWORD8);
97
1.37k
  const UWORD8 *p_bands = valid_bands_ld;
98
99
11.7k
  while (k < n && p_bands[k] != (UWORD8)num_param_bands) ++k;
100
1.37k
  if (k == n) {
101
0
    pstr_space_enc->num_param_bands = IXHEAACE_MPS_SAC_BANDS_INVALID;
102
1.37k
  } else {
103
1.37k
    pstr_space_enc->num_param_bands = num_param_bands;
104
1.37k
  }
105
1.37k
}
106
107
static IA_ERRORCODE ixheaace_mps_212_configure(
108
    ixheaace_mps_pstr_space_structure pstr_space_enc,
109
1.37k
    const ixheaace_mps_pstr_spece_enc_setup pstr_h_set_up) {
110
1.37k
  IA_ERRORCODE error = IA_NO_ERROR;
111
112
1.37k
  pstr_space_enc->num_sample_rate = pstr_h_set_up->sample_rate;
113
1.37k
  pstr_space_enc->num_qmf_bands =
114
1.37k
      ixheaace_mps_212_space_get_num_qmf_bands(pstr_space_enc->num_sample_rate);
115
1.37k
  pstr_space_enc->time_alignment = pstr_h_set_up->time_alignment;
116
1.37k
  pstr_space_enc->quant_mode = pstr_h_set_up->quant_mode;
117
118
1.37k
  pstr_space_enc->use_coarse_quant_cld = pstr_h_set_up->b_use_coarse_quant;
119
1.37k
  pstr_space_enc->use_coarse_quant_cpc = pstr_h_set_up->b_use_coarse_quant;
120
1.37k
  pstr_space_enc->use_frame_keep = (pstr_h_set_up->b_ld_mode == 2);
121
1.37k
  pstr_space_enc->use_coarse_quant_icc = 0;
122
1.37k
  pstr_space_enc->use_coarse_quant_arb_dmx = 0;
123
1.37k
  pstr_space_enc->independency_factor = pstr_h_set_up->independency_factor;
124
1.37k
  pstr_space_enc->independency_count = 0;
125
1.37k
  pstr_space_enc->independency_flag = 1;
126
127
1.37k
  pstr_space_enc->num_hybrid_bands = pstr_space_enc->num_qmf_bands;
128
1.37k
  pstr_space_enc->num_frame_time_slots = pstr_h_set_up->frame_time_slots;
129
1.37k
  ixheaace_mps_212_init_num_param_bands(pstr_space_enc, pstr_h_set_up->num_param_bands);
130
131
1.37k
  return error;
132
1.37k
}
133
134
static WORD32 ixheaace_mps_212_get_analysis_length_time_slots(FLOAT32 *ptr_frame_window_ana,
135
92.6k
                                                              WORD32 num_time_slots) {
136
92.6k
  WORD32 i;
137
1.66M
  for (i = num_time_slots - 1; i >= 0; i--) {
138
1.66M
    if (ptr_frame_window_ana[i] != 0) {
139
92.6k
      break;
140
92.6k
    }
141
1.66M
  }
142
92.6k
  num_time_slots = i + 1;
143
92.6k
  return num_time_slots;
144
92.6k
}
145
146
static WORD32 ixheaace_mps_212_get_analysis_start_time_slot(FLOAT32 *ptr_frame_window_ana,
147
92.6k
                                                            WORD32 num_time_slots) {
148
92.6k
  WORD32 start_time_slot = 0;
149
92.6k
  WORD32 i;
150
1.86M
  for (i = 0; i < num_time_slots; i++) {
151
1.86M
    if (ptr_frame_window_ana[i] != 0) {
152
92.6k
      break;
153
92.6k
    }
154
1.86M
  }
155
92.6k
  start_time_slot = i;
156
92.6k
  return start_time_slot;
157
92.6k
}
158
159
static VOID ixheaace_mps_212_memcpy_flex_pcm(FLOAT32 *const ptr_dst, const WORD32 dst_stride,
160
                                             const FLOAT32 *const ptr_src,
161
0
                                             const WORD32 src_stride, const WORD32 num_samples) {
162
0
  WORD32 i;
163
164
0
  for (i = 0; i < num_samples; i++) {
165
0
    ptr_dst[i * dst_stride] = ptr_src[i * src_stride];
166
0
  }
167
0
}
168
169
static IA_ERRORCODE ixheaace_mps_212_feed_de_inter_pre_scale(
170
    ixheaace_mps_pstr_space_structure pstr_space_enc, FLOAT32 const *const ptr_samples,
171
    FLOAT32 *const ptr_output_samples, WORD32 const num_samples,
172
    UWORD32 const is_input_inter_leaved, UWORD32 const input_buffer_size_per_channel,
173
92.6k
    UWORD32 *const ptr_n_samples_fed) {
174
92.6k
  IA_ERRORCODE error = IA_NO_ERROR;
175
92.6k
  WORD32 ch;
176
92.6k
  const WORD32 num_ch_in = pstr_space_enc->n_input_channels;
177
92.6k
  const WORD32 num_ch_in_with_dmx = num_ch_in;
178
92.6k
  const WORD32 samples_to_feed =
179
92.6k
      MIN(num_samples, pstr_space_enc->n_samples_next - pstr_space_enc->n_samples_valid);
180
92.6k
  const WORD32 num_samples_per_channel = samples_to_feed / num_ch_in_with_dmx;
181
182
92.6k
  if ((samples_to_feed < 0) || (samples_to_feed % num_ch_in_with_dmx != 0) ||
183
92.6k
      (samples_to_feed > num_ch_in_with_dmx * (WORD32)pstr_space_enc->n_frame_length)) {
184
0
    return IA_EXHEAACE_CONFIG_NONFATAL_MPS_INVALID_CONFIG;
185
0
  }
186
92.6k
  const FLOAT32 *p_input_mps;
187
92.6k
  const FLOAT32 *p_input_2_mps;
188
92.6k
  {
189
92.6k
    p_input_mps = ptr_samples;
190
92.6k
    p_input_2_mps = ptr_samples + (pstr_space_enc->n_input_delay * num_ch_in_with_dmx);
191
92.6k
  }
192
278k
  for (ch = 0; ch < num_ch_in; ch++) {
193
185k
    memcpy(&(pstr_space_enc->time_signal_in[ch][0]),
194
185k
           &(pstr_space_enc->time_signal_delay_in[ch][0]),
195
185k
           pstr_space_enc->n_surround_analysis_buffer_delay * sizeof(FLOAT32));
196
197
185k
    if (is_input_inter_leaved) {
198
0
      ixheaace_mps_212_memcpy_flex_pcm(
199
0
          &(pstr_space_enc->time_signal_in[ch][pstr_space_enc->n_surround_analysis_buffer_delay]),
200
0
          1, p_input_mps + ch, num_ch_in_with_dmx, pstr_space_enc->n_input_delay);
201
0
      ixheaace_mps_212_memcpy_flex_pcm(
202
0
          &(pstr_space_enc->time_signal_in[ch][pstr_space_enc->n_surround_analysis_buffer_delay +
203
0
                                               pstr_space_enc->n_input_delay]),
204
0
          1, p_input_2_mps + ch, num_ch_in_with_dmx,
205
0
          num_samples_per_channel - pstr_space_enc->n_input_delay);
206
185k
    } else {
207
185k
      memcpy(
208
185k
          &(pstr_space_enc->time_signal_in[ch][pstr_space_enc->n_surround_analysis_buffer_delay]),
209
185k
          p_input_mps + ch * input_buffer_size_per_channel,
210
185k
          pstr_space_enc->n_input_delay * sizeof(FLOAT32));
211
185k
      memcpy(
212
185k
          &(pstr_space_enc->time_signal_in[ch][pstr_space_enc->n_surround_analysis_buffer_delay +
213
185k
                                               pstr_space_enc->n_input_delay]),
214
185k
          p_input_2_mps + ch * input_buffer_size_per_channel,
215
185k
          (num_samples_per_channel - pstr_space_enc->n_input_delay) * sizeof(FLOAT32));
216
185k
    }
217
218
185k
    memcpy(&(pstr_space_enc->time_signal_delay_in[ch][0]),
219
185k
           &(pstr_space_enc->time_signal_in[ch][pstr_space_enc->n_frame_length]),
220
185k
           pstr_space_enc->n_surround_analysis_buffer_delay * sizeof(FLOAT32));
221
185k
  }
222
223
92.6k
  error = ixheaace_mps_212_apply_enhanced_time_domain_dmx(
224
92.6k
      pstr_space_enc->pstr_enhanced_time_dmx, pstr_space_enc->time_signal_in, ptr_output_samples,
225
92.6k
      pstr_space_enc->n_surround_analysis_buffer_delay);
226
92.6k
  if (error) {
227
0
    return error;
228
0
  }
229
230
92.6k
  pstr_space_enc->n_samples_valid += samples_to_feed;
231
232
92.6k
  *ptr_n_samples_fed = samples_to_feed;
233
92.6k
  return error;
234
92.6k
}
235
236
static IA_ERRORCODE ixheaace_mps_212_init_delay_compensation(
237
1.37k
    ixheaace_mps_pstr_space_structure pstr_space_enc, const WORD32 core_coder_delay, WORD32 aot) {
238
1.37k
  IA_ERRORCODE error = IA_NO_ERROR;
239
1.37k
  WORD32 i;
240
1.37k
  memset(&pstr_space_enc->pstr_delay->delay_config, 0,
241
1.37k
         sizeof(pstr_space_enc->pstr_delay->delay_config));
242
1.37k
  pstr_space_enc->core_coder_delay = core_coder_delay;
243
1.37k
  pstr_space_enc->pstr_delay->delay_config.num_qmf_len = pstr_space_enc->num_qmf_bands;
244
1.37k
  pstr_space_enc->pstr_delay->delay_config.num_frame_len = pstr_space_enc->n_frame_length;
245
1.37k
  pstr_space_enc->pstr_delay->delay_config.num_core_coder_delay = core_coder_delay;
246
1.37k
  pstr_space_enc->pstr_delay->delay_config.num_sac_stream_mux_delay =
247
1.37k
      pstr_space_enc->time_alignment;
248
1.37k
  pstr_space_enc->pstr_delay->delay_config.b_dmx_align = 0;
249
1.37k
  pstr_space_enc->pstr_delay->delay_config.b_minimize_delay = 1;
250
251
1.37k
  ixheaace_mps_212_delay_sub_calculate_buffer_delays(pstr_space_enc->pstr_delay);
252
253
1.37k
  pstr_space_enc->n_bitstream_delay_buffer =
254
1.37k
      pstr_space_enc->pstr_delay->num_bitstream_frame_buffer_size;
255
1.37k
  pstr_space_enc->n_output_buffer_delay = pstr_space_enc->pstr_delay->num_output_audio_buffer;
256
1.37k
  pstr_space_enc->n_surround_analysis_buffer_delay =
257
1.37k
      pstr_space_enc->pstr_delay->num_surround_analysis_buffer;
258
1.37k
  pstr_space_enc->n_bitstream_buffer_read = 0;
259
1.37k
  pstr_space_enc->n_bitstream_buffer_write = pstr_space_enc->n_bitstream_delay_buffer - 1;
260
1.37k
  pstr_space_enc->num_discard_out_frames = pstr_space_enc->pstr_delay->num_discard_out_frames;
261
1.37k
  pstr_space_enc->n_input_delay = pstr_space_enc->pstr_delay->num_dmx_align_buffer;
262
1.37k
  pstr_space_enc->independency_count = 0;
263
1.37k
  pstr_space_enc->independency_flag = 1;
264
265
1.37k
  for (i = 0; i < pstr_space_enc->n_bitstream_delay_buffer - 1; i++) {
266
0
    ixheaace_mps_spatial_frame *pstr_frame_data = NULL;
267
0
    pstr_frame_data = &pstr_space_enc->pstr_bitstream_formatter->frame;
268
0
    pstr_frame_data->bs_independency_flag = 1;
269
0
    pstr_frame_data->framing_info.num_param_sets = 1;
270
0
    pstr_frame_data->framing_info.bs_framing_type = 0;
271
272
0
    error = ixheaace_mps_212_write_spatial_frame(
273
0
        pstr_space_enc->bit_stream_delay_buffer[i], MAX_MPEGS_BYTES,
274
0
        &pstr_space_enc->pn_output_bits[i], pstr_space_enc->pstr_bitstream_formatter, aot);
275
0
    if (error) {
276
0
      return error;
277
0
    }
278
0
  }
279
280
1.37k
  if ((pstr_space_enc->n_input_delay > MAX_DELAY_INPUT) ||
281
1.37k
      (pstr_space_enc->n_output_buffer_delay > MAX_DELAY_OUTPUT) ||
282
1.37k
      (pstr_space_enc->n_surround_analysis_buffer_delay > MAX_DELAY_SURROUND_ANALYSIS) ||
283
1.37k
      (pstr_space_enc->n_bitstream_delay_buffer > MAX_BITSTREAM_DELAY)) {
284
0
    return IA_EXHEAACE_INIT_FATAL_MPS_INIT_FAILED;
285
0
  }
286
1.37k
  return error;
287
1.37k
}
288
289
static IA_ERRORCODE ixheaace_mps_212_fill_spatial_specific_config(
290
    const ixheaace_mps_pstr_space_structure pstr_space_enc,
291
1.37k
    ixheaace_mps_spatial_specific_config *const pstr_h_ssc) {
292
1.37k
  IA_ERRORCODE error = IA_NO_ERROR;
293
294
1.37k
  ixheaace_mps_space_tree_description space_tree_description;
295
1.37k
  WORD32 i;
296
1.37k
  space_tree_description = pstr_space_enc->pstr_space_tree->descr;
297
1.37k
  memset(pstr_h_ssc, 0, sizeof(ixheaace_mps_spatial_specific_config));
298
299
1.37k
  pstr_h_ssc->num_bands = pstr_space_enc->space_tree_setup.num_param_bands;
300
1.37k
  pstr_h_ssc->tree_description.num_ott_boxes = space_tree_description.num_ott_boxes;
301
1.37k
  pstr_h_ssc->tree_description.num_in_chan = space_tree_description.num_in_channels;
302
1.37k
  pstr_h_ssc->tree_description.num_out_chan = space_tree_description.num_out_channels;
303
304
2.74k
  for (i = 0; i < IXHEAACE_MPS_MAX_NUM_BOXES; i++) {
305
1.37k
    pstr_h_ssc->ott_config[i].bs_ott_bands = pstr_h_ssc->num_bands;
306
1.37k
  }
307
1.37k
  pstr_h_ssc->bs_tree_config = IXHEAACE_MPS_TREE_212;
308
1.37k
  pstr_h_ssc->bs_sampling_frequency = pstr_space_enc->num_sample_rate;
309
1.37k
  pstr_h_ssc->bs_frame_length = pstr_space_enc->num_frame_time_slots - 1;
310
1.37k
  pstr_h_ssc->bs_decorr_config = IXHEAACE_MPS_DECORR_QMFSPLIT0;
311
1.37k
  pstr_h_ssc->bs_quant_mode = pstr_space_enc->quant_mode;
312
1.37k
  if (pstr_space_enc->pstr_static_gain->fixed_gain_dmx > IXHEAACE_MPS_MAX_FIXED_GAIN_DMX) {
313
0
    pstr_h_ssc->bs_fixed_gain_dmx = IXHEAACE_MPS_FIXED_GAIN_DMX_INVALID;
314
1.37k
  } else {
315
1.37k
    pstr_h_ssc->bs_fixed_gain_dmx = pstr_space_enc->pstr_static_gain->fixed_gain_dmx;
316
1.37k
  }
317
1.37k
  pstr_h_ssc->bs_env_quant_mode = 0;
318
1.37k
  return error;
319
1.37k
}
320
321
static IA_ERRORCODE ixheaace_mps_212_fill_space_tree_setup(
322
    const ixheaace_mps_pstr_space_structure pstr_space_enc,
323
1.37k
    ixheaace_mps_space_tree_setup *const ptr_space_tree_setup) {
324
1.37k
  IA_ERRORCODE error = IA_NO_ERROR;
325
326
1.37k
  ptr_space_tree_setup->num_param_bands = pstr_space_enc->num_param_bands;
327
1.37k
  ptr_space_tree_setup->use_coarse_quant_tto_cld_flag = pstr_space_enc->use_coarse_quant_cld;
328
1.37k
  ptr_space_tree_setup->use_coarse_quant_tto_icc_flag = pstr_space_enc->use_coarse_quant_icc;
329
1.37k
  ptr_space_tree_setup->quant_mode = pstr_space_enc->quant_mode;
330
1.37k
  ptr_space_tree_setup->num_hybrid_bands_max = pstr_space_enc->num_hybrid_bands;
331
1.37k
  ptr_space_tree_setup->num_channels_in_max = 2;
332
1.37k
  return error;
333
1.37k
}
334
335
static VOID ixheaace_mps_212_get_info(const ixheaace_mps_pstr_space_structure pstr_space_enc,
336
1.37k
                                      ixheaace_mps_space_info *const pstr_space_info) {
337
1.37k
  pstr_space_info->num_sample_rate = pstr_space_enc->num_sample_rate;
338
1.37k
  pstr_space_info->num_samples_frame = pstr_space_enc->n_frame_length;
339
1.37k
  pstr_space_info->num_total_input_channels = pstr_space_enc->n_input_channels;
340
1.37k
  pstr_space_info->dmx_delay = pstr_space_enc->pstr_delay->num_info_dmx_delay;
341
1.37k
  pstr_space_info->codec_delay = pstr_space_enc->pstr_delay->num_info_codec_delay;
342
1.37k
  pstr_space_info->decoder_delay = pstr_space_enc->pstr_delay->num_info_decoder_delay;
343
1.37k
  pstr_space_info->pay_load_delay =
344
1.37k
      pstr_space_enc->pstr_delay->num_bitstream_frame_buffer_size - 1;
345
1.37k
  pstr_space_info->num_discard_out_frames = pstr_space_enc->num_discard_out_frames;
346
1.37k
  pstr_space_info->p_ssc_buf = &pstr_space_enc->ssc_buf;
347
1.37k
}
348
349
static VOID ixheaace_mps_212_duplicate_parameter_set(
350
    const ixheaace_mps_spatial_frame *const pstr_spatial_frame_from, const WORD32 set_from,
351
92.6k
    ixheaace_mps_spatial_frame *const pstr_spatial_frame_to, const WORD32 set_to) {
352
92.6k
  WORD32 box;
353
185k
  for (box = 0; box < IXHEAACE_MPS_MAX_NUM_BOXES; box++) {
354
92.6k
    memcpy(pstr_spatial_frame_to->ott_data.cld[box][set_to],
355
92.6k
           pstr_spatial_frame_from->ott_data.cld[box][set_from],
356
92.6k
           sizeof(pstr_spatial_frame_from->ott_data.cld[0][0]));
357
92.6k
    pstr_spatial_frame_to->cld_lossless_data.bs_xxx_data_mode[box][set_to] =
358
92.6k
        pstr_spatial_frame_from->cld_lossless_data.bs_xxx_data_mode[box][set_from];
359
92.6k
    pstr_spatial_frame_to->cld_lossless_data.bs_data_pair[box][set_to] =
360
92.6k
        pstr_spatial_frame_from->cld_lossless_data.bs_data_pair[box][set_from];
361
92.6k
    pstr_spatial_frame_to->cld_lossless_data.bs_quant_coarse_xxx[box][set_to] =
362
92.6k
        pstr_spatial_frame_from->cld_lossless_data.bs_quant_coarse_xxx[box][set_from];
363
92.6k
    pstr_spatial_frame_to->cld_lossless_data.bs_freq_res_stride_xxx[box][set_to] =
364
92.6k
        pstr_spatial_frame_from->cld_lossless_data.bs_freq_res_stride_xxx[box][set_from];
365
366
92.6k
    memcpy(pstr_spatial_frame_to->ott_data.icc[box][set_to],
367
92.6k
           pstr_spatial_frame_from->ott_data.icc[box][set_from],
368
92.6k
           sizeof(pstr_spatial_frame_from->ott_data.icc[0][0]));
369
92.6k
    pstr_spatial_frame_to->icc_lossless_data.bs_xxx_data_mode[box][set_to] =
370
92.6k
        pstr_spatial_frame_from->icc_lossless_data.bs_xxx_data_mode[box][set_from];
371
92.6k
    pstr_spatial_frame_to->icc_lossless_data.bs_data_pair[box][set_to] =
372
92.6k
        pstr_spatial_frame_from->icc_lossless_data.bs_data_pair[box][set_from];
373
92.6k
    pstr_spatial_frame_to->icc_lossless_data.bs_quant_coarse_xxx[box][set_to] =
374
92.6k
        pstr_spatial_frame_from->icc_lossless_data.bs_quant_coarse_xxx[box][set_from];
375
92.6k
    pstr_spatial_frame_to->icc_lossless_data.bs_freq_res_stride_xxx[box][set_to] =
376
92.6k
        pstr_spatial_frame_from->icc_lossless_data.bs_freq_res_stride_xxx[box][set_from];
377
92.6k
  }
378
92.6k
}
379
380
static IA_ERRORCODE ixheaace_mps_212_encode(
381
    const ixheaace_mps_pstr_space_structure pstr_space_enc,
382
    const ixheaace_mps_buf_descr *ptr_in_buf_desc, const ixheaace_mps_buf_descr *ptr_out_buf_desc,
383
    const ixheaace_mps_in_args *pstr_in_args, ixheaace_mps_out_args *pstr_out_args, WORD32 aot,
384
92.6k
    WORD8 *ptr_scratch) {
385
92.6k
  IA_ERRORCODE error = IA_NO_ERROR;
386
92.6k
  WORD32 num_output_samples;
387
92.6k
  WORD32 i, ch, ps, win_cnt, ts, slot;
388
92.6k
  WORD32 curr_trans_pos = -1;
389
92.6k
  WORD32 num_ch_in;
390
92.6k
  WORD32 num_ch_in_with_dmx;
391
92.6k
  WORD32 num_ch_out;
392
92.6k
  WORD32 num_samples_per_channel;
393
92.6k
  WORD32 num_output_samples_max;
394
92.6k
  WORD32 num_frame_time_slots;
395
92.6k
  WORD32 num_frame_time_slots_reduction;
396
92.6k
  ixheaace_mps_spatial_frame *pstr_frame_data = NULL;
397
92.6k
  UWORD8 *ptr_bitstream_delay_buffer;
398
92.6k
  const FLOAT32 *ptr_input_samples =
399
92.6k
      (const FLOAT32 *)ptr_in_buf_desc->pp_base[IXHEAACE_MPS_INPUT_BUFFER_IDX];
400
401
92.6k
  FLOAT32 *const ptr_output_samples =
402
92.6k
      (FLOAT32 *)ptr_out_buf_desc->pp_base[IXHEAACE_MPS_OUTUT_BUFFER_IDX];
403
404
92.6k
  const WORD32 num_output_samples_buffer_size =
405
92.6k
      ptr_out_buf_desc->p_buf_size[IXHEAACE_MPS_OUTUT_BUFFER_IDX] /
406
92.6k
      ptr_out_buf_desc->p_ele_size[IXHEAACE_MPS_OUTUT_BUFFER_IDX];
407
92.6k
  num_ch_in = pstr_space_enc->n_input_channels;
408
92.6k
  num_ch_in_with_dmx = num_ch_in;
409
92.6k
  num_ch_out = pstr_space_enc->n_output_channels;
410
92.6k
  num_samples_per_channel = pstr_in_args->num_input_samples / num_ch_in_with_dmx;
411
92.6k
  num_output_samples_max = num_samples_per_channel * num_ch_out;
412
92.6k
  num_frame_time_slots = pstr_space_enc->num_frame_time_slots;
413
92.6k
  num_frame_time_slots_reduction = pstr_space_enc->num_frame_time_slots >> 1;
414
92.6k
  if ((0 != pstr_in_args->num_input_samples % num_ch_in_with_dmx)) {
415
0
    return IA_EXHEAACE_CONFIG_NONFATAL_MPS_INVALID_CONFIG;
416
0
  }
417
92.6k
  pstr_frame_data = &pstr_space_enc->pstr_bitstream_formatter->frame;
418
419
92.6k
  if (aot != AOT_USAC) {
420
17.5k
    if (pstr_space_enc->num_discard_out_frames > 0) {
421
0
      pstr_space_enc->independency_count = 0;
422
0
      pstr_space_enc->independency_flag = 1;
423
17.5k
    } else {
424
17.5k
      pstr_space_enc->independency_flag = (pstr_space_enc->independency_count == 0) ? 1 : 0;
425
17.5k
      if (pstr_space_enc->independency_factor > 0) {
426
17.5k
        pstr_space_enc->independency_count++;
427
17.5k
        pstr_space_enc->independency_count =
428
17.5k
            pstr_space_enc->independency_count % ((WORD32)pstr_space_enc->independency_factor);
429
17.5k
      } else {
430
0
        pstr_space_enc->independency_count = -1;
431
0
      }
432
17.5k
    }
433
17.5k
  }
434
435
92.6k
  error = ixheaace_mps_212_feed_de_inter_pre_scale(
436
92.6k
      pstr_space_enc, ptr_input_samples, ptr_output_samples, pstr_in_args->num_input_samples,
437
92.6k
      pstr_in_args->is_input_inter_leaved, pstr_in_args->input_buffer_size_per_channel,
438
92.6k
      &pstr_out_args->num_samples_consumed);
439
92.6k
  if (error) {
440
0
    return error;
441
0
  }
442
443
92.6k
  if (pstr_space_enc->n_samples_next != pstr_space_enc->n_samples_valid) {
444
0
    return IA_EXHEAACE_CONFIG_NONFATAL_MPS_INVALID_CONFIG;
445
0
  }
446
447
278k
  for (ch = 0; ch < num_ch_in; ch++) {
448
6.45M
    for (slot = 0; slot < num_frame_time_slots; slot++) {
449
6.26M
      ixheaace_cmplx_str *pstr_cmplx_data;
450
451
6.26M
      pstr_cmplx_data =
452
6.26M
          pstr_space_enc
453
6.26M
              ->cmplx_hybrid_in[ch][pstr_space_enc->n_update_hybrid_position_time_slots +
454
6.26M
                                    num_frame_time_slots - num_frame_time_slots_reduction + slot];
455
6.26M
      memset(pstr_cmplx_data, 0, 2 * pstr_space_enc->num_hybrid_bands * sizeof(WORD32));
456
6.26M
    }
457
185k
  }
458
459
278k
  for (ch = 0; ch < num_ch_in; ch++) {
460
185k
    FLOAT32 qmf_in_real[MAX_QMF_BANDS];
461
185k
    FLOAT32 qmf_in_imag[MAX_QMF_BANDS];
462
185k
    FLOAT32 p_work_buffer[MAX_QMF_BANDS << 1];
463
185k
    FLOAT32 *ptr_pre_gain = pstr_space_enc->pstr_static_gain->pre_gain;
464
6.45M
    for (ts = 0; ts < num_frame_time_slots; ts++) {
465
6.26M
      FLOAT32 *ptr_spec_real;
466
6.26M
      FLOAT32 *ptr_spec_imag;
467
468
6.26M
      FLOAT32 *ptr_time_in =
469
6.26M
          &pstr_space_enc->time_signal_in[ch][(ts * pstr_space_enc->num_qmf_bands)];
470
471
6.26M
      ixheaace_mps_212_apply_dc_filter(pstr_space_enc->pstr_dc_filter[ch], ptr_time_in,
472
6.26M
                                       ptr_time_in, pstr_space_enc->num_qmf_bands);
473
474
6.26M
      error = ixheaace_mps_212_qmf_analysis_filtering_slot(pstr_space_enc->pstr_qmf_filter_in[ch],
475
6.26M
                                                           qmf_in_real, qmf_in_imag, ptr_time_in,
476
6.26M
                                                           1, p_work_buffer, ptr_scratch);
477
6.26M
      if (error != IA_NO_ERROR) {
478
0
        return error;
479
0
      }
480
481
6.26M
      ptr_spec_real = qmf_in_real;
482
6.26M
      ptr_spec_imag = qmf_in_imag;
483
6.26M
      if (1.0f != ptr_pre_gain[ch]) {
484
0
        for (i = 0; i < pstr_space_enc->num_hybrid_bands; i++) {
485
0
          pstr_space_enc
486
0
              ->cmplx_hybrid_in[ch][pstr_space_enc->n_analysis_lookahead_time_slots + ts][i]
487
0
              .re = ptr_spec_real[i] * ptr_pre_gain[ch];
488
0
          pstr_space_enc
489
0
              ->cmplx_hybrid_in[ch][pstr_space_enc->n_analysis_lookahead_time_slots + ts][i]
490
0
              .im = ptr_spec_imag[i] * ptr_pre_gain[ch];
491
0
        }
492
6.26M
      } else {
493
407M
        for (i = 0; i < pstr_space_enc->num_hybrid_bands; i++) {
494
401M
          pstr_space_enc
495
401M
              ->cmplx_hybrid_in[ch][pstr_space_enc->n_analysis_lookahead_time_slots + ts][i]
496
401M
              .re = ptr_spec_real[i];
497
401M
          pstr_space_enc
498
401M
              ->cmplx_hybrid_in[ch][pstr_space_enc->n_analysis_lookahead_time_slots + ts][i]
499
401M
              .im = ptr_spec_imag[i];
500
401M
        }
501
6.26M
      }
502
6.26M
    }
503
185k
  }
504
505
278k
  for (ch = 0; ch < num_ch_in; ch++) {
506
9.59M
    for (slot = 0; slot < (WORD32)(pstr_space_enc->n_update_hybrid_position_time_slots +
507
9.59M
                                   num_frame_time_slots - num_frame_time_slots_reduction);
508
9.41M
         slot++) {
509
9.41M
      memmove(pstr_space_enc->cmplx_hybrid_in[ch][slot],
510
9.41M
              pstr_space_enc->cmplx_hybrid_in_static[ch][slot],
511
9.41M
              sizeof(ixheaace_cmplx_str) * pstr_space_enc->num_hybrid_bands);
512
9.41M
    }
513
514
9.59M
    for (slot = 0; slot < (WORD32)(pstr_space_enc->n_update_hybrid_position_time_slots +
515
9.59M
                                   num_frame_time_slots - num_frame_time_slots_reduction);
516
9.41M
         slot++) {
517
9.41M
      memmove(pstr_space_enc->cmplx_hybrid_in_static[ch][slot],
518
9.41M
              pstr_space_enc->cmplx_hybrid_in[ch][num_frame_time_slots + slot],
519
9.41M
              sizeof(ixheaace_cmplx_str) * pstr_space_enc->num_hybrid_bands);
520
9.41M
    }
521
522
185k
    error = ixheaace_mps_212_onset_detect_apply(
523
185k
        pstr_space_enc->pstr_onset_detect[ch], num_frame_time_slots,
524
185k
        &pstr_space_enc->cmplx_hybrid_in[ch][pstr_space_enc->n_analysis_lookahead_time_slots],
525
185k
        pstr_space_enc->tr_prev_pos[1], pstr_space_enc->pp_tr_curr_pos[ch]);
526
185k
    if (error) {
527
0
      return error;
528
0
    }
529
530
185k
    if (pstr_space_enc->use_frame_keep == 0) {
531
0
      pstr_space_enc->pp_tr_curr_pos[ch][0] = -1;
532
0
    }
533
534
185k
    if ((pstr_space_enc->pp_tr_curr_pos[ch][0] >= 0) &&
535
50.0k
        ((curr_trans_pos < 0) || (pstr_space_enc->pp_tr_curr_pos[ch][0] < curr_trans_pos))) {
536
27.7k
      curr_trans_pos = pstr_space_enc->pp_tr_curr_pos[ch][0];
537
27.7k
    }
538
185k
  }
539
92.6k
  if (pstr_space_enc->use_frame_keep == 1) {
540
92.6k
    if ((curr_trans_pos != -1) || (pstr_space_enc->independency_flag == 1)) {
541
32.4k
      pstr_space_enc->avoid_keep = NUM_KEEP_WINDOWS;
542
32.4k
      curr_trans_pos = -1;
543
32.4k
    }
544
92.6k
  }
545
546
92.6k
  pstr_space_enc->tr_prev_pos[0] = MAX(-1, pstr_space_enc->tr_prev_pos[1] - num_frame_time_slots);
547
92.6k
  pstr_space_enc->tr_prev_pos[1] = curr_trans_pos;
548
549
278k
  for (ch = 0; ch < num_ch_in; ch++) {
550
185k
    error = ixheaace_mps_212_onset_detect_update(pstr_space_enc->pstr_onset_detect[ch],
551
185k
                                                 num_frame_time_slots);
552
185k
    if (error) {
553
0
      return error;
554
0
    }
555
185k
  }
556
557
92.6k
  ixheaace_mps_212_frame_window_get_window(
558
92.6k
      pstr_space_enc->h_frame_window, pstr_space_enc->tr_prev_pos, num_frame_time_slots,
559
92.6k
      &pstr_frame_data->framing_info, pstr_space_enc->ptr_frame_window_ana,
560
92.6k
      &pstr_space_enc->frame_win_list, pstr_space_enc->avoid_keep);
561
562
185k
  for (ps = 0, win_cnt = 0; ps < pstr_space_enc->frame_win_list.win_list_cnt; ++ps) {
563
92.6k
    if (pstr_space_enc->frame_win_list.dat[ps].hold == IXHEAACE_MPS_FRAME_WINDOWING_HOLD) {
564
0
      ixheaace_mps_212_duplicate_parameter_set(&pstr_space_enc->save_frame, 0, pstr_frame_data,
565
0
                                               ps);
566
92.6k
    } else {
567
92.6k
      WORD32 num_analysis_length_time_slots, analysis_start_time_slot;
568
92.6k
      FLOAT32 *ptr_frame_window_ana;
569
92.6k
      num_analysis_length_time_slots = ixheaace_mps_212_get_analysis_length_time_slots(
570
92.6k
          pstr_space_enc->ptr_frame_window_ana[win_cnt],
571
92.6k
          pstr_space_enc->num_analysis_length_time_slots);
572
573
92.6k
      analysis_start_time_slot = ixheaace_mps_212_get_analysis_start_time_slot(
574
92.6k
          pstr_space_enc->ptr_frame_window_ana[win_cnt],
575
92.6k
          pstr_space_enc->num_analysis_length_time_slots);
576
577
92.6k
      ptr_frame_window_ana = pstr_space_enc->ptr_frame_window_ana[win_cnt];
578
579
92.6k
      error = ixheaace_mps_212_space_tree_apply(
580
92.6k
          pstr_space_enc->pstr_space_tree, ps, num_ch_in, num_analysis_length_time_slots,
581
92.6k
          analysis_start_time_slot, pstr_space_enc->num_hybrid_bands, ptr_frame_window_ana,
582
92.6k
          pstr_space_enc->cmplx_hybrid_in, pstr_space_enc->cmplx_hybrid_in, pstr_frame_data,
583
92.6k
          pstr_space_enc->avoid_keep);
584
92.6k
      if (error) {
585
0
        return error;
586
0
      }
587
588
92.6k
      ixheaace_mps_212_duplicate_parameter_set(pstr_frame_data, ps, &pstr_space_enc->save_frame,
589
92.6k
                                               0);
590
92.6k
      ++win_cnt;
591
92.6k
    }
592
92.6k
    if (pstr_space_enc->avoid_keep > 0) {
593
52.4k
      pstr_space_enc->avoid_keep--;
594
52.4k
    }
595
92.6k
  }
596
597
92.6k
  memset(&pstr_frame_data->smg_data, 0, sizeof(pstr_frame_data->smg_data));
598
599
92.6k
  ptr_bitstream_delay_buffer =
600
92.6k
      (UWORD8 *)ptr_out_buf_desc->pp_base[IXHEAACE_MPS_BITSTREAM_BUFFER_IDX];
601
92.6k
  pstr_frame_data->bs_independency_flag = pstr_space_enc->independency_flag;
602
603
92.6k
  error = ixheaace_mps_212_write_spatial_frame(
604
92.6k
      ptr_bitstream_delay_buffer, MAX_MPEGS_BYTES,
605
92.6k
      &pstr_space_enc->pn_output_bits[pstr_space_enc->n_bitstream_buffer_write],
606
92.6k
      pstr_space_enc->pstr_bitstream_formatter, aot);
607
92.6k
  if (error) {
608
0
    return error;
609
0
  }
610
611
92.6k
  if ((pstr_space_enc->num_discard_out_frames == 0) &&
612
92.6k
      (IXHEAACE_MPS_BITSTREAM_BUFFER_IDX != -1)) {
613
92.6k
    const WORD32 idx = IXHEAACE_MPS_BITSTREAM_BUFFER_IDX;
614
92.6k
    const WORD32 out_bits =
615
92.6k
        pstr_space_enc->pn_output_bits[pstr_space_enc->n_bitstream_buffer_read];
616
617
92.6k
    if (((out_bits + 7) / 8) >
618
92.6k
        (WORD32)(ptr_out_buf_desc->p_buf_size[idx] / ptr_out_buf_desc->p_ele_size[idx])) {
619
0
      pstr_out_args->num_output_bits = 0;
620
0
      return IA_EXHEAACE_EXE_NONFATAL_MPS_ENCODE_ERROR;
621
0
    }
622
92.6k
    pstr_out_args->num_output_bits = out_bits;
623
92.6k
  } else {
624
0
    pstr_out_args->num_output_bits = 0;
625
0
  }
626
627
92.6k
  pstr_space_enc->n_bitstream_buffer_read =
628
92.6k
      (pstr_space_enc->n_bitstream_buffer_read + 1) % pstr_space_enc->n_bitstream_delay_buffer;
629
92.6k
  pstr_space_enc->n_bitstream_buffer_write =
630
92.6k
      (pstr_space_enc->n_bitstream_buffer_write + 1) % pstr_space_enc->n_bitstream_delay_buffer;
631
632
92.6k
  num_output_samples =
633
92.6k
      (pstr_space_enc->num_discard_out_frames == 0) ? (num_output_samples_max) : 0;
634
92.6k
  if (num_output_samples > num_output_samples_buffer_size) {
635
0
    return IA_EXHEAACE_CONFIG_NONFATAL_MPS_INVALID_CONFIG;
636
0
  }
637
92.6k
  pstr_out_args->num_output_samples = num_output_samples;
638
639
92.6k
  if (pstr_space_enc->num_discard_out_frames > 0) {
640
0
    pstr_space_enc->num_discard_out_frames--;
641
0
  }
642
92.6k
  pstr_space_enc->n_samples_valid = 0;
643
644
92.6k
  return error;
645
92.6k
}
646
647
static IA_ERRORCODE ixheaace_mps_212_init(ixheaace_mps_pstr_space_structure pstr_space_enc,
648
1.37k
                                          const WORD32 dmx_delay, WORD32 aot) {
649
1.37k
  IA_ERRORCODE error = IA_NO_ERROR;
650
1.37k
  WORD32 ch;
651
1.37k
  WORD32 num_ch_in_arb_dmx;
652
1.37k
  ixheaace_mps_space_tree_description space_tree_description;
653
1.37k
  ixheaace_mps_onset_detect_config onset_detect_config;
654
1.37k
  ixheaace_mps_frame_win_config frame_window_config;
655
656
1.37k
  error = ixheaace_mps_212_configure(pstr_space_enc, &pstr_space_enc->user);
657
1.37k
  if (error) {
658
0
    return error;
659
0
  }
660
1.37k
  pstr_space_enc->b_enc_mode_212_only = pstr_space_enc->setup->b_enc_mode_212;
661
662
1.37k
  if (pstr_space_enc->num_frame_time_slots < 1) {
663
0
    return IA_EXHEAACE_CONFIG_NONFATAL_MPS_INVALID_CONFIG;
664
0
  }
665
1.37k
  pstr_space_enc->n_frame_length =
666
1.37k
      pstr_space_enc->num_qmf_bands * pstr_space_enc->num_frame_time_slots;
667
668
1.37k
  if (pstr_space_enc->use_frame_keep == 1) {
669
1.37k
    pstr_space_enc->num_analysis_length_time_slots = 3 * pstr_space_enc->num_frame_time_slots;
670
1.37k
    pstr_space_enc->n_update_hybrid_position_time_slots = pstr_space_enc->num_frame_time_slots;
671
1.37k
  } else {
672
0
    pstr_space_enc->num_analysis_length_time_slots = 2 * pstr_space_enc->num_frame_time_slots;
673
0
    pstr_space_enc->n_update_hybrid_position_time_slots = 0;
674
0
  }
675
676
1.37k
  pstr_space_enc->n_analysis_lookahead_time_slots =
677
1.37k
      pstr_space_enc->num_analysis_length_time_slots -
678
1.37k
      3 * pstr_space_enc->num_frame_time_slots / 2;
679
680
1.37k
  ixheaace_mps_212_calc_parameter_band_to_hybrid_band_offset(
681
1.37k
      pstr_space_enc->num_hybrid_bands, pstr_space_enc->ptr_parameter_band_2_hybrid_band_offset,
682
1.37k
      aot);
683
684
1.37k
  error =
685
1.37k
      ixheaace_mps_212_fill_space_tree_setup(pstr_space_enc, &pstr_space_enc->space_tree_setup);
686
1.37k
  if (error) {
687
0
    return error;
688
0
  }
689
1.37k
  error = ixheaace_mps_212_space_tree_init(
690
1.37k
      pstr_space_enc->pstr_space_tree, &pstr_space_enc->space_tree_setup,
691
1.37k
      pstr_space_enc->ptr_parameter_band_2_hybrid_band_offset, pstr_space_enc->use_frame_keep,
692
1.37k
      aot);
693
1.37k
  if (error) {
694
0
    return error;
695
0
  }
696
697
1.37k
  space_tree_description = pstr_space_enc->pstr_space_tree->descr;
698
1.37k
  pstr_space_enc->n_input_channels = space_tree_description.num_out_channels;
699
1.37k
  pstr_space_enc->n_output_channels = space_tree_description.num_in_channels;
700
1.37k
  frame_window_config.num_time_slots_max = pstr_space_enc->num_frame_time_slots;
701
1.37k
  frame_window_config.frame_keep_flag = pstr_space_enc->use_frame_keep;
702
1.37k
  onset_detect_config.max_time_slots = pstr_space_enc->num_frame_time_slots;
703
1.37k
  onset_detect_config.lower_bound_onset_detection =
704
1.37k
      ((2 * 1725 * pstr_space_enc->num_qmf_bands) / pstr_space_enc->num_sample_rate);
705
1.37k
  onset_detect_config.upper_bound_onset_detection = pstr_space_enc->num_hybrid_bands;
706
1.37k
  num_ch_in_arb_dmx = 0;
707
708
4.11k
  for (ch = 0; ch < pstr_space_enc->n_input_channels; ch++) {
709
2.74k
    ixheaace_mps_212_qmf_init_filter_bank(
710
2.74k
        pstr_space_enc->pstr_qmf_filter_in[ch],
711
2.74k
        pstr_space_enc->pstr_qmf_filter_in[ch]->ptr_filter_states, 1,
712
2.74k
        pstr_space_enc->num_qmf_bands, pstr_space_enc->num_qmf_bands,
713
2.74k
        pstr_space_enc->num_qmf_bands);
714
2.74k
    if (error) {
715
0
      return error;
716
0
    }
717
2.74k
    ixheaace_mps_212_init_dc_filter(pstr_space_enc->pstr_dc_filter[ch],
718
2.74k
                                    pstr_space_enc->num_sample_rate);
719
2.74k
    error = ixheaace_mps_212_onset_detect_init(pstr_space_enc->pstr_onset_detect[ch],
720
2.74k
                                               &onset_detect_config, 1);
721
2.74k
    if (error) {
722
0
      return error;
723
0
    }
724
2.74k
  }
725
726
1.37k
  error =
727
1.37k
      ixheaace_mps_212_frame_window_init(pstr_space_enc->h_frame_window, &frame_window_config);
728
1.37k
  if (error) {
729
0
    return error;
730
0
  }
731
732
1.37k
  error = ixheaace_mps_212_static_gain_init(pstr_space_enc->pstr_static_gain,
733
1.37k
                                            pstr_space_enc->pstr_static_gain_config);
734
1.37k
  if (error) {
735
0
    return error;
736
0
  }
737
738
1.37k
  error = ixheaace_mps_212_init_enhanced_time_domain_dmx(
739
1.37k
      pstr_space_enc->pstr_enhanced_time_dmx, pstr_space_enc->pstr_static_gain->pre_gain,
740
1.37k
      pstr_space_enc->pstr_static_gain->post_gain, pstr_space_enc->n_frame_length);
741
1.37k
  if (error) {
742
0
    return error;
743
0
  }
744
745
1.37k
  memset(pstr_space_enc->pstr_bitstream_formatter, 0, sizeof(ixheaace_mps_spatial_frame));
746
1.37k
  pstr_space_enc->pstr_bitstream_formatter->frame.bs_independency_flag = 1;
747
1.37k
  pstr_space_enc->pstr_bitstream_formatter->frame.framing_info.num_param_sets = 1;
748
749
1.37k
  error = ixheaace_mps_212_fill_spatial_specific_config(
750
1.37k
      pstr_space_enc, &pstr_space_enc->pstr_bitstream_formatter->spatial_specific_config);
751
1.37k
  if (error) {
752
0
    return error;
753
0
  }
754
755
1.37k
  error = ixheaace_mps_212_write_spatial_specific_config(
756
1.37k
      &pstr_space_enc->pstr_bitstream_formatter->spatial_specific_config,
757
1.37k
      pstr_space_enc->ssc_buf.ptr_ssc, MAX_SSC_BYTES, &pstr_space_enc->ssc_buf.num_ssc_size_bits,
758
1.37k
      aot);
759
1.37k
  if (error) {
760
0
    return error;
761
0
  }
762
763
1.37k
  error = ixheaace_mps_212_init_delay_compensation(pstr_space_enc, dmx_delay, aot);
764
1.37k
  if (error) {
765
0
    return error;
766
0
  }
767
768
1.37k
  pstr_space_enc->n_samples_next =
769
1.37k
      pstr_space_enc->n_frame_length * (pstr_space_enc->n_input_channels + num_ch_in_arb_dmx);
770
1.37k
  pstr_space_enc->n_samples_valid = 0;
771
772
1.37k
  return error;
773
1.37k
}
774
775
static VOID ixheaace_mps_open(ixheaace_mps_pstr_space_structure *pstr_space_enc_structure,
776
1.40k
                              ixheaace_mps_212_memory_struct *pstr_mps_memory) {
777
1.40k
  WORD32 ch;
778
1.40k
  WORD32 param;
779
1.40k
  ixheaace_mps_pstr_space_structure pstr_space_enc = NULL;
780
1.40k
  pstr_space_enc = &pstr_mps_memory->mp4_space_encoder_instance;
781
1.40k
  if (NULL != pstr_space_enc) {
782
1.40k
    memset(pstr_space_enc, 0, sizeof(struct ixheaace_mps_space_structure));
783
1.40k
  }
784
1.40k
  pstr_space_enc->setup = &pstr_mps_memory->setup;
785
1.40k
  pstr_space_enc->setup->max_sampling_rate = MAX_SAMPLING_RATE;
786
1.40k
  pstr_space_enc->setup->max_frame_time_slots = MAX_FRAME_TIME_SLOT;
787
1.40k
  pstr_space_enc->setup->max_analysis_length_time_slots =
788
1.40k
      3 * pstr_space_enc->setup->max_frame_time_slots;
789
1.40k
  pstr_space_enc->setup->max_qmf_bands =
790
1.40k
      ixheaace_mps_212_space_get_num_qmf_bands(pstr_space_enc->setup->max_sampling_rate);
791
1.40k
  pstr_space_enc->setup->max_hybrid_bands = pstr_space_enc->setup->max_qmf_bands;
792
1.40k
  pstr_space_enc->setup->max_frame_length =
793
1.40k
      pstr_space_enc->setup->max_qmf_bands * pstr_space_enc->setup->max_frame_time_slots;
794
1.40k
  pstr_space_enc->setup->max_ch_in = 2;
795
1.40k
  pstr_space_enc->setup->max_ch_out = 1;
796
1.40k
  pstr_space_enc->setup->max_ch_tot_out = pstr_space_enc->setup->max_ch_out;
797
1.40k
  pstr_space_enc->setup->b_enc_mode_212 = 1;
798
1.40k
  pstr_space_enc->setup->max_hybrid_in_static_slots = 24;
799
800
1.40k
  pstr_space_enc->pstr_static_gain_config = &pstr_mps_memory->static_gain_config;
801
1.40k
  pstr_space_enc->pstr_enhanced_time_dmx = &pstr_mps_memory->enhanced_time_dmx;
802
1.40k
  pstr_space_enc->pstr_enhanced_time_dmx->sinus_window = pstr_mps_memory->sinus_window_flt;
803
1.40k
  pstr_space_enc->ptr_parameter_band_2_hybrid_band_offset =
804
1.40k
      pstr_mps_memory->parameter_band_2_hybrid_band_offset;
805
1.40k
  ixheaace_mps_212_space_tree_open(&pstr_space_enc->pstr_space_tree, pstr_mps_memory);
806
1.40k
  pstr_space_enc->pstr_qmf_filter_in = pstr_mps_memory->pstr_qmf_filter_bank;
807
4.22k
  for (ch = 0; ch < pstr_space_enc->setup->max_ch_in; ch++) {
808
2.81k
    pstr_space_enc->pstr_qmf_filter_in[ch] = &pstr_mps_memory->qmf_filter_bank[ch];
809
2.81k
    pstr_space_enc->pstr_qmf_filter_in[ch]->ptr_filter_states =
810
2.81k
        &pstr_mps_memory->ptr_filter_states[ch];
811
2.81k
    pstr_space_enc->pstr_dc_filter[ch] = &pstr_mps_memory->dc_filter[ch];
812
2.81k
    pstr_space_enc->pstr_onset_detect[ch] = &pstr_mps_memory->onset_detect[ch];
813
2.81k
    pstr_space_enc->pstr_onset_detect[ch]->p_energy_hist =
814
2.81k
        &pstr_mps_memory->energy_hist_float[ch][0];
815
2.81k
  }
816
1.40k
  pstr_space_enc->h_frame_window = &pstr_mps_memory->frame_window;
817
1.40k
  pstr_space_enc->pstr_static_gain = &pstr_mps_memory->static_gain;
818
1.40k
  pstr_space_enc->pstr_bitstream_formatter = &pstr_mps_memory->bitstream;
819
1.40k
  pstr_space_enc->ssc_buf.ptr_ssc = pstr_mps_memory->ssc;
820
1.40k
  pstr_space_enc->pstr_delay = &pstr_mps_memory->delay;
821
1.40k
  pstr_space_enc->pn_output_bits = pstr_mps_memory->n_output_bits;
822
11.2k
  for (param = 0; param < MAX_NUM_PARAMS; param++) {
823
9.84k
    pstr_space_enc->ptr_frame_window_ana[param] =
824
9.84k
        &pstr_mps_memory->frame_window_ana_flt[param][0];
825
9.84k
  }
826
1.40k
  pstr_space_enc->pstr_enhanced_time_dmx->max_frame_length =
827
1.40k
      pstr_space_enc->setup->max_frame_length;
828
4.22k
  for (ch = 0; ch < pstr_space_enc->setup->max_ch_in; ch++) {
829
2.81k
    pstr_space_enc->pstr_onset_detect[ch]->max_time_slots =
830
2.81k
        pstr_space_enc->setup->max_frame_time_slots;
831
2.81k
    pstr_space_enc->pstr_onset_detect[ch]->min_trans_dist = 8;
832
2.81k
    pstr_space_enc->pstr_onset_detect[ch]->avg_energy_dist = 16;
833
2.81k
    pstr_space_enc->pstr_onset_detect[ch]->avg_energy_dist_scale = 4;
834
2.81k
  }
835
1.40k
  pstr_space_enc->pstr_static_gain_config->fixed_gain_dmx = IXHEAACE_MPS_DMX_GAIN_DEFAULT;
836
1.40k
  pstr_space_enc->pstr_static_gain_config->pre_gain_factor_db = 0;
837
838
1.40k
  if (NULL != pstr_space_enc_structure) {
839
1.40k
    *pstr_space_enc_structure = pstr_space_enc;
840
1.40k
  }
841
1.40k
}
842
843
static WORD32 ixheaace_mps_212_get_closest_bit_rate(const WORD32 audio_object_type,
844
                                                    const UWORD32 sampling_rate,
845
1.37k
                                                    const UWORD32 sbr_ratio, UWORD32 bitrate) {
846
1.37k
  UWORD32 idx;
847
1.37k
  WORD32 target_bitrate = -1;
848
849
30.1k
  for (idx = 0; idx < sizeof(mps_config_tab) / sizeof(ixheaace_mps_config_table); idx++) {
850
28.7k
    if ((mps_config_tab[idx].sampling_rate == sampling_rate) &&
851
6.85k
        (mps_config_tab[idx].audio_object_type == audio_object_type) &&
852
2.94k
        (mps_config_tab[idx].sbr_ratio == sbr_ratio)) {
853
1.37k
      target_bitrate =
854
1.37k
          MIN(MAX(bitrate, mps_config_tab[idx].bitrate_min), mps_config_tab[idx].bitrate_max);
855
1.37k
    }
856
28.7k
  }
857
858
1.37k
  return target_bitrate;
859
1.37k
}
860
861
static WORD32 ixheaace_mps_212_write_spatial_specific_config_data(
862
1.37k
    ixheaace_mps_pstr_struct pstr_mps_enc, ixheaace_bit_buf_handle pstr_bit_buf) {
863
1.37k
  WORD32 idx;
864
1.37k
  WORD32 ssc_bits = 0;
865
1.37k
  WORD32 written_bits = 0;
866
1.37k
  ixheaace_mps_space_info pstr_space_encoder_info;
867
1.37k
  ixheaace_mps_212_get_info(pstr_mps_enc->ptr_sac_encoder, &pstr_space_encoder_info);
868
869
4.51k
  for (idx = 0; idx<pstr_space_encoder_info.p_ssc_buf->num_ssc_size_bits>> 3; idx++) {
870
3.14k
    ixheaace_write_bits(pstr_bit_buf, pstr_space_encoder_info.p_ssc_buf->ptr_ssc[idx], 8);
871
3.14k
    written_bits += 8;
872
3.14k
  }
873
1.37k
  ixheaace_write_bits(
874
1.37k
      pstr_bit_buf, pstr_space_encoder_info.p_ssc_buf->ptr_ssc[idx],
875
1.37k
      (UWORD8)(pstr_space_encoder_info.p_ssc_buf->num_ssc_size_bits - written_bits));
876
877
1.37k
  ssc_bits = pstr_space_encoder_info.p_ssc_buf->num_ssc_size_bits;
878
1.37k
  return ssc_bits;
879
1.37k
}
880
881
VOID ixheaace_mps_212_open(VOID **pstr_handle_mps,
882
1.40k
                           ixheaace_mps_212_memory_struct *pstr_mps_memory) {
883
1.40k
  ixheaace_mps_pstr_struct pstr_mps_enc = NULL;
884
1.40k
  pstr_mps_enc = &pstr_mps_memory->mps_encoder_instance;
885
1.40k
  memset(pstr_mps_enc, 0, sizeof(ixheaace_mps_struct));
886
1.40k
  ixheaace_mps_open(&pstr_mps_enc->ptr_sac_encoder, pstr_mps_memory);
887
1.40k
  *pstr_handle_mps = pstr_mps_enc;
888
1.40k
}
889
890
0
VOID ixheaace_mps_212_close(VOID **pstr_handle_mps) {
891
0
  ixheaace_mps_pstr_struct *pstr_mps_enc = (ixheaace_mps_pstr_struct *)pstr_handle_mps;
892
0
  if (*pstr_mps_enc != NULL) {
893
0
    *pstr_mps_enc = NULL;
894
0
  }
895
0
}
896
897
IA_ERRORCODE ixheaace_mps_212_initialise(VOID *pstr_handle_mps, const WORD32 audio_object_type,
898
                                         const UWORD32 sampling_rate, WORD32 *ptr_bitrate,
899
                                         const UWORD32 sbr_ratio, const UWORD32 frame_length,
900
                                         const UWORD32 input_buffer_size_per_channel,
901
1.40k
                                         const UWORD32 core_coder_delay, WORD8 *ptr_scratch) {
902
1.40k
  IA_ERRORCODE error = IA_NO_ERROR;
903
1.40k
  const UWORD32 fs_low = 27713;
904
1.40k
  const UWORD32 fs_high = 55426;
905
1.40k
  const UWORD32 no_inter_frame_coding = 0;
906
1.40k
  UWORD32 num_time_slots = 0, num_qmf_bands_ld = 0;
907
1.40k
  ixheaace_mps_pstr_struct pstr_mps_enc = (ixheaace_mps_pstr_struct)pstr_handle_mps;
908
1.40k
  switch (sbr_ratio) {
909
0
    case 1:
910
0
      if (!(sampling_rate < fs_low)) {
911
0
        return IA_EXHEAACE_INIT_FATAL_MPS_INIT_FAILED;
912
0
      }
913
0
      break;
914
1.24k
    case 2:
915
1.40k
    case 4:
916
1.40k
      if (!((sampling_rate >= fs_low) && (sampling_rate < fs_high))) {
917
36
        return IA_EXHEAACE_INIT_FATAL_MPS_INIT_FAILED;
918
36
      }
919
1.37k
      break;
920
1.37k
    case 0:
921
0
    default:;
922
1.40k
  }
923
924
1.37k
  num_qmf_bands_ld = (sampling_rate < fs_low) ? 5 : ((sampling_rate > fs_high) ? 7 : 6);
925
1.37k
  num_time_slots = frame_length >> num_qmf_bands_ld;
926
1.37k
  *ptr_bitrate = ixheaace_mps_212_get_closest_bit_rate(audio_object_type, sampling_rate,
927
1.37k
                                                       sbr_ratio, *ptr_bitrate);
928
929
1.37k
  pstr_mps_enc->ptr_sac_encoder->user.b_ld_mode = ((no_inter_frame_coding == 1) ? 1 : 2);
930
1.37k
  pstr_mps_enc->ptr_sac_encoder->user.sample_rate = sampling_rate;
931
1.37k
  pstr_mps_enc->ptr_sac_encoder->user.frame_time_slots = num_time_slots;
932
1.37k
  if (audio_object_type == AOT_AAC_ELD) {
933
202
    pstr_mps_enc->ptr_sac_encoder->user.num_param_bands = IXHEAACE_MPS_SAC_BANDS_ld;
934
202
    pstr_mps_enc->ptr_sac_encoder->user.independency_factor = 20;
935
1.16k
  } else {
936
1.16k
    pstr_mps_enc->ptr_sac_encoder->user.num_param_bands = IXHEAACE_MPS_SAC_BANDS_usac;
937
1.16k
    pstr_mps_enc->ptr_sac_encoder->user.independency_factor = 25;
938
1.16k
  }
939
940
1.37k
  pstr_mps_enc->ptr_sac_encoder->user.b_use_coarse_quant = 0;
941
1.37k
  pstr_mps_enc->ptr_sac_encoder->user.quant_mode = IXHEAACE_MPS_QUANTMODE_FINE;
942
1.37k
  pstr_mps_enc->ptr_sac_encoder->user.time_alignment = 0;
943
1.37k
  pstr_mps_enc->audio_object_type = audio_object_type;
944
1.37k
  error =
945
1.37k
      ixheaace_mps_212_init(pstr_mps_enc->ptr_sac_encoder, core_coder_delay, audio_object_type);
946
1.37k
  if (error) {
947
0
    return IA_EXHEAACE_INIT_FATAL_MPS_INIT_FAILED;
948
0
  }
949
950
1.37k
  pstr_mps_enc->in_buf_desc.pp_base = (VOID **)&pstr_mps_enc->p_in_buffer;
951
1.37k
  pstr_mps_enc->in_buf_desc.p_buf_size = pstr_mps_enc->p_in_buffer_size;
952
1.37k
  pstr_mps_enc->in_buf_desc.p_ele_size = pstr_mps_enc->p_in_buffer_el_size;
953
1.37k
  pstr_mps_enc->in_buf_desc.p_buf_type = pstr_mps_enc->p_in_buffer_type;
954
1.37k
  pstr_mps_enc->in_buf_desc.num_bufs = 1;
955
956
1.37k
  pstr_mps_enc->out_buf_desc.pp_base = (VOID **)&pstr_mps_enc->p_out_buffer;
957
1.37k
  pstr_mps_enc->out_buf_desc.p_buf_size = pstr_mps_enc->p_out_buffer_size;
958
1.37k
  pstr_mps_enc->out_buf_desc.p_ele_size = pstr_mps_enc->p_out_buffer_el_size;
959
1.37k
  pstr_mps_enc->out_buf_desc.p_buf_type = pstr_mps_enc->p_out_buffer_type;
960
1.37k
  pstr_mps_enc->out_buf_desc.num_bufs = 2;
961
962
1.37k
  pstr_mps_enc->p_in_buffer[0] = NULL;
963
1.37k
  pstr_mps_enc->p_in_buffer_size[0] = 0;
964
1.37k
  pstr_mps_enc->p_in_buffer_el_size[0] = sizeof(FLOAT32);
965
1.37k
  pstr_mps_enc->p_in_buffer_type[0] = IXHEAACE_MPS_INPUT_BUFFER_IDX;
966
967
1.37k
  pstr_mps_enc->p_out_buffer[0] = NULL;
968
1.37k
  pstr_mps_enc->p_out_buffer_size[0] = 0;
969
1.37k
  pstr_mps_enc->p_out_buffer_el_size[0] = sizeof(FLOAT32);
970
1.37k
  pstr_mps_enc->p_out_buffer_type[0] = IXHEAACE_MPS_OUTUT_BUFFER_IDX;
971
972
1.37k
  pstr_mps_enc->p_out_buffer[1] = NULL;
973
1.37k
  pstr_mps_enc->p_out_buffer_size[1] = 0;
974
1.37k
  pstr_mps_enc->p_out_buffer_el_size[1] = sizeof(UWORD8);
975
1.37k
  pstr_mps_enc->p_out_buffer_type[1] = IXHEAACE_MPS_BITSTREAM_BUFFER_IDX;
976
977
1.37k
  pstr_mps_enc->in_args.is_input_inter_leaved = 0;
978
1.37k
  pstr_mps_enc->in_args.input_buffer_size_per_channel = input_buffer_size_per_channel;
979
980
1.37k
  pstr_mps_enc->ptr_scratch = ptr_scratch;
981
982
1.37k
  return error;
983
1.37k
}
984
985
IA_ERRORCODE ixheaace_mps_212_process(VOID *pstr_handle_mps, FLOAT32 *const ptr_audio_samples,
986
                                      const WORD32 num_audio_samples,
987
92.6k
                                      ixheaace_mps_enc_ext_payload *pstr_mps_ext_payload) {
988
92.6k
  IA_ERRORCODE error = IA_NO_ERROR;
989
92.6k
  ixheaace_mps_pstr_struct pstr_mps_enc = (ixheaace_mps_pstr_struct)pstr_handle_mps;
990
92.6k
  WORD32 aot = pstr_mps_enc->audio_object_type;
991
92.6k
  WORD32 sac_header_flag = 0;
992
92.6k
  WORD32 sac_out_buffer_offset = 0;
993
994
92.6k
  if (aot == AOT_AAC_ELD) {
995
17.5k
    pstr_mps_enc->sac_out_buffer[0] = (sac_header_flag == 0) ? 0x3 : 0x7;
996
17.5k
    sac_out_buffer_offset += 1;
997
17.5k
  }
998
999
92.6k
  pstr_mps_enc->p_in_buffer[0] = (VOID *)ptr_audio_samples;
1000
92.6k
  pstr_mps_enc->in_args.num_input_samples = num_audio_samples;
1001
1002
92.6k
  pstr_mps_enc->p_out_buffer[0] = (VOID *)ptr_audio_samples;
1003
92.6k
  pstr_mps_enc->p_out_buffer_size[0] = sizeof(FLOAT32) * ((WORD32)num_audio_samples) / 2;
1004
1005
92.6k
  pstr_mps_enc->p_out_buffer[1] = (VOID *)&pstr_mps_enc->sac_out_buffer[sac_out_buffer_offset];
1006
92.6k
  pstr_mps_enc->p_out_buffer_size[1] =
1007
92.6k
      sizeof(pstr_mps_enc->sac_out_buffer) - sac_out_buffer_offset;
1008
1009
92.6k
  error = ixheaace_mps_212_encode(pstr_mps_enc->ptr_sac_encoder, &pstr_mps_enc->in_buf_desc,
1010
92.6k
                                  &pstr_mps_enc->out_buf_desc, &pstr_mps_enc->in_args,
1011
92.6k
                                  &pstr_mps_enc->out_args, aot, pstr_mps_enc->ptr_scratch);
1012
92.6k
  if (error) {
1013
0
    return error;
1014
0
  }
1015
1016
92.6k
  pstr_mps_ext_payload->p_data = (UWORD8 *)pstr_mps_enc->sac_out_buffer;
1017
92.6k
  pstr_mps_ext_payload->data_size = pstr_mps_enc->out_args.num_output_bits;
1018
92.6k
  if (aot == AOT_AAC_ELD) {
1019
17.5k
    pstr_mps_ext_payload->data_size += 8 * (sac_out_buffer_offset - 1);
1020
17.5k
  }
1021
92.6k
  pstr_mps_ext_payload->data_type = IXHEAACE_MPS_EXT_LDSAC_DATA;
1022
92.6k
  pstr_mps_ext_payload->associated_ch_element = -1;
1023
1024
92.6k
  return error;
1025
92.6k
}
1026
1027
WORD32 ixheaace_mps_212_get_spatial_specific_config(VOID *pstr_handle_mps, WORD8 *ptr_out_buffer,
1028
1.37k
                                                    WORD32 buf_size, WORD32 aot) {
1029
1.37k
  ixheaace_bit_buf bit_buf;
1030
1.37k
  ixheaace_bit_buf_handle pstr_bit_buf =
1031
1.37k
      ia_enhaacplus_enc_create_bitbuffer(&bit_buf, (UWORD8 *)ptr_out_buffer, buf_size);
1032
1.37k
  ixheaace_mps_212_write_spatial_specific_config_data(pstr_handle_mps, pstr_bit_buf);
1033
1.37k
  if (aot == AOT_AAC_ELD) {
1034
202
    ixheaace_byte_align_buffer(pstr_bit_buf);
1035
202
  }
1036
1.37k
  return ia_enhaacplus_enc_get_bits_available(pstr_bit_buf);
1037
1.37k
}
1038
1039
441
WORD32 ixheaace_mps_515_scratch_size(VOID) {
1040
441
  WORD32 size = 0;
1041
441
  size += ((MAX_INPUT_CHANNELS * MAX_BUFFER_SIZE) * sizeof(FLOAT32));
1042
441
  size += ((MAX_OUTPUT_CHANNELS * MAX_BUFFER_SIZE) * sizeof(FLOAT32));
1043
441
  size +=
1044
441
      (((MAX_INPUT_CHANNELS * MAX_BUFFER_SIZE) + (2 * MAX_BUFFER_SIZE) + (2 * MAX_BUFFER_SIZE)) *
1045
441
       sizeof(FLOAT32));
1046
441
  size += (((6 * MAX_TIME_SLOTS * NUM_QMF_BANDS) + (6 * MAX_TIME_SLOTS * NUM_QMF_BANDS) +
1047
441
            (6 * MAX_TIME_SLOTS * NUM_QMF_BANDS) + (6 * MAX_TIME_SLOTS * NUM_QMF_BANDS) +
1048
441
            (6 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS) + (6 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS)) *
1049
441
           sizeof(FLOAT32));
1050
441
  size += (INPUT_LEN_DOWNSAMPLE * IXHEAACE_MAX_CH_IN_BS_ELE * UPSAMPLE_FAC * sizeof(FLOAT32));
1051
441
  size += (INPUT_LEN_DOWNSAMPLE * IXHEAACE_MAX_CH_IN_BS_ELE * UPSAMPLE_FAC * sizeof(FLOAT32));
1052
441
  size = IXHEAAC_GET_SIZE_ALIGNED(size, BYTE_ALIGN_8);
1053
441
  return size;
1054
441
}
1055
1056
IA_ERRORCODE ixheaace_mps_515_open(VOID **pstr_handle_mps, WORD32 sample_freq, WORD32 tree_config,
1057
                                   ixheaace_bit_buf_handle pstr_bitstream,
1058
                                   WORD32 *ptr_bits_written,
1059
                                   ixheaace_mps_515_memory_struct *pstr_mps_memory,
1060
423
                                   WORD32 flag_480) {
1061
423
  WORD32 i;
1062
423
  IA_ERRORCODE error = IA_NO_ERROR;
1063
423
  ixheaace_mps_sac_specific_config *pstr_mps_specific_config;
1064
423
  ixheaace_mps_sac_pstr_enc pstr_mps_enc = &pstr_mps_memory->spatial_enc_instance;
1065
1066
423
  ixheaace_mps_sac_pstr_qmf_ana_filter_bank pstr_qmf_ana_bank = &pstr_mps_enc->qmf_fltbank;
1067
423
  ixheaace_mps_sac_pstr_qmf_synth_filter_bank pstr_qmf_synth_bank =
1068
423
      &pstr_mps_enc->qmf_synth_fltbank;
1069
1070
423
  memset(pstr_mps_enc, 0, sizeof(ixheaace_mps_sac_enc));
1071
423
  pstr_mps_enc->tree_config = tree_config;
1072
423
  switch (tree_config) {
1073
149
    case 5151:
1074
183
    case 5152:
1075
183
      pstr_mps_enc->output_channels = 1;
1076
183
      break;
1077
240
    case 525:
1078
240
      pstr_mps_enc->output_channels = 2;
1079
423
  }
1080
423
  if (flag_480) {
1081
231
    pstr_mps_enc->time_slots = 15;
1082
231
  } else {
1083
192
    pstr_mps_enc->time_slots = 16;
1084
192
  }
1085
1086
423
  pstr_mps_enc->frame_size = NUM_QMF_BANDS * pstr_mps_enc->time_slots;
1087
1088
423
  pstr_qmf_ana_bank->p_filter = ia_mps_enc_qmf_64_640;
1089
1090
423
  pstr_qmf_synth_bank->p_filter = ia_mps_enc_qmf_64_640;
1091
423
  pstr_qmf_synth_bank->alt_sin_twiddle = sbr_alt_sin_twiddle;
1092
423
  pstr_qmf_synth_bank->cos_twiddle = sbr_cos_twiddle;
1093
423
  pstr_qmf_synth_bank->sin_twiddle = sbr_sin_twiddle;
1094
1095
2.96k
  for (i = 0; i < 6; i++) {
1096
2.53k
    memset(&pstr_mps_enc->filterbank[i], 0, sizeof(ixheaace_mps_sac_sbr_encoder_ana_filter_bank));
1097
1098
2.53k
    memset(&pstr_mps_enc->hyb_state[i], 0, sizeof(ixheaace_mps_hyb_filter_state));
1099
2.53k
  }
1100
1101
423
  pstr_mps_enc->bitstream_formatter = &pstr_mps_memory->bsf_memory_instance;
1102
423
  pstr_mps_specific_config = &pstr_mps_enc->bitstream_formatter->spatial_specific_config;
1103
1104
423
  memset(pstr_mps_specific_config, 0, sizeof(ixheaace_mps_sac_specific_config));
1105
1106
423
  pstr_mps_enc->bitstream_formatter->current_frame.bs_independency_flag_count = 0;
1107
423
  pstr_mps_specific_config->bs_sampling_frequency = sample_freq;
1108
1109
423
  switch (tree_config) {
1110
149
    case 5151:
1111
149
      pstr_mps_specific_config->bs_tree_config = IXHEAACE_MPS_TREE_5151;
1112
149
      pstr_mps_specific_config->ott_config[4].bs_ott_bands = 2;
1113
149
      break;
1114
1115
34
    case 5152:
1116
34
      pstr_mps_specific_config->bs_tree_config = IXHEAACE_MPS_TREE_5152;
1117
34
      pstr_mps_specific_config->ott_config[2].bs_ott_bands = 2;
1118
34
      break;
1119
1120
240
    case 525:
1121
240
      pstr_mps_specific_config->bs_tree_config = IXHEAACE_MPS_TREE_525;
1122
240
      pstr_mps_specific_config->ott_config[0].bs_ott_bands = 2;
1123
240
      pstr_mps_specific_config->ttt_config->bs_ttt_bands_low = PARAMETER_BANDS;
1124
240
      pstr_mps_specific_config->ttt_config->bs_ttt_mode_low = 5;
1125
423
  }
1126
1127
423
  pstr_mps_specific_config->bs_frame_length = pstr_mps_enc->time_slots - 1;
1128
423
  pstr_mps_specific_config->bs_freq_res = 2;
1129
1130
423
  pstr_mps_specific_config->bs_fixed_gain_sur = 2;
1131
423
  pstr_mps_specific_config->bs_fixed_gain_lfe = 1;
1132
423
  pstr_mps_specific_config->bs_fixed_gain_dmx = 0;
1133
1134
423
  error = ixheaace_mps_515_write_spatial_specific_config(pstr_bitstream,
1135
423
                                                         pstr_mps_enc->bitstream_formatter);
1136
1137
423
  *ptr_bits_written = ia_enhaacplus_enc_get_bits_available(pstr_bitstream);
1138
423
  *pstr_handle_mps = pstr_mps_enc;
1139
423
  return error;
1140
423
}
1141
1142
IA_ERRORCODE ixheaace_mps_515_apply(ixheaace_mps_sac_enc *pstr_mps_enc, FLOAT32 *ptr_audio_input,
1143
                                    FLOAT32 *ptr_audio_output,
1144
18.5k
                                    ixheaace_bit_buf_handle pstr_bitstream, VOID *ptr_scratch) {
1145
18.5k
  IA_ERRORCODE error = IA_NO_ERROR;
1146
18.5k
  FLOAT32 *pstr_scratch = (FLOAT32 *)ptr_scratch;
1147
1148
18.5k
  FLOAT32 *in = (FLOAT32 *)pstr_scratch;
1149
18.5k
  memset(in, 0, sizeof(*in) * MAX_INPUT_CHANNELS * MAX_BUFFER_SIZE);
1150
18.5k
  pstr_scratch += MAX_INPUT_CHANNELS * MAX_BUFFER_SIZE;
1151
1152
18.5k
  FLOAT32 *out = (FLOAT32 *)pstr_scratch;
1153
18.5k
  memset(out, 0, sizeof(*out) * 2 * MAX_BUFFER_SIZE);
1154
18.5k
  pstr_scratch += 2 * MAX_BUFFER_SIZE;
1155
1156
18.5k
  FLOAT32 *out1 = (FLOAT32 *)pstr_scratch;
1157
18.5k
  memset(out1, 0, sizeof(*out1) * 2 * MAX_BUFFER_SIZE);
1158
18.5k
  pstr_scratch += 2 * MAX_BUFFER_SIZE;
1159
1160
18.5k
  FLOAT32 *m_qmf_real = (FLOAT32 *)pstr_scratch;
1161
18.5k
  memset(m_qmf_real, 0, sizeof(*m_qmf_real) * 6 * MAX_TIME_SLOTS * NUM_QMF_BANDS);
1162
18.5k
  pstr_scratch += 6 * MAX_TIME_SLOTS * NUM_QMF_BANDS;
1163
1164
18.5k
  FLOAT32 *m_qmf_imag = (FLOAT32 *)pstr_scratch;
1165
18.5k
  memset(m_qmf_imag, 0, sizeof(*m_qmf_imag) * 6 * MAX_TIME_SLOTS * NUM_QMF_BANDS);
1166
18.5k
  pstr_scratch += 6 * MAX_TIME_SLOTS * NUM_QMF_BANDS;
1167
1168
18.5k
  FLOAT32 *m_hybrid_real = (FLOAT32 *)pstr_scratch;
1169
18.5k
  memset(m_hybrid_real, 0, sizeof(*m_hybrid_real) * 6 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS);
1170
18.5k
  pstr_scratch += 6 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS;
1171
1172
18.5k
  FLOAT32 *m_hybrid_imag = (FLOAT32 *)pstr_scratch;
1173
18.5k
  memset(m_hybrid_imag, 0, sizeof(*m_hybrid_imag) * 6 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS);
1174
18.5k
  pstr_scratch += 6 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS;
1175
1176
18.5k
  FLOAT32 *m_qmf_real_out = (FLOAT32 *)pstr_scratch;
1177
18.5k
  memset(m_qmf_real_out, 0, sizeof(*m_qmf_real_out) * 6 * MAX_TIME_SLOTS * NUM_QMF_BANDS);
1178
18.5k
  pstr_scratch += 6 * MAX_TIME_SLOTS * NUM_QMF_BANDS;
1179
1180
18.5k
  FLOAT32 *m_qmf_imag_out = (FLOAT32 *)pstr_scratch;
1181
18.5k
  memset(m_qmf_imag_out, 0, sizeof(*m_qmf_imag_out) * 6 * MAX_TIME_SLOTS * NUM_QMF_BANDS);
1182
1183
18.5k
  ixheaace_mps_sac_spatial_frame *pstr_frame_data;
1184
18.5k
  ixheaace_mps_sac_pstr_qmf_ana_filter_bank pstr_qmf_ana_bank = &pstr_mps_enc->qmf_fltbank;
1185
18.5k
  ixheaace_mps_sac_pstr_qmf_synth_filter_bank pstr_qmf_synth_bank =
1186
18.5k
      &pstr_mps_enc->qmf_synth_fltbank;
1187
1188
18.5k
  WORD32 i, j, k, l;
1189
1190
18.5k
  FLOAT32 p_pre_scale[6] = {1.f, 1.f, 1.f, 0.3162f, 0.7071f, 0.7071f};
1191
6.56M
  for (i = 0; i < DELAY_COMPENSATION; i++) {
1192
45.8M
    for (j = 0; j < 6; j++) {
1193
39.2M
      pstr_mps_enc->in1[j][i] = pstr_mps_enc->in1[j][i + pstr_mps_enc->frame_size];
1194
39.2M
    }
1195
6.54M
  }
1196
1197
18.3M
  for (i = 0; i < pstr_mps_enc->frame_size; i++) {
1198
128M
    for (j = 0; j < 6; j++) {
1199
109M
      pstr_mps_enc->in1[j][i + DELAY_COMPENSATION] = ptr_audio_input[i * 6 + j] * p_pre_scale[j];
1200
109M
    }
1201
18.3M
  }
1202
1203
18.3M
  for (i = 0; i < pstr_mps_enc->frame_size; i++) {
1204
128M
    for (j = 0; j < 6; j++) {
1205
109M
      in[j * MAX_BUFFER_SIZE + i] = ptr_audio_input[i * 6 + j] * p_pre_scale[j];
1206
109M
    }
1207
18.3M
  }
1208
1209
18.3M
  for (i = 0; i < pstr_mps_enc->frame_size; i++) {
1210
18.3M
    if (pstr_mps_enc->output_channels == 1)
1211
6.59M
      out1[i] = in[i] + in[MAX_BUFFER_SIZE + i] + in[2 * MAX_BUFFER_SIZE + i] +
1212
6.59M
                in[3 * MAX_BUFFER_SIZE + i] + in[4 * MAX_BUFFER_SIZE + i] +
1213
6.59M
                in[5 * MAX_BUFFER_SIZE + i];
1214
11.7M
    else {
1215
11.7M
      out1[i] = in[i] + 0.7071f * (in[2 * MAX_BUFFER_SIZE + i] + in[3 * MAX_BUFFER_SIZE + i]) +
1216
11.7M
                in[4 * MAX_BUFFER_SIZE + i];
1217
11.7M
      out1[MAX_BUFFER_SIZE + i] =
1218
11.7M
          in[MAX_BUFFER_SIZE + i] +
1219
11.7M
          0.7071f * (in[2 * MAX_BUFFER_SIZE + i] + in[3 * MAX_BUFFER_SIZE + i]) +
1220
11.7M
          in[5 * MAX_BUFFER_SIZE + i];
1221
11.7M
    }
1222
18.3M
  }
1223
1224
18.3M
  for (i = 0; i < pstr_mps_enc->frame_size; i++) {
1225
128M
    for (j = 0; j < 6; j++) {
1226
109M
      in[j * MAX_BUFFER_SIZE + i] = pstr_mps_enc->in1[j][i];
1227
109M
    }
1228
18.3M
  }
1229
1230
304k
  for (l = 0; l < pstr_mps_enc->time_slots; l++) {
1231
2.00M
    for (j = 0; j < 6; j++) {
1232
1.71M
      ixheaace_mps_515_calculate_ana_filterbank(
1233
1.71M
          &pstr_mps_enc->filterbank[j], in + (j * MAX_BUFFER_SIZE) + (l * 64),
1234
1.71M
          m_qmf_real + (j * MAX_TIME_SLOTS * NUM_QMF_BANDS) + (l * NUM_QMF_BANDS),
1235
1.71M
          m_qmf_imag + (j * MAX_TIME_SLOTS * NUM_QMF_BANDS) + (l * NUM_QMF_BANDS),
1236
1.71M
          pstr_qmf_ana_bank);
1237
1.71M
    }
1238
286k
  }
1239
1240
130k
  for (k = 0; k < 6; k++) {
1241
111k
    ixheaace_mps_515_apply_ana_hyb_filterbank(
1242
111k
        &pstr_mps_enc->hyb_state[k], m_qmf_real + (k * MAX_TIME_SLOTS * NUM_QMF_BANDS),
1243
111k
        m_qmf_imag + (k * MAX_TIME_SLOTS * NUM_QMF_BANDS), pstr_mps_enc->time_slots,
1244
111k
        m_hybrid_real + (k * MAX_TIME_SLOTS * MAX_HYBRID_BANDS),
1245
111k
        m_hybrid_imag + k * MAX_TIME_SLOTS * MAX_HYBRID_BANDS);
1246
111k
  }
1247
1248
18.5k
  pstr_frame_data = &pstr_mps_enc->bitstream_formatter->current_frame;
1249
18.5k
  switch (pstr_mps_enc->tree_config) {
1250
5.27k
    case 5151:
1251
5.27k
      ixheaace_mps_515_ott_box(pstr_mps_enc->time_slots, m_hybrid_real, m_hybrid_imag,
1252
5.27k
                               m_hybrid_real + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1253
5.27k
                               m_hybrid_imag + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1254
5.27k
                               pstr_frame_data->ott_data.cld[3][0],
1255
5.27k
                               pstr_frame_data->ott_data.icc[3][0]);
1256
5.27k
      ixheaace_mps_515_ott_box(
1257
5.27k
          pstr_mps_enc->time_slots, m_hybrid_real + 4 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1258
5.27k
          m_hybrid_imag + 4 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1259
5.27k
          m_hybrid_real + 5 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1260
5.27k
          m_hybrid_imag + 5 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1261
5.27k
          pstr_frame_data->ott_data.cld[2][0], pstr_frame_data->ott_data.icc[2][0]);
1262
5.27k
      ixheaace_mps_515_ott_box(
1263
5.27k
          pstr_mps_enc->time_slots, m_hybrid_real + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1264
5.27k
          m_hybrid_imag + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1265
5.27k
          m_hybrid_real + 3 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1266
5.27k
          m_hybrid_imag + 3 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1267
5.27k
          pstr_frame_data->ott_data.cld[4][0], pstr_frame_data->ott_data.icc[4][0]);
1268
5.27k
      ixheaace_mps_515_ott_box(pstr_mps_enc->time_slots, m_hybrid_real, m_hybrid_imag,
1269
5.27k
                               m_hybrid_real + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1270
5.27k
                               m_hybrid_imag + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1271
5.27k
                               pstr_frame_data->ott_data.cld[1][0],
1272
5.27k
                               pstr_frame_data->ott_data.icc[1][0]);
1273
5.27k
      ixheaace_mps_515_ott_box(pstr_mps_enc->time_slots, m_hybrid_real, m_hybrid_imag,
1274
5.27k
                               m_hybrid_real + 4 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1275
5.27k
                               m_hybrid_imag + 4 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1276
5.27k
                               pstr_frame_data->ott_data.cld[0][0],
1277
5.27k
                               pstr_frame_data->ott_data.icc[0][0]);
1278
1279
5.27k
      break;
1280
1.46k
    case 5152:
1281
1.46k
      ixheaace_mps_515_ott_box(pstr_mps_enc->time_slots, m_hybrid_real, m_hybrid_imag,
1282
1.46k
                               m_hybrid_real + 4 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1283
1.46k
                               m_hybrid_imag + 4 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1284
1.46k
                               pstr_frame_data->ott_data.cld[3][0],
1285
1.46k
                               pstr_frame_data->ott_data.icc[3][0]);
1286
1.46k
      ixheaace_mps_515_ott_box(
1287
1.46k
          pstr_mps_enc->time_slots, m_hybrid_real + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1288
1.46k
          m_hybrid_imag + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1289
1.46k
          m_hybrid_real + 5 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1290
1.46k
          m_hybrid_imag + 5 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1291
1.46k
          pstr_frame_data->ott_data.cld[4][0], pstr_frame_data->ott_data.icc[4][0]);
1292
1.46k
      ixheaace_mps_515_ott_box(
1293
1.46k
          pstr_mps_enc->time_slots, m_hybrid_real + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1294
1.46k
          m_hybrid_imag + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1295
1.46k
          m_hybrid_real + 3 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1296
1.46k
          m_hybrid_imag + 3 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1297
1.46k
          pstr_frame_data->ott_data.cld[2][0], pstr_frame_data->ott_data.icc[2][0]);
1298
1.46k
      ixheaace_mps_515_ott_box(pstr_mps_enc->time_slots, m_hybrid_real, m_hybrid_imag,
1299
1.46k
                               m_hybrid_real + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1300
1.46k
                               m_hybrid_imag + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1301
1.46k
                               pstr_frame_data->ott_data.cld[1][0],
1302
1.46k
                               pstr_frame_data->ott_data.icc[1][0]);
1303
1.46k
      ixheaace_mps_515_ott_box(pstr_mps_enc->time_slots, m_hybrid_real, m_hybrid_imag,
1304
1.46k
                               m_hybrid_real + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1305
1.46k
                               m_hybrid_imag + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1306
1.46k
                               pstr_frame_data->ott_data.cld[0][0],
1307
1.46k
                               pstr_frame_data->ott_data.icc[0][0]);
1308
1.46k
      break;
1309
11.8k
    case 525:
1310
11.8k
      ixheaace_mps_515_ott_box(pstr_mps_enc->time_slots, m_hybrid_real, m_hybrid_imag,
1311
11.8k
                               m_hybrid_real + 4 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1312
11.8k
                               m_hybrid_imag + 4 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1313
11.8k
                               pstr_frame_data->ott_data.cld[1][0],
1314
11.8k
                               pstr_frame_data->ott_data.icc[1][0]);
1315
11.8k
      ixheaace_mps_515_ott_box(
1316
11.8k
          pstr_mps_enc->time_slots, m_hybrid_real + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1317
11.8k
          m_hybrid_imag + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1318
11.8k
          m_hybrid_real + 5 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1319
11.8k
          m_hybrid_imag + 5 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1320
11.8k
          pstr_frame_data->ott_data.cld[2][0], pstr_frame_data->ott_data.icc[2][0]);
1321
11.8k
      ixheaace_mps_515_ott_box(
1322
11.8k
          pstr_mps_enc->time_slots, m_hybrid_real + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1323
11.8k
          m_hybrid_imag + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1324
11.8k
          m_hybrid_real + 3 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1325
11.8k
          m_hybrid_imag + 3 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1326
11.8k
          pstr_frame_data->ott_data.cld[0][0], pstr_frame_data->ott_data.icc[0][0]);
1327
11.8k
      ixheaace_mps_515_ttt_box(pstr_mps_enc->time_slots, m_hybrid_real, m_hybrid_imag,
1328
11.8k
                               m_hybrid_real + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1329
11.8k
                               m_hybrid_imag + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1330
11.8k
                               m_hybrid_real + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1331
11.8k
                               m_hybrid_imag + 2 * MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1332
11.8k
                               pstr_frame_data->ttt_data.cpc_cld1[0][0],
1333
11.8k
                               pstr_frame_data->ttt_data.cpc_cld2[0][0]);
1334
18.5k
  }
1335
1336
18.5k
  pstr_frame_data->framing_info.bs_framing_type = 1;
1337
18.5k
  pstr_frame_data->framing_info.bs_num_param_sets = 1;
1338
1339
18.5k
  pstr_frame_data->framing_info.bs_param_slots[0] = 31;
1340
18.5k
  if (pstr_frame_data->bs_independency_flag_count == 0) {
1341
2.10k
    pstr_frame_data->bs_independency_flag = 1;
1342
2.10k
  }
1343
18.5k
  pstr_frame_data->bs_independency_flag_count =
1344
18.5k
      (pstr_frame_data->bs_independency_flag_count + 1) % 10;
1345
1346
18.5k
  error = ixheaace_mps_515_write_spatial_frame(pstr_bitstream, pstr_mps_enc->bitstream_formatter);
1347
18.5k
  if (error) {
1348
0
    return error;
1349
0
  }
1350
1351
18.5k
  if (pstr_mps_enc->output_channels == 1) {
1352
6.73k
    ixheaace_mps_515_apply_syn_hyb_filterbank(
1353
6.73k
        m_hybrid_real, m_hybrid_imag, pstr_mps_enc->time_slots, m_qmf_real_out, m_qmf_imag_out);
1354
1355
6.73k
    ixheaace_mps_515_calculate_sbr_syn_filterbank(m_qmf_real_out, m_qmf_imag_out, out, 0,
1356
6.73k
                                                  pstr_qmf_synth_bank, pstr_mps_enc->time_slots,
1357
6.73k
                                                  pstr_mps_enc->sbr_qmf_states_synthesis);
1358
1359
6.59M
    for (j = 0; j < pstr_mps_enc->frame_size; j++) {
1360
6.59M
      ptr_audio_output[j] = out1[j];
1361
6.59M
    }
1362
11.8k
  } else {
1363
11.8k
    ixheaace_mps_515_apply_syn_hyb_filterbank(
1364
11.8k
        m_hybrid_real, m_hybrid_imag, pstr_mps_enc->time_slots, m_qmf_real_out, m_qmf_imag_out);
1365
11.8k
    ixheaace_mps_515_apply_syn_hyb_filterbank(m_hybrid_real + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1366
11.8k
                                              m_hybrid_imag + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1367
11.8k
                                              pstr_mps_enc->time_slots,
1368
11.8k
                                              m_qmf_real_out + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1369
11.8k
                                              m_qmf_imag_out + MAX_TIME_SLOTS * MAX_HYBRID_BANDS);
1370
1371
11.8k
    ixheaace_mps_515_calculate_sbr_syn_filterbank(m_qmf_real_out, m_qmf_imag_out, out, 0,
1372
11.8k
                                                  pstr_qmf_synth_bank, pstr_mps_enc->time_slots,
1373
11.8k
                                                  pstr_mps_enc->sbr_qmf_states_synthesis);
1374
11.8k
    ixheaace_mps_515_calculate_sbr_syn_filterbank(
1375
11.8k
        m_qmf_real_out + MAX_TIME_SLOTS * MAX_HYBRID_BANDS,
1376
11.8k
        m_qmf_imag_out + MAX_TIME_SLOTS * MAX_HYBRID_BANDS, out + MAX_BUFFER_SIZE, 1,
1377
11.8k
        pstr_qmf_synth_bank, pstr_mps_enc->time_slots, pstr_mps_enc->sbr_qmf_states_synthesis);
1378
1379
11.7M
    for (j = 0; j < pstr_mps_enc->frame_size; j++) {
1380
11.7M
      ptr_audio_output[2 * j] = out1[j];
1381
11.7M
      ptr_audio_output[2 * j + 1] = out1[MAX_BUFFER_SIZE + j];
1382
11.7M
    }
1383
11.8k
  }
1384
18.5k
  return IA_NO_ERROR;
1385
18.5k
}
1386
1387
0
VOID ixheaace_mps_515_close(ixheaace_mps_sac_enc *pstr_mps_enc) {
1388
0
  if (pstr_mps_enc != NULL) {
1389
    pstr_mps_enc->bitstream_formatter = NULL;
1390
0
  }
1391
0
}