xref: /aosp_15_r20/external/libxaac/encoder/ixheaace_fd_enc.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 
21*15dc779aSAndroid Build Coastguard Worker #include <string.h>
22*15dc779aSAndroid Build Coastguard Worker #include "iusace_type_def.h"
23*15dc779aSAndroid Build Coastguard Worker #include "iusace_bitbuffer.h"
24*15dc779aSAndroid Build Coastguard Worker #include "iusace_cnst.h"
25*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_common_enc.h"
26*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_uni_drc.h"
27*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_api.h"
28*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_uni_drc_eq.h"
29*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_uni_drc_filter_bank.h"
30*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_gain_enc.h"
31*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_struct_def.h"
32*15dc779aSAndroid Build Coastguard Worker 
33*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_memory_standards.h"
34*15dc779aSAndroid Build Coastguard Worker #include "iusace_tns_usac.h"
35*15dc779aSAndroid Build Coastguard Worker #include "iusace_psy_mod.h"
36*15dc779aSAndroid Build Coastguard Worker #include "iusace_config.h"
37*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_adjust_threshold_data.h"
38*15dc779aSAndroid Build Coastguard Worker #include "iusace_fd_qc_util.h"
39*15dc779aSAndroid Build Coastguard Worker #include "iusace_config.h"
40*15dc779aSAndroid Build Coastguard Worker #include "iusace_arith_enc.h"
41*15dc779aSAndroid Build Coastguard Worker #include "iusace_fd_quant.h"
42*15dc779aSAndroid Build Coastguard Worker #include "iusace_ms.h"
43*15dc779aSAndroid Build Coastguard Worker #include "iusace_signal_classifier.h"
44*15dc779aSAndroid Build Coastguard Worker #include "iusace_block_switch_const.h"
45*15dc779aSAndroid Build Coastguard Worker #include "iusace_block_switch_struct_def.h"
46*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_sbr_header.h"
47*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_config.h"
48*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_asc_write.h"
49*15dc779aSAndroid Build Coastguard Worker #include "iusace_main.h"
50*15dc779aSAndroid Build Coastguard Worker #include "iusace_write_bitstream.h"
51*15dc779aSAndroid Build Coastguard Worker #include "iusace_lpd.h"
52*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_cplx_pred.h"
53*15dc779aSAndroid Build Coastguard Worker #include "iusace_func_prototypes.h"
54*15dc779aSAndroid Build Coastguard Worker 
iusace_fd_encode(ia_sfb_params_struct * pstr_sfb_prms,WORD32 usac_independancy_flag,ia_usac_data_struct * pstr_usac_data,ia_usac_encoder_config_struct * pstr_usac_config,ia_bit_buf_struct * pstr_it_bit_buff,WORD32 nr_core_coder_ch,WORD32 chn,WORD32 ele_id,WORD32 * bit_written,WORD32 * is_quant_spec_zero,WORD32 * is_gain_limited)55*15dc779aSAndroid Build Coastguard Worker IA_ERRORCODE iusace_fd_encode(ia_sfb_params_struct *pstr_sfb_prms, WORD32 usac_independancy_flag,
56*15dc779aSAndroid Build Coastguard Worker                               ia_usac_data_struct *pstr_usac_data,
57*15dc779aSAndroid Build Coastguard Worker                               ia_usac_encoder_config_struct *pstr_usac_config,
58*15dc779aSAndroid Build Coastguard Worker                               ia_bit_buf_struct *pstr_it_bit_buff, WORD32 nr_core_coder_ch,
59*15dc779aSAndroid Build Coastguard Worker                               WORD32 chn, WORD32 ele_id, WORD32 *bit_written,
60*15dc779aSAndroid Build Coastguard Worker                               WORD32 *is_quant_spec_zero, WORD32 *is_gain_limited) {
61*15dc779aSAndroid Build Coastguard Worker   iusace_scratch_mem *pstr_scratch = &pstr_usac_data->str_scratch;
62*15dc779aSAndroid Build Coastguard Worker   IA_ERRORCODE err_code = 0;
63*15dc779aSAndroid Build Coastguard Worker   WORD32 i_ch, idx = 0;
64*15dc779aSAndroid Build Coastguard Worker   WORD32 *ptr_num_fac_bits = pstr_scratch->ptr_num_fac_bits;
65*15dc779aSAndroid Build Coastguard Worker   WORD32 tns_data_present[2] = {0};
66*15dc779aSAndroid Build Coastguard Worker   WORD32 *ptr_core_mode_next = pstr_usac_data->core_mode_next;
67*15dc779aSAndroid Build Coastguard Worker   WORD32 *ptr_core_mode_prev = pstr_usac_data->core_mode_prev;
68*15dc779aSAndroid Build Coastguard Worker   *bit_written = 0;
69*15dc779aSAndroid Build Coastguard Worker   memset(pstr_scratch->ptr_num_fac_bits, 0,
70*15dc779aSAndroid Build Coastguard Worker          MAX_TIME_CHANNELS * sizeof(pstr_scratch->ptr_num_fac_bits[0]));
71*15dc779aSAndroid Build Coastguard Worker   for (i_ch = chn; i_ch < chn + nr_core_coder_ch; i_ch++) {
72*15dc779aSAndroid Build Coastguard Worker     tns_data_present[idx] = pstr_usac_data->pstr_tns_info[i_ch] != NULL;
73*15dc779aSAndroid Build Coastguard Worker 
74*15dc779aSAndroid Build Coastguard Worker     if (tns_data_present[idx]) {
75*15dc779aSAndroid Build Coastguard Worker       tns_data_present[idx] = pstr_usac_data->pstr_tns_info[i_ch]->tns_data_present;
76*15dc779aSAndroid Build Coastguard Worker     }
77*15dc779aSAndroid Build Coastguard Worker     idx++;
78*15dc779aSAndroid Build Coastguard Worker   }
79*15dc779aSAndroid Build Coastguard Worker 
80*15dc779aSAndroid Build Coastguard Worker   idx = 0;
81*15dc779aSAndroid Build Coastguard Worker   for (i_ch = chn; i_ch < chn + nr_core_coder_ch; i_ch++) {
82*15dc779aSAndroid Build Coastguard Worker     memset(pstr_scratch->p_reconstructed_time_signal[idx], 0, 4096 * sizeof(FLOAT64));
83*15dc779aSAndroid Build Coastguard Worker     err_code = iusace_fd_fac(
84*15dc779aSAndroid Build Coastguard Worker         pstr_sfb_prms->grouped_sfb_offset[i_ch], pstr_sfb_prms->max_sfb[i_ch],
85*15dc779aSAndroid Build Coastguard Worker         pstr_usac_data->ptr_2frame_time_data[i_ch], pstr_sfb_prms->window_sequence[i_ch],
86*15dc779aSAndroid Build Coastguard Worker         pstr_scratch->p_reconstructed_time_signal[idx], pstr_usac_data->td_encoder[i_ch],
87*15dc779aSAndroid Build Coastguard Worker         ((pstr_usac_data->td_encoder[i_ch]->prev_mode == 0) && ptr_core_mode_prev[i_ch]) ==
88*15dc779aSAndroid Build Coastguard Worker             CORE_MODE_TD,
89*15dc779aSAndroid Build Coastguard Worker         ptr_core_mode_next[i_ch] == CORE_MODE_TD, pstr_usac_data->fac_out_stream[i_ch],
90*15dc779aSAndroid Build Coastguard Worker         &ptr_num_fac_bits[i_ch], pstr_scratch);
91*15dc779aSAndroid Build Coastguard Worker     if (err_code) {
92*15dc779aSAndroid Build Coastguard Worker       return err_code;
93*15dc779aSAndroid Build Coastguard Worker     }
94*15dc779aSAndroid Build Coastguard Worker     idx++;
95*15dc779aSAndroid Build Coastguard Worker   }
96*15dc779aSAndroid Build Coastguard Worker 
97*15dc779aSAndroid Build Coastguard Worker   err_code = iusace_quantize_spec(pstr_sfb_prms, usac_independancy_flag, nr_core_coder_ch,
98*15dc779aSAndroid Build Coastguard Worker                                   pstr_usac_data, pstr_usac_config, chn, ele_id,
99*15dc779aSAndroid Build Coastguard Worker                                   is_quant_spec_zero, is_gain_limited);
100*15dc779aSAndroid Build Coastguard Worker   if (err_code) return err_code;
101*15dc779aSAndroid Build Coastguard Worker 
102*15dc779aSAndroid Build Coastguard Worker   for (i_ch = chn; i_ch < chn + nr_core_coder_ch; i_ch++) {
103*15dc779aSAndroid Build Coastguard Worker     pstr_sfb_prms->window_shape[i_ch] =
104*15dc779aSAndroid Build Coastguard Worker         pstr_usac_data->str_psy_mod.str_psy_out_data[i_ch].window_shape;
105*15dc779aSAndroid Build Coastguard Worker   }
106*15dc779aSAndroid Build Coastguard Worker 
107*15dc779aSAndroid Build Coastguard Worker   if (nr_core_coder_ch == 1) {
108*15dc779aSAndroid Build Coastguard Worker     iusace_write_bits_buf(pstr_it_bit_buff, tns_data_present[0], 1);
109*15dc779aSAndroid Build Coastguard Worker     *bit_written = *bit_written + 1;
110*15dc779aSAndroid Build Coastguard Worker   }
111*15dc779aSAndroid Build Coastguard Worker   if (nr_core_coder_ch == 2) {
112*15dc779aSAndroid Build Coastguard Worker     *bit_written = *bit_written + iusace_write_cpe(pstr_sfb_prms, pstr_it_bit_buff,
113*15dc779aSAndroid Build Coastguard Worker                                                    tns_data_present, usac_independancy_flag,
114*15dc779aSAndroid Build Coastguard Worker                                                    pstr_usac_config, pstr_usac_data, chn);
115*15dc779aSAndroid Build Coastguard Worker   }
116*15dc779aSAndroid Build Coastguard Worker 
117*15dc779aSAndroid Build Coastguard Worker   idx = 0;
118*15dc779aSAndroid Build Coastguard Worker   for (i_ch = chn; i_ch < chn + nr_core_coder_ch; i_ch++) {
119*15dc779aSAndroid Build Coastguard Worker     *bit_written =
120*15dc779aSAndroid Build Coastguard Worker         *bit_written + iusace_write_fd_data(pstr_it_bit_buff, pstr_sfb_prms,
121*15dc779aSAndroid Build Coastguard Worker                                             ptr_num_fac_bits[i_ch], usac_independancy_flag,
122*15dc779aSAndroid Build Coastguard Worker                                             pstr_usac_data, pstr_usac_config, i_ch, ele_id, idx);
123*15dc779aSAndroid Build Coastguard Worker     idx++;
124*15dc779aSAndroid Build Coastguard Worker   }
125*15dc779aSAndroid Build Coastguard Worker 
126*15dc779aSAndroid Build Coastguard Worker   return err_code;
127*15dc779aSAndroid Build Coastguard Worker }
128