1 /****************************************************************************** 2 * * 3 * Copyright (C) 2018 The Android Open Source Project 4 * 5 * Licensed under the Apache License, Version 2.0 (the "License"); 6 * you may not use this file except in compliance with the License. 7 * You may obtain a copy of the License at: 8 * 9 * http://www.apache.org/licenses/LICENSE-2.0 10 * 11 * Unless required by applicable law or agreed to in writing, software 12 * distributed under the License is distributed on an "AS IS" BASIS, 13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 * See the License for the specific language governing permissions and 15 * limitations under the License. 16 * 17 ***************************************************************************** 18 * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore 19 */ 20 #ifndef IXHEAACD_ENV_CALC_H 21 #define IXHEAACD_ENV_CALC_H 22 23 typedef struct { 24 WORD16 *filt_buf_me; 25 WORD16 *filt_buf_noise_m; 26 WORD32 filt_buf_noise_e; 27 FLAG start_up; 28 WORD16 ph_index; 29 WORD16 tansient_env_prev; 30 WORD8 harm_flags_prev[MAX_FREQ_COEFFS]; 31 WORD16 harm_index; 32 } ia_sbr_calc_env_struct; 33 34 IA_ERRORCODE ixheaacd_calc_sbrenvelope( 35 ia_sbr_scale_fact_struct *sbr_scale_factor, 36 ia_sbr_calc_env_struct *ptr_sbr_calc_env, 37 ia_sbr_header_data_struct *ptr_header_data, 38 ia_sbr_frame_info_data_struct *ptr_frame_data, 39 ia_sbr_prev_frame_data_struct *ptr_prev_frame_data, 40 WORD32 **anal_buf_real_mant, WORD32 **anal_buf_imag_mant, 41 WORD16 *degree_alias, FLAG low_pow_flag, 42 ia_sbr_tables_struct *ptr_sbr_tables, 43 ixheaacd_misc_tables *pstr_common_tables, WORD32 *ptr_qmf_matrix, 44 WORD32 audio_object_type); 45 46 VOID ixheaacd_reset_sbrenvelope_calc(ia_sbr_calc_env_struct *ptr_calc_env); 47 48 WORD32 ixheaacd_derive_lim_band_tbl( 49 ia_sbr_header_data_struct *ptr_header_data, 50 const ia_patch_param_struct *p_str_patch_param, WORD16 num_patches, 51 ixheaacd_misc_tables *pstr_common_tables); 52 53 PLATFORM_INLINE VOID ixheaacd_equalize_filt_buff_exp(WORD16 *ptr_filt_buf, 54 WORD16 *nrg_gain_mant, 55 WORD32 subbands); 56 57 static PLATFORM_INLINE VOID ixheaacd_filt_buf_update(WORD16 *filt_buf_mant, 58 WORD16 *ptr_filt_buf_noise, 59 WORD16 *nrg_gain_mant, 60 WORD16 *noise_level_mant, 61 WORD32 num_sub_bands); 62 63 VOID ixheaacd_noise_level_rescaling(WORD16 *noise_level_mant, WORD32 diff, 64 WORD32 num_sub_bands, 65 WORD32 ixheaacd_drc_offset); 66 67 VOID ixheaacd_enery_calc_persfb(WORD32 **anal_buf_real, WORD32 **anal_buf_imag, 68 WORD32 num_sf_bands, WORD16 *freq_band_table, 69 WORD32 start_pos, WORD32 next_pos, 70 WORD32 max_qmf_subband_aac, WORD32 frame_exp, 71 WORD16 *nrg_est_m, FLAG low_pow_flag, 72 ia_sbr_tables_struct *ptr_sbr_tables); 73 74 VOID ixheaacd_avggain_calc(WORD16 *ptr_enrg_orig, WORD16 *nrg_est, 75 WORD32 sub_band_start, WORD32 sub_band_end, 76 WORD16 *sum_orig_mant, WORD16 *sum_orig_exp, 77 WORD16 *ptr_avg_gain_mant, WORD16 *ptr_avg_gain_exp, 78 ixheaacd_misc_tables *pstr_common_tables, 79 WORD32 flag); 80 81 VOID ixheaacd_adj_timeslot(WORD32 *ptr_buf_real, WORD32 *ptr_buf_imag, 82 WORD16 *ptr_filt_buf, WORD16 *ptr_filt_buf_noise, 83 WORD16 *ptr_gain_buf, WORD16 *ptr_noise_floor, 84 WORD16 *ptr_sine_lvl_buf, WORD16 noise_floor_exp, 85 WORD16 *ptr_harm_index, WORD16 sub_band_start, 86 WORD16 num_sub_bands, WORD16 scale_change, 87 WORD16 smooth_ratio, FLAG num_noise_flg, 88 WORD16 *ptr_phase_index, 89 ia_sbr_tables_struct *ptr_sbr_tables); 90 91 VOID ixheaacd_map_sineflags(WORD16 *freq_band_table, WORD16 num_sf_bands, 92 FLAG *add_harmonics, WORD8 *harm_flags_prev, 93 WORD16 transient_env, WORD8 *sine_mapped_matrix); 94 95 VOID ixheaacd_adjust_scale_dec(WORD32 **re, WORD32 **im, WORD sub_band_start, 96 WORD num_sub_bands, WORD start_pos, 97 WORD next_pos, WORD shift, FLAG low_pow_flag); 98 99 VOID ixheaacd_adjust_scale_armv7(WORD32 **re, WORD32 **im, WORD sub_band_start, 100 WORD num_sub_bands, WORD start_pos, 101 WORD next_pos, WORD shift, FLAG low_pow_flag); 102 103 WORD16 ixheaacd_expsubbandsamples_dec(WORD32 **anal_buf_real_mant, 104 WORD32 **anal_buf_imag_mant, 105 WORD sub_band_start, WORD sub_band_end, 106 WORD start_pos, WORD end_pos, 107 FLAG low_pow_flag); 108 109 WORD16 ixheaacd_expsubbandsamples_armv7(WORD32 **anal_buf_real_mant, 110 WORD32 **anal_buf_imag_mant, 111 WORD sub_band_start, WORD sub_band_end, 112 WORD start_pos, WORD end_pos, 113 FLAG low_pow_flag); 114 115 VOID ixheaacd_enery_calc_per_subband_dec(WORD32 start_pos, WORD32 next_pos, 116 WORD32 sub_band_start, 117 WORD32 sub_band_end, WORD32 frame_exp, 118 WORD16 *nrg_est_mant, 119 FLAG low_pow_flag, 120 ia_sbr_tables_struct *ptr_sbr_tables, 121 WORD32 *ptr_qmf_matrix); 122 123 VOID ixheaacd_enery_calc_per_subband_armv7( 124 WORD32 start_pos, WORD32 next_pos, WORD32 sub_band_start, 125 WORD32 sub_band_end, WORD32 frame_exp, WORD16 *nrg_est_mant, 126 FLAG low_pow_flag, ia_sbr_tables_struct *ptr_sbr_tables, 127 WORD32 *ptr_qmf_matrix); 128 129 WORD32 ixheaacd_reset_hf_generator(ia_sbr_hf_generator_struct *hf_generator, 130 ia_sbr_header_data_struct *ptr_header_data, 131 WORD audio_obj_type); 132 133 VOID ixheaacd_harm_idx_zerotwolp_dec(WORD32 *ptr_real_buf, WORD16 *ptr_gain_buf, 134 WORD scale_change, 135 WORD16 *ptr_sine_level_buf, 136 const WORD32 *ptr_rand_ph, 137 WORD16 *noise_lvl_me, WORD num_sub_bands, 138 FLAG noise_absc_flag, WORD32 harm_index); 139 140 VOID ixheaacd_harm_idx_zerotwolp_armv7(WORD32 *ptr_real_buf, 141 WORD16 *ptr_gain_buf, WORD scale_change, 142 WORD16 *ptr_sine_level_buf, 143 const WORD32 *ptr_rand_ph, 144 WORD16 *noise_lvl_me, WORD num_sub_bands, 145 FLAG noise_absc_flag, WORD32 harm_index); 146 147 VOID ixheaacd_harm_idx_onethreelp(WORD32 *ptr_real_buf, WORD16 *ptr_gain_buf, 148 WORD scale_change, WORD16 *ptr_sine_level_buf, 149 const WORD32 *ptr_rand_ph, 150 WORD16 *noise_lvl_me, WORD num_sub_bands, 151 FLAG noise_absc_flag, WORD freq_inv_flag, 152 WORD noise_e, WORD sub_band_start); 153 154 VOID ixheaacd_conv_ergtoamplitudelp_dec(WORD32 bands, WORD16 noise_e, 155 WORD16 *nrg_sine, WORD16 *nrg_gain, 156 WORD16 *noise_level_mant, 157 WORD16 *sqrt_table); 158 159 VOID ixheaacd_conv_ergtoamplitudelp_armv7(WORD32 bands, WORD16 noise_e, 160 WORD16 *nrg_sine, WORD16 *nrg_gain, 161 WORD16 *noise_level_mant, 162 WORD16 *sqrt_table); 163 164 VOID ixheaacd_conv_ergtoamplitude_dec(WORD32 bands, WORD16 noise_e, 165 WORD16 *nrg_sine, WORD16 *nrg_gain, 166 WORD16 *noise_level_mant, 167 WORD16 *sqrt_table); 168 169 VOID ixheaacd_conv_ergtoamplitude_armv7(WORD32 bands, WORD16 noise_e, 170 WORD16 *nrg_sine, WORD16 *nrg_gain, 171 WORD16 *noise_level_mant, 172 WORD16 *sqrt_table); 173 174 VOID ixheaacd_subbandgain_calc(WORD16 e_orig_mant_matrix, WORD16 tmp_noise_mant, 175 WORD16 nrg_est_mant, WORD16 nrg_est_exp, 176 WORD16 tmp_noise_exp, WORD16 nrg_ref_exp, 177 FLAG sine_present_flag, FLAG sine_mapped_matrix, 178 FLAG noise_absc_flag, WORD16 *ptr_nrg_gain_mant, 179 WORD16 *ptr_noise_floor_mant, 180 WORD16 *ptr_nrg_sine_m, 181 ixheaacd_misc_tables *pstr_common_tables); 182 183 PLATFORM_INLINE VOID ixheaacd_equalize_filt_buff_exp(WORD16 *ptr_filt_buf, 184 WORD16 *nrg_gain, 185 WORD32 subbands); 186 187 #endif 188