xref: /aosp_15_r20/external/libxaac/decoder/ixheaacd_mps_m1m2_common.c (revision 15dc779a375ca8b5125643b829a8aa4b70d7f451)
1*15dc779aSAndroid Build Coastguard Worker /******************************************************************************
2*15dc779aSAndroid Build Coastguard Worker  *
3*15dc779aSAndroid Build Coastguard Worker  * Copyright (C) 2023 The Android Open Source Project
4*15dc779aSAndroid Build Coastguard Worker  *
5*15dc779aSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
6*15dc779aSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
7*15dc779aSAndroid Build Coastguard Worker  * You may obtain a copy of the License at:
8*15dc779aSAndroid Build Coastguard Worker  *
9*15dc779aSAndroid Build Coastguard Worker  * http://www.apache.org/licenses/LICENSE-2.0
10*15dc779aSAndroid Build Coastguard Worker  *
11*15dc779aSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
12*15dc779aSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
13*15dc779aSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*15dc779aSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
15*15dc779aSAndroid Build Coastguard Worker  * limitations under the License.
16*15dc779aSAndroid Build Coastguard Worker  *
17*15dc779aSAndroid Build Coastguard Worker  *****************************************************************************
18*15dc779aSAndroid Build Coastguard Worker  * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*15dc779aSAndroid Build Coastguard Worker */
20*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_type_def.h"
21*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_struct_def.h"
22*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_error_codes.h"
23*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_res_rom.h"
24*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_aac_struct.h"
25*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_constants.h"
26*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_basic_ops32.h"
27*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_basic_ops40.h"
28*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_bitbuffer.h"
29*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_common_rom.h"
30*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbrdecsettings.h"
31*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbr_scale.h"
32*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_env_extr_part.h"
33*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbr_rom.h"
34*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_hybrid.h"
35*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_ps_dec.h"
36*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_error_standards.h"
37*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_polyphase.h"
38*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_config.h"
39*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_qmf_dec.h"
40*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_dec.h"
41*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_macro_def.h"
42*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_bitdec.h"
43*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_calc_m1m2_tree_config.h"
44*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_buffer_m1(ia_heaac_mps_state_struct * pstr_mps_state)45*15dc779aSAndroid Build Coastguard Worker VOID ixheaacd_buffer_m1(ia_heaac_mps_state_struct *pstr_mps_state) {
46*15dc779aSAndroid Build Coastguard Worker   ia_mps_dec_m1_param_struct *m1_param = pstr_mps_state->array_struct->m1_param;
47*15dc779aSAndroid Build Coastguard Worker   WORD32 pb, row, col;
48*15dc779aSAndroid Build Coastguard Worker 
49*15dc779aSAndroid Build Coastguard Worker   ia_mps_persistent_mem *persistent_mem = &pstr_mps_state->mps_persistent_mem;
50*15dc779aSAndroid Build Coastguard Worker   WORD32 *m1_param_real_prev = persistent_mem->m1_param_real_prev;
51*15dc779aSAndroid Build Coastguard Worker   WORD32 *m1_param_imag_prev = persistent_mem->m1_param_imag_prev;
52*15dc779aSAndroid Build Coastguard Worker 
53*15dc779aSAndroid Build Coastguard Worker   WORD32 *m1_param_real, *m1_param_imag;
54*15dc779aSAndroid Build Coastguard Worker 
55*15dc779aSAndroid Build Coastguard Worker   WORD32 *p_m1_param_real, *p_m1_param_re;
56*15dc779aSAndroid Build Coastguard Worker 
57*15dc779aSAndroid Build Coastguard Worker   WORD32 num_parameter_bands = pstr_mps_state->num_parameter_bands;
58*15dc779aSAndroid Build Coastguard Worker   WORD32 num_v_channels = pstr_mps_state->num_v_channels;
59*15dc779aSAndroid Build Coastguard Worker   WORD32 num_x_channels = pstr_mps_state->num_x_channels;
60*15dc779aSAndroid Build Coastguard Worker   WORD32 m1_param_imag_present = pstr_mps_state->m1_param_imag_present;
61*15dc779aSAndroid Build Coastguard Worker 
62*15dc779aSAndroid Build Coastguard Worker   WORD32 num_parameter_sets_prev;
63*15dc779aSAndroid Build Coastguard Worker 
64*15dc779aSAndroid Build Coastguard Worker   pstr_mps_state->num_parameter_sets_prev = pstr_mps_state->num_parameter_sets;
65*15dc779aSAndroid Build Coastguard Worker   num_parameter_sets_prev = pstr_mps_state->num_parameter_sets_prev;
66*15dc779aSAndroid Build Coastguard Worker 
67*15dc779aSAndroid Build Coastguard Worker   if (m1_param_imag_present) {
68*15dc779aSAndroid Build Coastguard Worker     WORD32 *p_m1_param_imag = &m1_param->m1_param_imag[0][0][0][0];
69*15dc779aSAndroid Build Coastguard Worker     p_m1_param_real = &m1_param->m1_param_real[0][0][0][0];
70*15dc779aSAndroid Build Coastguard Worker     for (row = 0; row < num_v_channels; row++) {
71*15dc779aSAndroid Build Coastguard Worker       WORD32 *p_m1_param_im = p_m1_param_imag;
72*15dc779aSAndroid Build Coastguard Worker       p_m1_param_re = p_m1_param_real;
73*15dc779aSAndroid Build Coastguard Worker 
74*15dc779aSAndroid Build Coastguard Worker       for (col = 0; col < num_x_channels; col++) {
75*15dc779aSAndroid Build Coastguard Worker         m1_param_real = p_m1_param_re + (num_parameter_sets_prev - 1) * MAX_PARAMETER_BANDS;
76*15dc779aSAndroid Build Coastguard Worker         m1_param_imag = p_m1_param_im + (num_parameter_sets_prev - 1) * MAX_PARAMETER_BANDS;
77*15dc779aSAndroid Build Coastguard Worker 
78*15dc779aSAndroid Build Coastguard Worker         for (pb = 0; pb < num_parameter_bands; pb++) {
79*15dc779aSAndroid Build Coastguard Worker           *m1_param_real_prev++ = *m1_param_real++;
80*15dc779aSAndroid Build Coastguard Worker           *m1_param_imag_prev++ = *m1_param_imag++;
81*15dc779aSAndroid Build Coastguard Worker         }
82*15dc779aSAndroid Build Coastguard Worker         p_m1_param_re += PBXPS;
83*15dc779aSAndroid Build Coastguard Worker         p_m1_param_im += PBXPS;
84*15dc779aSAndroid Build Coastguard Worker       }
85*15dc779aSAndroid Build Coastguard Worker       p_m1_param_real += MAX_INPUT_CHANNELS_MPS * PBXPS;
86*15dc779aSAndroid Build Coastguard Worker       p_m1_param_imag += MAX_INPUT_CHANNELS_MPS * PBXPS;
87*15dc779aSAndroid Build Coastguard Worker     }
88*15dc779aSAndroid Build Coastguard Worker   } else {
89*15dc779aSAndroid Build Coastguard Worker     p_m1_param_real = &m1_param->m1_param_real[0][0][0][0];
90*15dc779aSAndroid Build Coastguard Worker     for (row = 0; row < num_v_channels; row++) {
91*15dc779aSAndroid Build Coastguard Worker       p_m1_param_re = p_m1_param_real;
92*15dc779aSAndroid Build Coastguard Worker       for (col = 0; col < num_x_channels; col++) {
93*15dc779aSAndroid Build Coastguard Worker         m1_param_real = p_m1_param_re + (num_parameter_sets_prev - 1) * MAX_PARAMETER_BANDS;
94*15dc779aSAndroid Build Coastguard Worker         for (pb = 0; pb < num_parameter_bands; pb++) *m1_param_real_prev++ = *m1_param_real++;
95*15dc779aSAndroid Build Coastguard Worker 
96*15dc779aSAndroid Build Coastguard Worker         p_m1_param_re += PBXPS;
97*15dc779aSAndroid Build Coastguard Worker       }
98*15dc779aSAndroid Build Coastguard Worker       p_m1_param_real += MAX_INPUT_CHANNELS_MPS * PBXPS;
99*15dc779aSAndroid Build Coastguard Worker     }
100*15dc779aSAndroid Build Coastguard Worker   }
101*15dc779aSAndroid Build Coastguard Worker }
102*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_buffer_m2(ia_heaac_mps_state_struct * pstr_mps_state)103*15dc779aSAndroid Build Coastguard Worker VOID ixheaacd_buffer_m2(ia_heaac_mps_state_struct *pstr_mps_state) {
104*15dc779aSAndroid Build Coastguard Worker   WORD32 num_direct_signals = pstr_mps_state->num_direct_signals;
105*15dc779aSAndroid Build Coastguard Worker   WORD32 pb, row, col, col_counter = num_direct_signals + pstr_mps_state->num_decor_signals;
106*15dc779aSAndroid Build Coastguard Worker 
107*15dc779aSAndroid Build Coastguard Worker   ia_mps_persistent_mem *persistent_mem = &pstr_mps_state->mps_persistent_mem;
108*15dc779aSAndroid Build Coastguard Worker   ia_mps_dec_m2_param_struct *m2_param = pstr_mps_state->aux_struct->m2_param;
109*15dc779aSAndroid Build Coastguard Worker 
110*15dc779aSAndroid Build Coastguard Worker   WORD32 *m2_decor_real_prev = persistent_mem->m2_decor_real_prev;
111*15dc779aSAndroid Build Coastguard Worker   WORD32 *m2_decor_imag_prev = persistent_mem->m2_decor_imag_prev;
112*15dc779aSAndroid Build Coastguard Worker 
113*15dc779aSAndroid Build Coastguard Worker   WORD32 *m2_resid_real_prev = persistent_mem->m2_resid_real_prev;
114*15dc779aSAndroid Build Coastguard Worker   WORD32 *m2_resid_imag_prev = persistent_mem->m2_resid_imag_prev;
115*15dc779aSAndroid Build Coastguard Worker 
116*15dc779aSAndroid Build Coastguard Worker   WORD32 *m2_decor_real, *m2_decor_imag, *m2_resid_real, *m2_resid_imag;
117*15dc779aSAndroid Build Coastguard Worker   WORD32 idx = -1;
118*15dc779aSAndroid Build Coastguard Worker 
119*15dc779aSAndroid Build Coastguard Worker   WORD32 resid_col_counter;
120*15dc779aSAndroid Build Coastguard Worker 
121*15dc779aSAndroid Build Coastguard Worker   WORD32 num_parameter_bands = pstr_mps_state->num_parameter_bands;
122*15dc779aSAndroid Build Coastguard Worker   WORD32 num_output_channels = pstr_mps_state->num_output_channels;
123*15dc779aSAndroid Build Coastguard Worker   WORD32 num_parameter_sets_prev = pstr_mps_state->num_parameter_sets_prev;
124*15dc779aSAndroid Build Coastguard Worker 
125*15dc779aSAndroid Build Coastguard Worker   if (pstr_mps_state->residual_coding)
126*15dc779aSAndroid Build Coastguard Worker     resid_col_counter = col_counter;
127*15dc779aSAndroid Build Coastguard Worker   else
128*15dc779aSAndroid Build Coastguard Worker     resid_col_counter = num_direct_signals;
129*15dc779aSAndroid Build Coastguard Worker 
130*15dc779aSAndroid Build Coastguard Worker   if (pstr_mps_state->m2_param_imag_present) {
131*15dc779aSAndroid Build Coastguard Worker     for (row = 0; row < num_output_channels; row++) {
132*15dc779aSAndroid Build Coastguard Worker       for (col = num_direct_signals; col < col_counter; col++) {
133*15dc779aSAndroid Build Coastguard Worker         if (pstr_mps_state->m2_param_present[row][col] & 1) {
134*15dc779aSAndroid Build Coastguard Worker           idx++;
135*15dc779aSAndroid Build Coastguard Worker           m2_decor_real = &m2_param->m2_decor_real[idx][num_parameter_sets_prev - 1][0];
136*15dc779aSAndroid Build Coastguard Worker 
137*15dc779aSAndroid Build Coastguard Worker           for (pb = 0; pb < num_parameter_bands; pb++) *m2_decor_real_prev++ = *m2_decor_real++;
138*15dc779aSAndroid Build Coastguard Worker 
139*15dc779aSAndroid Build Coastguard Worker           m2_decor_imag = &m2_param->m2_decor_imag[idx][num_parameter_sets_prev - 1][0];
140*15dc779aSAndroid Build Coastguard Worker 
141*15dc779aSAndroid Build Coastguard Worker           for (pb = 0; pb < num_parameter_bands; pb++) *m2_decor_imag_prev++ = *m2_decor_imag++;
142*15dc779aSAndroid Build Coastguard Worker         }
143*15dc779aSAndroid Build Coastguard Worker       }
144*15dc779aSAndroid Build Coastguard Worker     }
145*15dc779aSAndroid Build Coastguard Worker 
146*15dc779aSAndroid Build Coastguard Worker     idx = -1;
147*15dc779aSAndroid Build Coastguard Worker     for (row = 0; row < num_output_channels; row++) {
148*15dc779aSAndroid Build Coastguard Worker       for (col = 0; col < resid_col_counter; col++) {
149*15dc779aSAndroid Build Coastguard Worker         if (pstr_mps_state->m2_param_present[row][col] & 2) {
150*15dc779aSAndroid Build Coastguard Worker           idx++;
151*15dc779aSAndroid Build Coastguard Worker           m2_resid_real = &m2_param->m2_resid_real[idx][num_parameter_sets_prev - 1][0];
152*15dc779aSAndroid Build Coastguard Worker 
153*15dc779aSAndroid Build Coastguard Worker           for (pb = 0; pb < num_parameter_bands; pb++) *m2_resid_real_prev++ = *m2_resid_real++;
154*15dc779aSAndroid Build Coastguard Worker           m2_resid_imag = &m2_param->m2_resid_imag[idx][num_parameter_sets_prev - 1][0];
155*15dc779aSAndroid Build Coastguard Worker           for (pb = 0; pb < num_parameter_bands; pb++) *m2_resid_imag_prev++ = *m2_resid_imag++;
156*15dc779aSAndroid Build Coastguard Worker         }
157*15dc779aSAndroid Build Coastguard Worker       }
158*15dc779aSAndroid Build Coastguard Worker     }
159*15dc779aSAndroid Build Coastguard Worker   } else {
160*15dc779aSAndroid Build Coastguard Worker     for (row = 0; row < num_output_channels; row++) {
161*15dc779aSAndroid Build Coastguard Worker       for (col = num_direct_signals; col < col_counter; col++) {
162*15dc779aSAndroid Build Coastguard Worker         if (pstr_mps_state->m2_param_present[row][col] & 1) {
163*15dc779aSAndroid Build Coastguard Worker           idx++;
164*15dc779aSAndroid Build Coastguard Worker           m2_decor_real = &m2_param->m2_decor_real[idx][num_parameter_sets_prev - 1][0];
165*15dc779aSAndroid Build Coastguard Worker 
166*15dc779aSAndroid Build Coastguard Worker           for (pb = 0; pb < num_parameter_bands; pb++) *m2_decor_real_prev++ = *m2_decor_real++;
167*15dc779aSAndroid Build Coastguard Worker         }
168*15dc779aSAndroid Build Coastguard Worker       }
169*15dc779aSAndroid Build Coastguard Worker     }
170*15dc779aSAndroid Build Coastguard Worker 
171*15dc779aSAndroid Build Coastguard Worker     idx = -1;
172*15dc779aSAndroid Build Coastguard Worker     for (row = 0; row < num_output_channels; row++) {
173*15dc779aSAndroid Build Coastguard Worker       for (col = 0; col < resid_col_counter; col++) {
174*15dc779aSAndroid Build Coastguard Worker         if (pstr_mps_state->m2_param_present[row][col] & 2) {
175*15dc779aSAndroid Build Coastguard Worker           idx++;
176*15dc779aSAndroid Build Coastguard Worker           m2_resid_real = &m2_param->m2_resid_real[idx][num_parameter_sets_prev - 1][0];
177*15dc779aSAndroid Build Coastguard Worker 
178*15dc779aSAndroid Build Coastguard Worker           for (pb = 0; pb < num_parameter_bands; pb++) *m2_resid_real_prev++ = *m2_resid_real++;
179*15dc779aSAndroid Build Coastguard Worker         }
180*15dc779aSAndroid Build Coastguard Worker       }
181*15dc779aSAndroid Build Coastguard Worker     }
182*15dc779aSAndroid Build Coastguard Worker   }
183*15dc779aSAndroid Build Coastguard Worker }
184*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_update_alpha(ia_heaac_mps_state_struct * pstr_mps_state)185*15dc779aSAndroid Build Coastguard Worker static VOID ixheaacd_update_alpha(ia_heaac_mps_state_struct *pstr_mps_state) {
186*15dc779aSAndroid Build Coastguard Worker   WORD32 alpha;
187*15dc779aSAndroid Build Coastguard Worker 
188*15dc779aSAndroid Build Coastguard Worker   WORD32 *arbdmx_alpha_prev = pstr_mps_state->mps_persistent_mem.arbdmx_alpha_prev;
189*15dc779aSAndroid Build Coastguard Worker   ia_mps_dec_auxilary_struct *p_aux_struct = pstr_mps_state->aux_struct;
190*15dc779aSAndroid Build Coastguard Worker   WORD32 *arbdmx_alpha = p_aux_struct->arbdmx_alpha;
191*15dc779aSAndroid Build Coastguard Worker 
192*15dc779aSAndroid Build Coastguard Worker   WORD32 n_ch_in = pstr_mps_state->num_input_channels;
193*15dc779aSAndroid Build Coastguard Worker   WORD32 ch;
194*15dc779aSAndroid Build Coastguard Worker 
195*15dc779aSAndroid Build Coastguard Worker   for (ch = 0; ch < n_ch_in; ch++) {
196*15dc779aSAndroid Build Coastguard Worker     *arbdmx_alpha_prev++ = arbdmx_alpha[ch];
197*15dc779aSAndroid Build Coastguard Worker 
198*15dc779aSAndroid Build Coastguard Worker     if (pstr_mps_state->arbitrary_downmix == 2) {
199*15dc779aSAndroid Build Coastguard Worker       alpha = arbdmx_alpha[ch];
200*15dc779aSAndroid Build Coastguard Worker 
201*15dc779aSAndroid Build Coastguard Worker       if (p_aux_struct->arbdmx_residual_abs[ch]) {
202*15dc779aSAndroid Build Coastguard Worker         alpha -= POINT_THREE_THREE_Q15;
203*15dc779aSAndroid Build Coastguard Worker 
204*15dc779aSAndroid Build Coastguard Worker         if (alpha < 0) alpha = 0;
205*15dc779aSAndroid Build Coastguard Worker       } else {
206*15dc779aSAndroid Build Coastguard Worker         alpha += POINT_THREE_THREE_Q15;
207*15dc779aSAndroid Build Coastguard Worker 
208*15dc779aSAndroid Build Coastguard Worker         if (alpha > ONE_IN_Q15) alpha = ONE_IN_Q15;
209*15dc779aSAndroid Build Coastguard Worker       }
210*15dc779aSAndroid Build Coastguard Worker     } else {
211*15dc779aSAndroid Build Coastguard Worker       alpha = ONE_IN_Q15;
212*15dc779aSAndroid Build Coastguard Worker     }
213*15dc779aSAndroid Build Coastguard Worker 
214*15dc779aSAndroid Build Coastguard Worker     arbdmx_alpha[ch] = alpha;
215*15dc779aSAndroid Build Coastguard Worker   }
216*15dc779aSAndroid Build Coastguard Worker }
217*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_calc_m1m2(ia_heaac_mps_state_struct * pstr_mps_state)218*15dc779aSAndroid Build Coastguard Worker VOID ixheaacd_calc_m1m2(ia_heaac_mps_state_struct *pstr_mps_state) {
219*15dc779aSAndroid Build Coastguard Worker   WORD32 up_mix_type = pstr_mps_state->up_mix_type;
220*15dc779aSAndroid Build Coastguard Worker   WORD32 binaural_quality = pstr_mps_state->binaural_quality;
221*15dc779aSAndroid Build Coastguard Worker 
222*15dc779aSAndroid Build Coastguard Worker   if (pstr_mps_state->arbitrary_downmix != 0) {
223*15dc779aSAndroid Build Coastguard Worker     ixheaacd_update_alpha(pstr_mps_state);
224*15dc779aSAndroid Build Coastguard Worker   }
225*15dc779aSAndroid Build Coastguard Worker 
226*15dc779aSAndroid Build Coastguard Worker   switch (pstr_mps_state->tree_config) {
227*15dc779aSAndroid Build Coastguard Worker     case TREE_5151: {
228*15dc779aSAndroid Build Coastguard Worker       if (up_mix_type == 3) {
229*15dc779aSAndroid Build Coastguard Worker         ixheaacd_calc_m1m2_51s1(pstr_mps_state);
230*15dc779aSAndroid Build Coastguard Worker       } else {
231*15dc779aSAndroid Build Coastguard Worker         ixheaacd_calc_m1m2_5151(pstr_mps_state);
232*15dc779aSAndroid Build Coastguard Worker       }
233*15dc779aSAndroid Build Coastguard Worker     } break;
234*15dc779aSAndroid Build Coastguard Worker     case TREE_5152: {
235*15dc779aSAndroid Build Coastguard Worker       if (up_mix_type == 3) {
236*15dc779aSAndroid Build Coastguard Worker         ixheaacd_calc_m1m2_51s2(pstr_mps_state);
237*15dc779aSAndroid Build Coastguard Worker       } else {
238*15dc779aSAndroid Build Coastguard Worker         ixheaacd_calc_m1m2_5152(pstr_mps_state);
239*15dc779aSAndroid Build Coastguard Worker       }
240*15dc779aSAndroid Build Coastguard Worker     } break;
241*15dc779aSAndroid Build Coastguard Worker     case TREE_525:
242*15dc779aSAndroid Build Coastguard Worker       if (up_mix_type == 1) {
243*15dc779aSAndroid Build Coastguard Worker         ixheaacd_calc_m1m2_emm(pstr_mps_state);
244*15dc779aSAndroid Build Coastguard Worker       } else if (up_mix_type == 2) {
245*15dc779aSAndroid Build Coastguard Worker         if (binaural_quality == 1) {
246*15dc779aSAndroid Build Coastguard Worker           ixheaacd_calc_m1m2_5227(pstr_mps_state);
247*15dc779aSAndroid Build Coastguard Worker         }
248*15dc779aSAndroid Build Coastguard Worker       } else {
249*15dc779aSAndroid Build Coastguard Worker         ixheaacd_calc_m1m2_5251(pstr_mps_state);
250*15dc779aSAndroid Build Coastguard Worker       }
251*15dc779aSAndroid Build Coastguard Worker       break;
252*15dc779aSAndroid Build Coastguard Worker     case TREE_7271:
253*15dc779aSAndroid Build Coastguard Worker       if (up_mix_type == 0) {
254*15dc779aSAndroid Build Coastguard Worker         ixheaacd_calc_m1m2_7271(pstr_mps_state);
255*15dc779aSAndroid Build Coastguard Worker       } else if (up_mix_type == 2) {
256*15dc779aSAndroid Build Coastguard Worker         if (binaural_quality == 1) {
257*15dc779aSAndroid Build Coastguard Worker           ixheaacd_calc_m1m2_5227(pstr_mps_state);
258*15dc779aSAndroid Build Coastguard Worker         }
259*15dc779aSAndroid Build Coastguard Worker       }
260*15dc779aSAndroid Build Coastguard Worker       break;
261*15dc779aSAndroid Build Coastguard Worker     case TREE_7272:
262*15dc779aSAndroid Build Coastguard Worker       if (up_mix_type == 0) {
263*15dc779aSAndroid Build Coastguard Worker         ixheaacd_calc_m1m2_7272(pstr_mps_state);
264*15dc779aSAndroid Build Coastguard Worker       } else if (up_mix_type == 2) {
265*15dc779aSAndroid Build Coastguard Worker         if (binaural_quality == 1) {
266*15dc779aSAndroid Build Coastguard Worker           ixheaacd_calc_m1m2_5227(pstr_mps_state);
267*15dc779aSAndroid Build Coastguard Worker         }
268*15dc779aSAndroid Build Coastguard Worker       }
269*15dc779aSAndroid Build Coastguard Worker       break;
270*15dc779aSAndroid Build Coastguard Worker     case TREE_7571:
271*15dc779aSAndroid Build Coastguard Worker       ixheaacd_calc_m1m2_7571(pstr_mps_state);
272*15dc779aSAndroid Build Coastguard Worker       break;
273*15dc779aSAndroid Build Coastguard Worker     case TREE_7572:
274*15dc779aSAndroid Build Coastguard Worker       ixheaacd_calc_m1m2_7572(pstr_mps_state);
275*15dc779aSAndroid Build Coastguard Worker       break;
276*15dc779aSAndroid Build Coastguard Worker     default:
277*15dc779aSAndroid Build Coastguard Worker       break;
278*15dc779aSAndroid Build Coastguard Worker   };
279*15dc779aSAndroid Build Coastguard Worker 
280*15dc779aSAndroid Build Coastguard Worker   return;
281*15dc779aSAndroid Build Coastguard Worker }
282