aboutsummaryrefslogtreecommitdiff
path: root/encoder/iusace_main.h
blob: dcacb143f2b3fc398f1bda9a3909b3bb8767fa2b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/******************************************************************************
 *                                                                            *
 * Copyright (C) 2023 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at:
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 *****************************************************************************
 * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
 */

#pragma once

typedef struct {
  WORD32 window_size_samples[MAX_TIME_CHANNELS];
  WORD32 usac_independency_flag_interval;
  WORD32 usac_independency_flag_count;
  WORD32 usac_independency_flag;
  WORD32 frame_count;
  WORD32 core_mode[MAX_TIME_CHANNELS];
  WORD32 core_mode_prev[MAX_TIME_CHANNELS];
  WORD32 core_mode_prev_copy[MAX_TIME_CHANNELS];
  WORD32 core_mode_next[MAX_TIME_CHANNELS];
  WORD32 core_mode_copy[MAX_TIME_CHANNELS];
  ia_block_switch_ctrl block_switch_ctrl[MAX_TIME_CHANNELS];
  ia_classification_struct str_sig_class_data;
  FLOAT32 td_in_buf[MAX_TIME_CHANNELS][LEN_SUPERFRAME + LEN_NEXT_HIGH_RATE];
  FLOAT32 td_in_prev_buf[MAX_TIME_CHANNELS][LEN_SUPERFRAME + LEN_NEXT_HIGH_RATE + LEN_LPC0];
  FLOAT32 speech_buf[LEN_TOTAL_HIGH_RATE + LEN_LPC0];
  FLOAT32 synth_buf[ORDER + LEN_SUPERFRAME];
  WORD32 param_buf[(NUM_FRAMES * MAX_NUM_TCX_PRM_PER_DIV) + NUM_LPC_PRM];
  ia_usac_td_encoder_struct *td_encoder[MAX_TIME_CHANNELS];
  WORD32 total_nbbits[MAX_TIME_CHANNELS];
  WORD32 FD_nbbits_fac[MAX_TIME_CHANNELS];
  WORD32 num_td_fac_bits[MAX_TIME_CHANNELS];
  WORD32 td_bitrate[MAX_TIME_CHANNELS];
  WORD32 acelp_core_mode[MAX_TIME_CHANNELS];
  WORD32 max_bitreservoir_bits;
  WORD32 available_bitreservoir_bits;
  ia_drc_enc_state str_drc_state;
  WORD32 num_sbr_bits;
  ia_ms_info_struct str_ms_info[MAX_TIME_CHANNELS];
  WORD32 pred_coef_re[MAX_TIME_CHANNELS][MAX_SHORT_WINDOWS][MAX_SFB_LONG],
      pred_coef_im[MAX_TIME_CHANNELS][MAX_SHORT_WINDOWS][MAX_SFB_LONG];
  WORD32 pred_coef_re_prev[MAX_TIME_CHANNELS][MAX_SFB_LONG],
      pred_coef_im_prev[MAX_TIME_CHANNELS][MAX_SFB_LONG];
  /* Temporary buffers for bitstream writing function when computing static bits */
  WORD32 temp_pred_coef_re_prev[MAX_TIME_CHANNELS][MAX_SFB_LONG],
      temp_pred_coef_im_prev[MAX_TIME_CHANNELS][MAX_SFB_LONG];
  WORD32 pred_dir_idx[MAX_TIME_CHANNELS];
  WORD32 cplx_pred_all[MAX_TIME_CHANNELS];
  WORD32 cplx_pred_used[MAX_TIME_CHANNELS][MAX_SHORT_WINDOWS][MAX_SFB_LONG];
  WORD32 delta_code_time[MAX_TIME_CHANNELS];
  WORD32 complex_coef[MAX_TIME_CHANNELS];
  FLOAT64 *ptr_dmx_re_save[MAX_TIME_CHANNELS]; /*For saving previous frame MDCT down-mix */
  FLOAT64 *ptr_dmx_im[MAX_TIME_CHANNELS];
  FLOAT64 arr_dmx_im[MAX_TIME_CHANNELS][(FRAME_LEN_LONG + FRAME_LEN_LONG / 8)];
  FLOAT64 arr_dmx_save_float[MAX_TIME_CHANNELS][(FRAME_LEN_LONG + FRAME_LEN_LONG / 8)];
  FLOAT64 left_chan_save[MAX_TIME_CHANNELS][(FRAME_LEN_LONG + FRAME_LEN_LONG / 8)];
  FLOAT64 right_chan_save[MAX_TIME_CHANNELS][(FRAME_LEN_LONG + FRAME_LEN_LONG / 8)];

  ia_tns_info *pstr_tns_info[MAX_TIME_CHANNELS];
  WORD32 common_window[MAX_TIME_CHANNELS];
  WORD32 noise_offset[MAX_TIME_CHANNELS];
  WORD32 noise_level[MAX_TIME_CHANNELS];

  ia_usac_quant_info_struct str_quant_info[MAX_TIME_CHANNELS];
  WORD32 noise_filling[MAX_TIME_CHANNELS];
  ia_psy_mod_struct str_psy_mod;
  ia_qc_main_struct str_qc_main;
  FLOAT64 *ptr_time_data[MAX_TIME_CHANNELS];
  FLOAT64 *ptr_look_ahead_time_data[MAX_TIME_CHANNELS];
  FLOAT64 *spectral_line_vector[MAX_TIME_CHANNELS];
  // Pre-/post- twiddle portions of MDCT use two times ccfl of this buffer, hence size of second
  // argument is 2 * pstr_config->ccfl
  FLOAT64 mdst_spectrum[MAX_TIME_CHANNELS][2 * FRAME_LEN_LONG];
  FLOAT64 *ptr_2frame_time_data[MAX_TIME_CHANNELS];
  WORD16 td_serial_out[MAX_TIME_CHANNELS][NBITS_MAX];
  WORD16 fac_out_stream[MAX_TIME_CHANNELS][NBITS_MAX];
  FLOAT64 overlap_buf[MAX_TIME_CHANNELS][2 * FRAME_LEN_LONG];
  WORD32 channel_elem_type[MAX_TIME_CHANNELS];
  WORD32 channel_elem_idx[MAX_TIME_CHANNELS];
  WORD32 num_ext_elements;
  WORD32 ext_type[MAX_EXTENSION_PAYLOADS];
  UWORD8 ext_elem_config_payload[MAX_EXTENSION_PAYLOADS][MAX_EXTENSION_PAYLOAD_LEN];
  UWORD32 ext_elem_config_len[MAX_EXTENSION_PAYLOADS];
  iusace_scratch_mem str_scratch;
  WORD32 min_bits_needed;
} ia_usac_data_struct;

typedef struct {
  ia_usac_lpd_state_struct lpd_state[6];
  ia_usac_lpd_state_struct flpd_state[6];

} ia_usac_lpd_scratch;

IA_ERRORCODE iusace_enc_init(ia_usac_encoder_config_struct *ptr_usac_config,
                             ixheaace_audio_specific_config_struct *pstr_asc,
                             ia_usac_data_struct *pstr_state);

IA_ERRORCODE iusace_quantize_spec(ia_sfb_params_struct *pstr_sfb_prms,
                                  WORD32 usac_independancy_flag, WORD32 num_chans,
                                  ia_usac_data_struct *ptr_usac_data,
                                  ia_usac_encoder_config_struct *ptr_usac_config, WORD32 chn,
                                  WORD32 ele_id, WORD32 *is_quant_spec_zero,
                                  WORD32 *is_gain_limited);

IA_ERRORCODE iusace_grouping(ia_sfb_params_struct *pstr_sfb_prms, WORD32 num_chans,
                             ia_usac_data_struct *ptr_usac_data,
                             ia_usac_encoder_config_struct *ptr_usac_config, WORD32 chn,
                             WORD32 ele_id);

IA_ERRORCODE iusace_stereo_proc(ia_sfb_params_struct *pstr_sfb_prms,
                                WORD32 usac_independancy_flag, ia_usac_data_struct *ptr_usac_data,
                                ia_usac_encoder_config_struct *ptr_usac_config, WORD32 chn);

VOID iusace_classification(ia_classification_struct *pstr_sig_class,
                           iusace_scratch_mem *pstr_scratch, WORD32 ccfl);