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_mps_res_rom.h"
23*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_aac_struct.h"
24*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_constants.h"
25*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_bitbuffer.h"
26*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_common_rom.h"
27*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbrdecsettings.h"
28*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbr_scale.h"
29*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_env_extr_part.h"
30*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbr_rom.h"
31*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_hybrid.h"
32*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_ps_dec.h"
33*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_polyphase.h"
34*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_config.h"
35*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_qmf_dec.h"
36*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_dec.h"
37*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_macro_def.h"
38*15dc779aSAndroid Build Coastguard Worker
ixheaacd_dec_interp_umx(WORD32 m[MAX_PARAMETER_SETS][MAX_PARAMETER_BANDS],WORD32 * ptr_r,WORD32 * ptr_m_prev,ia_heaac_mps_state_struct * pstr_mps_state)39*15dc779aSAndroid Build Coastguard Worker VOID ixheaacd_dec_interp_umx(WORD32 m[MAX_PARAMETER_SETS][MAX_PARAMETER_BANDS], WORD32 *ptr_r,
40*15dc779aSAndroid Build Coastguard Worker WORD32 *ptr_m_prev, ia_heaac_mps_state_struct *pstr_mps_state) {
41*15dc779aSAndroid Build Coastguard Worker WORD32 ts, ps = 0, pb;
42*15dc779aSAndroid Build Coastguard Worker WORD32 *r_out;
43*15dc779aSAndroid Build Coastguard Worker const WORD32 *reciprocal_tab = pstr_mps_state->ia_mps_dec_mps_table.m1_m2_table_ptr->reciprocal;
44*15dc779aSAndroid Build Coastguard Worker
45*15dc779aSAndroid Build Coastguard Worker WORD32 num_parameter_bands = pstr_mps_state->num_parameter_bands;
46*15dc779aSAndroid Build Coastguard Worker WORD32 num_parameter_sets = pstr_mps_state->num_parameter_sets;
47*15dc779aSAndroid Build Coastguard Worker
48*15dc779aSAndroid Build Coastguard Worker WORD32 prev_slot = -1;
49*15dc779aSAndroid Build Coastguard Worker WORD32 *prm_slot = pstr_mps_state->aux_struct->param_slot;
50*15dc779aSAndroid Build Coastguard Worker WORD32 curr_slot = *prm_slot;
51*15dc779aSAndroid Build Coastguard Worker
52*15dc779aSAndroid Build Coastguard Worker WORD32 temp = reciprocal_tab[curr_slot];
53*15dc779aSAndroid Build Coastguard Worker r_out = ptr_r;
54*15dc779aSAndroid Build Coastguard Worker
55*15dc779aSAndroid Build Coastguard Worker for (ts = prev_slot + 1; ts <= curr_slot; ts++) {
56*15dc779aSAndroid Build Coastguard Worker for (pb = 0; pb < num_parameter_bands; pb++) {
57*15dc779aSAndroid Build Coastguard Worker WORD32 alpha = temp * (ts + 1);
58*15dc779aSAndroid Build Coastguard Worker WORD32 one_minus_alpha;
59*15dc779aSAndroid Build Coastguard Worker WORD64 result;
60*15dc779aSAndroid Build Coastguard Worker
61*15dc779aSAndroid Build Coastguard Worker one_minus_alpha = (ONE_IN_Q28 - alpha);
62*15dc779aSAndroid Build Coastguard Worker
63*15dc779aSAndroid Build Coastguard Worker result = ((WORD64)(*ptr_m_prev) * (WORD64)one_minus_alpha);
64*15dc779aSAndroid Build Coastguard Worker result += ((WORD64)(m[ps][pb]) * (WORD64)alpha);
65*15dc779aSAndroid Build Coastguard Worker
66*15dc779aSAndroid Build Coastguard Worker *r_out++ = (WORD32)((WORD64)result >> 28);
67*15dc779aSAndroid Build Coastguard Worker ptr_m_prev++;
68*15dc779aSAndroid Build Coastguard Worker }
69*15dc779aSAndroid Build Coastguard Worker ptr_m_prev -= num_parameter_bands;
70*15dc779aSAndroid Build Coastguard Worker }
71*15dc779aSAndroid Build Coastguard Worker
72*15dc779aSAndroid Build Coastguard Worker for (ps = 1; ps < num_parameter_sets; ps++) {
73*15dc779aSAndroid Build Coastguard Worker WORD32 prev_slot = prm_slot[ps - 1];
74*15dc779aSAndroid Build Coastguard Worker WORD32 curr_slot = prm_slot[ps];
75*15dc779aSAndroid Build Coastguard Worker
76*15dc779aSAndroid Build Coastguard Worker temp = reciprocal_tab[curr_slot - prev_slot - 1];
77*15dc779aSAndroid Build Coastguard Worker
78*15dc779aSAndroid Build Coastguard Worker for (ts = (prev_slot) + 1; ts <= (curr_slot); ts++) {
79*15dc779aSAndroid Build Coastguard Worker for (pb = 0; pb < num_parameter_bands; pb++) {
80*15dc779aSAndroid Build Coastguard Worker WORD32 alpha = (ts - prev_slot) * temp;
81*15dc779aSAndroid Build Coastguard Worker WORD64 result;
82*15dc779aSAndroid Build Coastguard Worker WORD32 one_minus_alpha;
83*15dc779aSAndroid Build Coastguard Worker one_minus_alpha = (ONE_IN_Q28 - alpha);
84*15dc779aSAndroid Build Coastguard Worker
85*15dc779aSAndroid Build Coastguard Worker result = ((WORD64)(m[ps - 1][pb]) * (WORD64)one_minus_alpha);
86*15dc779aSAndroid Build Coastguard Worker result += ((WORD64)(m[ps][pb]) * (WORD64)alpha);
87*15dc779aSAndroid Build Coastguard Worker
88*15dc779aSAndroid Build Coastguard Worker *r_out++ = (WORD32)((WORD64)result >> 28);
89*15dc779aSAndroid Build Coastguard Worker }
90*15dc779aSAndroid Build Coastguard Worker }
91*15dc779aSAndroid Build Coastguard Worker }
92*15dc779aSAndroid Build Coastguard Worker return;
93*15dc779aSAndroid Build Coastguard Worker }
94*15dc779aSAndroid Build Coastguard Worker
ixheaacd_apply_abs_kernels(WORD32 * ptr_r_in,WORD32 * ptr_r_out,SIZE_T * ptr_params)95*15dc779aSAndroid Build Coastguard Worker VOID ixheaacd_apply_abs_kernels(WORD32 *ptr_r_in, WORD32 *ptr_r_out, SIZE_T *ptr_params) {
96*15dc779aSAndroid Build Coastguard Worker WORD32 ts, qb;
97*15dc779aSAndroid Build Coastguard Worker SIZE_T *idx_ptr = (SIZE_T *)ptr_params[0];
98*15dc779aSAndroid Build Coastguard Worker WORD32 time_slots = (WORD32)ptr_params[1];
99*15dc779aSAndroid Build Coastguard Worker WORD32 num_parameter_bands = (WORD32)ptr_params[2];
100*15dc779aSAndroid Build Coastguard Worker WORD32 hybrid_bands = (WORD32)ptr_params[3];
101*15dc779aSAndroid Build Coastguard Worker
102*15dc779aSAndroid Build Coastguard Worker for (ts = 0; ts < time_slots; ts++) {
103*15dc779aSAndroid Build Coastguard Worker SIZE_T *idx = idx_ptr;
104*15dc779aSAndroid Build Coastguard Worker for (qb = 0; qb < hybrid_bands; qb++) {
105*15dc779aSAndroid Build Coastguard Worker WORD32 idx_v = (WORD32)(*idx);
106*15dc779aSAndroid Build Coastguard Worker *ptr_r_out++ = *(ptr_r_in + idx_v);
107*15dc779aSAndroid Build Coastguard Worker idx++;
108*15dc779aSAndroid Build Coastguard Worker }
109*15dc779aSAndroid Build Coastguard Worker ptr_r_in += num_parameter_bands;
110*15dc779aSAndroid Build Coastguard Worker }
111*15dc779aSAndroid Build Coastguard Worker return;
112*15dc779aSAndroid Build Coastguard Worker }
113