aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorakshayragir833 <110660198+akshayragir833@users.noreply.github.com>2023-12-28 17:47:33 +0530
committerGitHub <noreply@github.com>2023-12-28 17:47:33 +0530
commit1ce177ea0eba8bd56c22131e53df102ddf9fd6fe (patch)
tree1a8d5a330618ea574323fc72b6d41900d9baa07f
parenta7019eafff34dede10e409d342afaeac84615a97 (diff)
downloadlibxaac-1ce177ea0eba8bd56c22131e53df102ddf9fd6fe.tar.gz
Encoder enhancements and minor bug fixes (#73)
Test done: Smoke test
-rw-r--r--encoder/drc_src/impd_drc_api.c12
-rw-r--r--encoder/drc_src/impd_drc_uni_drc.h1
-rw-r--r--encoder/iusace_enc_main.c1
-rw-r--r--encoder/iusace_main.h1
-rw-r--r--encoder/ixheaace_adjust_threshold.c101
-rw-r--r--encoder/ixheaace_adjust_threshold.h2
-rw-r--r--encoder/ixheaace_enc_init.c42
-rw-r--r--encoder/ixheaace_enc_main.c20
-rw-r--r--encoder/ixheaace_fd_quant.c2
-rw-r--r--encoder/ixheaace_ms_stereo.c18
-rw-r--r--encoder/ixheaace_ms_stereo.h2
-rw-r--r--encoder/ixheaace_psy_mod.c144
-rw-r--r--encoder/ixheaace_psy_mod.h6
-rw-r--r--encoder/ixheaace_qc_main_hp.c66
-rw-r--r--encoder/ixheaace_qc_util.h4
-rw-r--r--encoder/ixheaace_sbr_frame_info_gen.c10
-rw-r--r--encoder/ixheaace_sbr_frame_info_gen.h4
-rw-r--r--encoder/ixheaace_sbr_main.c109
-rw-r--r--encoder/ixheaace_sbr_main.h1
-rw-r--r--encoder/ixheaace_sf_estimation.c24
-rw-r--r--encoder/ixheaace_sf_estimation.h4
-rw-r--r--encoder/ixheaace_static_bits.c16
-rw-r--r--encoder/ixheaace_static_bits.h2
-rw-r--r--encoder/ixheaace_stereo_preproc.c10
-rw-r--r--encoder/ixheaace_stereo_preproc.h2
25 files changed, 339 insertions, 265 deletions
diff --git a/encoder/drc_src/impd_drc_api.c b/encoder/drc_src/impd_drc_api.c
index 4218903..0a1b6e1 100644
--- a/encoder/drc_src/impd_drc_api.c
+++ b/encoder/drc_src/impd_drc_api.c
@@ -126,6 +126,18 @@ static IA_ERRORCODE impd_drc_validate_config_params(ia_drc_input_config *pstr_in
.gain_params[k]
.start_sub_band_index,
0, STFT256_HOP_SIZE - 1);
+ IMPD_DRC_BOUND_CHECK(pstr_uni_drc_config->str_drc_coefficients_uni_drc[i]
+ .str_gain_set_params[j].gain_params[k].width,
+ -MAX_FLT_VAL_DB, MAX_FLT_VAL_DB);
+ for (WORD32 m = 0; m < pstr_uni_drc_config->str_drc_coefficients_uni_drc[i]
+ .str_gain_set_params[j].gain_params[k].nb_points; m++) {
+ IMPD_DRC_BOUND_CHECK(pstr_uni_drc_config->str_drc_coefficients_uni_drc[i]
+ .str_gain_set_params[j].gain_params[k].gain_points[m].x,
+ -MAX_FLT_VAL_DB, MAX_FLT_VAL_DB);
+ IMPD_DRC_BOUND_CHECK(pstr_uni_drc_config->str_drc_coefficients_uni_drc[i]
+ .str_gain_set_params[j].gain_params[k].gain_points[m].y,
+ -MAX_FLT_VAL_DB, MAX_FLT_VAL_DB);
+ }
}
for (k = 0; k <
pstr_uni_drc_config->str_drc_coefficients_uni_drc[i].str_gain_set_params[j].band_count
diff --git a/encoder/drc_src/impd_drc_uni_drc.h b/encoder/drc_src/impd_drc_uni_drc.h
index 02a03ab..95f656a 100644
--- a/encoder/drc_src/impd_drc_uni_drc.h
+++ b/encoder/drc_src/impd_drc_uni_drc.h
@@ -129,6 +129,7 @@
#define MAX_METHOD_DEFINITION_TYPE (9)
#define MIN_METHOD_VALUE (-116.0f)
#define MAX_METHOD_VALUE (121.0f)
+#define MAX_FLT_VAL_DB (770.6367883810890080451095799195f)
typedef struct {
WORD32 level_estim_k_weighting_type;
diff --git a/encoder/iusace_enc_main.c b/encoder/iusace_enc_main.c
index fa2a0ac..293db83 100644
--- a/encoder/iusace_enc_main.c
+++ b/encoder/iusace_enc_main.c
@@ -1218,6 +1218,7 @@ IA_ERRORCODE ixheaace_usac_encode(FLOAT32 **ptr_input,
return err;
}
num_bits += num_bits_ext_elem;
+ ptr_usac_data->num_drc_bits = num_bits_ext_elem;
#ifdef DRC_BITRATE_CONSIDERATION
ptr_usac_data->drc_data_bit_cnt = num_bits_ext_elem;
#endif
diff --git a/encoder/iusace_main.h b/encoder/iusace_main.h
index dcacb14..e717286 100644
--- a/encoder/iusace_main.h
+++ b/encoder/iusace_main.h
@@ -95,6 +95,7 @@ typedef struct {
UWORD32 ext_elem_config_len[MAX_EXTENSION_PAYLOADS];
iusace_scratch_mem str_scratch;
WORD32 min_bits_needed;
+ WORD32 num_drc_bits;
} ia_usac_data_struct;
typedef struct {
diff --git a/encoder/ixheaace_adjust_threshold.c b/encoder/ixheaace_adjust_threshold.c
index 9e4e91c..3e38b22 100644
--- a/encoder/ixheaace_adjust_threshold.c
+++ b/encoder/ixheaace_adjust_threshold.c
@@ -129,7 +129,7 @@ VOID iaace_adj_thr_init(ia_adj_thr_state_struct *pstr_adj_thr_state, const FLOAT
}
FLOAT32 iaace_bits_to_pe(const FLOAT32 bits) { return (bits * 1.18f); }
static VOID iaace_calc_sfb_pe_data(ia_qc_pe_data_struct *pstr_qc_pe_data,
- ixheaace_psy_out_channel *pstr_psy_out, WORD32 num_channels,
+ ixheaace_psy_out_channel **pstr_psy_out, WORD32 num_channels,
WORD32 chn) {
WORD32 ch;
WORD32 scf_band_grp;
@@ -148,11 +148,11 @@ static VOID iaace_calc_sfb_pe_data(ia_qc_pe_data_struct *pstr_qc_pe_data,
pstr_qc_pe_data->num_active_lines = 0.0f;
for (ch = chn; ch < chn + num_channels; ch++) {
- sfb_count = pstr_psy_out[ch].sfb_count;
- scf_band_per_grp = pstr_psy_out[ch].sfb_per_group;
- max_sfb_per_grp = pstr_psy_out[ch].max_sfb_per_grp;
- ptr_sfb_energy = pstr_psy_out[ch].ptr_sfb_energy;
- ptr_sfb_thr = pstr_psy_out[ch].ptr_sfb_thr;
+ sfb_count = pstr_psy_out[ch]->sfb_count;
+ scf_band_per_grp = pstr_psy_out[ch]->sfb_per_group;
+ max_sfb_per_grp = pstr_psy_out[ch]->max_sfb_per_grp;
+ ptr_sfb_energy = pstr_psy_out[ch]->ptr_sfb_energy;
+ ptr_sfb_thr = pstr_psy_out[ch]->ptr_sfb_thr;
pstr_qc_pe_chan_data = &pstr_qc_pe_data->pe_ch_data[ch];
pstr_qc_pe_chan_data->pe = 0;
pstr_qc_pe_chan_data->num_active_lines = 0;
@@ -190,7 +190,7 @@ static VOID iaace_calc_sfb_pe_data(ia_qc_pe_data_struct *pstr_qc_pe_data,
pstr_qc_pe_data->pe += pstr_qc_pe_chan_data->pe;
pstr_qc_pe_data->const_part += pstr_qc_pe_chan_data->const_part;
pstr_qc_pe_data->num_active_lines += pstr_qc_pe_chan_data->num_active_lines;
- pstr_psy_out[ch].pe = pstr_qc_pe_data->pe;
+ pstr_psy_out[ch]->pe = pstr_qc_pe_data->pe;
}
}
static FLOAT32 iaace_calc_bit_save(ia_bitres_param_struct *pstr_bitres_params, FLOAT32 fill_lvl) {
@@ -334,13 +334,13 @@ static VOID iaace_calc_pe_correction(FLOAT32 *ptr_correction_fac, const FLOAT32
static VOID iaace_calc_thr_exp(
FLOAT32 thr_exp[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
- ixheaace_psy_out_channel *pstr_psy_out, WORD32 num_chans, WORD32 chn) {
+ ixheaace_psy_out_channel **pstr_psy_out, WORD32 num_chans, WORD32 chn) {
WORD32 sfb, ch, scf_band_grp;
ixheaace_psy_out_channel *pstr_psy_chan_out;
FLOAT32 *ptr_scf_band_thr;
FLOAT32 *ptr_thr_exp;
for (ch = chn; ch < chn + num_chans; ch++) {
- pstr_psy_chan_out = &pstr_psy_out[ch];
+ pstr_psy_chan_out = pstr_psy_out[ch];
ptr_thr_exp = thr_exp[ch];
for (scf_band_grp = 0; scf_band_grp < pstr_psy_chan_out->sfb_count;
scf_band_grp += pstr_psy_chan_out->sfb_per_group) {
@@ -353,7 +353,7 @@ static VOID iaace_calc_thr_exp(
}
}
-static VOID iaace_adapt_min_snr(ixheaace_psy_out_channel *pstr_psy_out,
+static VOID iaace_adapt_min_snr(ixheaace_psy_out_channel **pstr_psy_out,
ia_min_snr_adapt_param_struct *pstr_min_snr_params,
WORD32 num_chans, WORD32 chn) {
WORD32 num_scf_band = 0, ch, scf_band_cnt, scf_band_offs, sfb;
@@ -361,7 +361,7 @@ static VOID iaace_adapt_min_snr(ixheaace_psy_out_channel *pstr_psy_out,
WORD32 i;
for (ch = chn; ch < chn + num_chans; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
num_scf_band = 0;
avg_energy = 0;
scf_band_cnt = pstr_psy_chan_out->max_sfb_per_grp;
@@ -392,8 +392,9 @@ static VOID iaace_adapt_min_snr(ixheaace_psy_out_channel *pstr_psy_out,
pstr_min_snr_params->red_offs + pstr_min_snr_params->red_ratio_fac * db_ratio;
min_snr_red = MAX(min_snr_red, pstr_min_snr_params->max_red);
pstr_psy_chan_out->sfb_min_snr[i] =
- (FLOAT32)pow(pstr_psy_out[ch].sfb_min_snr[i], min_snr_red);
- pstr_psy_chan_out->sfb_min_snr[i] = MIN(MIN_SNR_LIMIT, pstr_psy_out[ch].sfb_min_snr[i]);
+ (FLOAT32)pow(pstr_psy_out[ch]->sfb_min_snr[i], min_snr_red);
+ pstr_psy_chan_out->sfb_min_snr[i] =
+ MIN(MIN_SNR_LIMIT, pstr_psy_out[ch]->sfb_min_snr[i]);
}
}
}
@@ -402,7 +403,7 @@ static VOID iaace_adapt_min_snr(ixheaace_psy_out_channel *pstr_psy_out,
static VOID iaace_init_avoid_hole_flag(
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
- ixheaace_psy_out_channel *pstr_psy_out, ia_ah_param_struct *pstr_ah_param, WORD32 num_chans,
+ ixheaace_psy_out_channel **pstr_psy_out, ia_ah_param_struct *pstr_ah_param, WORD32 num_chans,
WORD32 chn, WORD32 aot) {
WORD32 ch;
FLOAT32 sfb_energy;
@@ -410,7 +411,7 @@ static VOID iaace_init_avoid_hole_flag(
WORD32 scf_band_grp, scf_band_cnt, scf_band;
FLOAT32 *ptr_scf_band_spread_energy, *ptr_scf_band_energy, *ptr_scf_band_min_snr;
for (ch = chn; ch < chn + num_chans; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
if (pstr_psy_chan_out->window_sequence != SHORT_WINDOW) {
switch (aot) {
@@ -442,7 +443,7 @@ static VOID iaace_init_avoid_hole_flag(
if (pstr_ah_param->modify_min_snr) {
for (ch = chn; ch < chn + num_chans; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
ptr_scf_band_energy = pstr_psy_chan_out->ptr_sfb_energy;
ptr_scf_band_min_snr = pstr_psy_chan_out->sfb_min_snr;
@@ -509,12 +510,12 @@ static VOID iaace_init_avoid_hole_flag(
}
if (num_chans == 2) {
- ixheaace_psy_out_channel *pstr_psy_out_mid = &pstr_psy_out[chn];
- ixheaace_psy_out_channel *pstr_psy_out_side = &pstr_psy_out[chn + 1];
+ ixheaace_psy_out_channel *pstr_psy_out_mid = pstr_psy_out[chn];
+ ixheaace_psy_out_channel *pstr_psy_out_side = pstr_psy_out[chn + 1];
WORD32 sfb;
for (sfb = 0; sfb < pstr_psy_out_mid->sfb_count; sfb++) {
- if (pstr_psy_out[chn].ms_used[sfb]) {
+ if (pstr_psy_out[chn]->ms_used[sfb]) {
FLOAT32 sfb_en_mid = pstr_psy_out_mid->ptr_sfb_energy[sfb];
FLOAT32 sfb_en_side = pstr_psy_out_side->ptr_sfb_energy[sfb];
FLOAT32 max_sfb_en = MAX(sfb_en_mid, sfb_en_side);
@@ -541,7 +542,7 @@ static VOID iaace_init_avoid_hole_flag(
}
for (ch = chn; ch < chn + num_chans; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
for (scf_band_grp = 0; scf_band_grp < pstr_psy_chan_out->sfb_count;
scf_band_grp += pstr_psy_chan_out->sfb_per_group) {
for (scf_band = 0; scf_band < pstr_psy_chan_out->max_sfb_per_grp; scf_band++) {
@@ -563,7 +564,7 @@ static VOID iaace_init_avoid_hole_flag(
}
static VOID iaace_reduce_thr(
- ixheaace_psy_out_channel *pstr_psy_out,
+ ixheaace_psy_out_channel **pstr_psy_out,
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
FLOAT32 thr_exp[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
const FLOAT32 red_value, WORD32 num_channels, WORD32 chn) {
@@ -572,7 +573,7 @@ static VOID iaace_reduce_thr(
FLOAT32 *ptr_sfb_energy_fix, *ptr_sfb_threshold_fix, *ptr_sfb_min_snr_fix, *ptr_thr_exp_fix;
for (ch = chn; ch < chn + num_channels; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
ptr_sfb_energy_fix = pstr_psy_chan_out->ptr_sfb_energy;
ptr_sfb_threshold_fix = pstr_psy_chan_out->ptr_sfb_thr;
ptr_sfb_min_snr_fix = pstr_psy_chan_out->sfb_min_snr;
@@ -603,14 +604,14 @@ static VOID iaace_calc_pe_no_active_holes(
FLOAT32 *ptr_pe, FLOAT32 *ptr_const_part, FLOAT32 *ptr_num_active_lines,
ia_qc_pe_data_struct *pstr_qs_pe_data,
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
- ixheaace_psy_out_channel *pstr_psy_out, WORD32 num_channels, WORD32 chn) {
+ ixheaace_psy_out_channel **pstr_psy_out, WORD32 num_channels, WORD32 chn) {
WORD32 ch, sfb_group, sfb;
*ptr_pe = 0.0f;
*ptr_const_part = 0.0f;
*ptr_num_active_lines = 0;
for (ch = chn; ch < chn + num_channels; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
ia_qc_pe_chan_data_struct *ptr_pe_chan_data = &pstr_qs_pe_data->pe_ch_data[ch];
for (sfb_group = 0; sfb_group < pstr_psy_chan_out->sfb_count;
@@ -627,7 +628,7 @@ static VOID iaace_calc_pe_no_active_holes(
}
static VOID iaace_correct_thr(
- ixheaace_psy_out_channel *pstr_psy_out,
+ ixheaace_psy_out_channel **pstr_psy_out,
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
ia_qc_pe_data_struct *pstr_qs_pe_data,
FLOAT32 thr_exp[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
@@ -644,7 +645,7 @@ static VOID iaace_correct_thr(
ia_qc_pe_chan_data_struct *pstr_pe_chan_data = NULL;
for (ch = chn; ch < chn + num_channels; ch++) {
- pstr_psy_chan_out = &pstr_psy_out[ch];
+ pstr_psy_chan_out = pstr_psy_out[ch];
pstr_pe_chan_data = &pstr_qs_pe_data->pe_ch_data[ch];
norm_factor[ch] = MIN_FLT_VAL;
ptr_thr_exp = thr_exp[ch];
@@ -669,7 +670,7 @@ static VOID iaace_correct_thr(
norm_factor[chn] = 1.0f / norm_factor[chn];
for (ch = chn; ch < chn + num_channels; ch++) {
- pstr_psy_chan_out = &pstr_psy_out[ch];
+ pstr_psy_chan_out = pstr_psy_out[ch];
pstr_pe_chan_data = &pstr_qs_pe_data->pe_ch_data[ch];
ptr_sfb_energy = pstr_psy_chan_out->ptr_sfb_energy;
ptr_sfb_thr = pstr_psy_chan_out->ptr_sfb_thr;
@@ -700,23 +701,23 @@ static VOID iaace_correct_thr(
}
static VOID iaace_reduce_min_snr(
- ixheaace_psy_out_channel *pstr_psy_out, ia_qc_pe_data_struct *pstr_qs_pe_data,
+ ixheaace_psy_out_channel **pstr_psy_out, ia_qc_pe_data_struct *pstr_qs_pe_data,
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
const FLOAT32 desired_pe, WORD32 num_channels, WORD32 chn) {
WORD32 sfb, sfb_sub_win, ch;
FLOAT32 delta_pe;
- sfb_sub_win = pstr_psy_out[chn].max_sfb_per_grp;
+ sfb_sub_win = pstr_psy_out[chn]->max_sfb_per_grp;
while (pstr_qs_pe_data->pe > desired_pe && sfb_sub_win > 0) {
sfb_sub_win--;
- for (sfb = sfb_sub_win; sfb < pstr_psy_out[chn].sfb_count;
- sfb += pstr_psy_out[chn].sfb_per_group) {
+ for (sfb = sfb_sub_win; sfb < pstr_psy_out[chn]->sfb_count;
+ sfb += pstr_psy_out[chn]->sfb_per_group) {
for (ch = chn; ch < chn + num_channels; ch++) {
- if (ah_flag[ch][sfb] != NO_AH && pstr_psy_out[ch].sfb_min_snr[sfb] < MIN_SNR_LIMIT) {
- pstr_psy_out[ch].sfb_min_snr[sfb] = MIN_SNR_LIMIT;
- pstr_psy_out[ch].ptr_sfb_thr[sfb] =
- pstr_psy_out[ch].ptr_sfb_energy[sfb] * pstr_psy_out[ch].sfb_min_snr[sfb];
+ if (ah_flag[ch][sfb] != NO_AH && pstr_psy_out[ch]->sfb_min_snr[sfb] < MIN_SNR_LIMIT) {
+ pstr_psy_out[ch]->sfb_min_snr[sfb] = MIN_SNR_LIMIT;
+ pstr_psy_out[ch]->ptr_sfb_thr[sfb] =
+ pstr_psy_out[ch]->ptr_sfb_energy[sfb] * pstr_psy_out[ch]->sfb_min_snr[sfb];
delta_pe = pstr_qs_pe_data->pe_ch_data[ch].sfb_lines[sfb] * 1.5f -
pstr_qs_pe_data->pe_ch_data[ch].sfb_pe[sfb];
pstr_qs_pe_data->pe += delta_pe;
@@ -731,7 +732,7 @@ static VOID iaace_reduce_min_snr(
}
static VOID iaace_allow_more_holes(
- ixheaace_psy_out_channel *pstr_psy_out, ia_qc_pe_data_struct *pstr_qs_pe_data,
+ ixheaace_psy_out_channel **pstr_psy_out, ia_qc_pe_data_struct *pstr_qs_pe_data,
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
const ia_ah_param_struct *pstr_str_ah_param, const FLOAT32 desired_pe, WORD32 num_channels,
WORD32 chn) {
@@ -739,12 +740,12 @@ static VOID iaace_allow_more_holes(
FLOAT32 act_pe = pstr_qs_pe_data->pe;
if (num_channels == 2 &&
- pstr_psy_out[chn].window_sequence == pstr_psy_out[chn + 1].window_sequence) {
- ixheaace_psy_out_channel *pstr_psy_out_left = &pstr_psy_out[chn];
- ixheaace_psy_out_channel *pstr_psy_out_right = &pstr_psy_out[chn + 1];
+ pstr_psy_out[chn]->window_sequence == pstr_psy_out[chn + 1]->window_sequence) {
+ ixheaace_psy_out_channel *pstr_psy_out_left = pstr_psy_out[chn];
+ ixheaace_psy_out_channel *pstr_psy_out_right = pstr_psy_out[chn + 1];
for (sfb = 0; sfb < pstr_psy_out_left->sfb_count; sfb++) {
- if (pstr_psy_out[chn].ms_used[sfb]) {
+ if (pstr_psy_out[chn]->ms_used[sfb]) {
if (ah_flag[chn + 1][sfb] != NO_AH &&
0.4f * pstr_psy_out_left->sfb_min_snr[sfb] * pstr_psy_out_left->ptr_sfb_energy[sfb] >
pstr_psy_out_right->ptr_sfb_energy[sfb]) {
@@ -780,7 +781,7 @@ static VOID iaace_allow_more_holes(
WORD32 done;
for (ch = chn; ch < chn + num_channels; ch++) {
- if (pstr_psy_out[ch].window_sequence != SHORT_WINDOW) {
+ if (pstr_psy_out[ch]->window_sequence != SHORT_WINDOW) {
start_sfb[ch] = pstr_str_ah_param->start_sfb_long;
} else {
start_sfb[ch] = pstr_str_ah_param->start_sfb_short;
@@ -791,7 +792,7 @@ static VOID iaace_allow_more_holes(
min_energy = MAX_FLT_VAL;
ah_cnt = 0;
for (ch = chn; ch < chn + num_channels; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
for (sfb = start_sfb[ch]; sfb < pstr_psy_chan_out->sfb_count; sfb++) {
if ((ah_flag[ch][sfb] != NO_AH) &&
(pstr_psy_chan_out->ptr_sfb_energy[sfb] > pstr_psy_chan_out->ptr_sfb_thr[sfb])) {
@@ -808,11 +809,11 @@ static VOID iaace_allow_more_holes(
energy[en_idx] = min_energy * (FLOAT32)pow(average_energy / (min_energy + MIN_FLT_VAL),
(2 * en_idx + 1) / 7.0f);
}
- max_sfb = pstr_psy_out[chn].sfb_count - 1;
+ max_sfb = pstr_psy_out[chn]->sfb_count - 1;
min_sfb = start_sfb[chn];
if (num_channels == 2) {
- max_sfb = MAX(max_sfb, pstr_psy_out[chn + 1].sfb_count - 1);
+ max_sfb = MAX(max_sfb, pstr_psy_out[chn + 1]->sfb_count - 1);
min_sfb = MIN(min_sfb, start_sfb[chn + 1]);
}
@@ -822,7 +823,7 @@ static VOID iaace_allow_more_holes(
done = 0;
while (!done) {
for (ch = chn; ch < chn + num_channels; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
if (sfb >= start_sfb[ch] && sfb < pstr_psy_chan_out->sfb_count) {
if (ah_flag[ch][sfb] != NO_AH &&
pstr_psy_chan_out->ptr_sfb_energy[sfb] < energy[en_idx]) {
@@ -850,7 +851,7 @@ static VOID iaace_allow_more_holes(
}
static VOID iaace_adapt_thr_to_pe(
- ixheaace_psy_out_channel pstr_psy_out[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **pstr_psy_out,
ia_qc_pe_data_struct *pstr_qs_pe_data, const FLOAT32 desired_pe,
ia_ah_param_struct *pstr_ah_param, ia_min_snr_adapt_param_struct *pstr_msa_param,
WORD32 num_channels, WORD32 chn, WORD32 aot) {
@@ -918,7 +919,7 @@ static VOID iaace_adapt_thr_to_pe(
VOID iaace_adjust_threshold(ia_adj_thr_state_struct *pstr_adj_thr_state,
ia_adj_thr_elem_struct *pstr_adj_thr_elem,
- ixheaace_psy_out_channel pstr_psy_out[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **pstr_psy_out,
FLOAT32 *ptr_ch_bit_dist, ixheaace_qc_out_element *pstr_qc_out_el,
const WORD32 avg_bits, const WORD32 bitres_bits,
const WORD32 max_bitres_bits, const WORD32 side_info_bits,
@@ -945,12 +946,12 @@ VOID iaace_adjust_threshold(ia_adj_thr_state_struct *pstr_adj_thr_state,
curr_win_sequence = LONG_WINDOW;
if (num_channels == 2) {
- if ((pstr_psy_out[chn].window_sequence == SHORT_WINDOW) ||
- (pstr_psy_out[chn + 1].window_sequence == SHORT_WINDOW)) {
+ if ((pstr_psy_out[chn]->window_sequence == SHORT_WINDOW) ||
+ (pstr_psy_out[chn + 1]->window_sequence == SHORT_WINDOW)) {
curr_win_sequence = SHORT_WINDOW;
}
} else {
- curr_win_sequence = pstr_psy_out[chn].window_sequence;
+ curr_win_sequence = pstr_psy_out[chn]->window_sequence;
}
bit_factor = iaace_bitres_calc_bitfac(
diff --git a/encoder/ixheaace_adjust_threshold.h b/encoder/ixheaace_adjust_threshold.h
index e18855f..b538b9d 100644
--- a/encoder/ixheaace_adjust_threshold.h
+++ b/encoder/ixheaace_adjust_threshold.h
@@ -45,7 +45,7 @@ VOID iaace_adj_thr_init(ia_adj_thr_state_struct *pstr_adj_thr_state, const FLOAT
VOID iaace_adjust_threshold(ia_adj_thr_state_struct *pstr_adj_thr_state,
ia_adj_thr_elem_struct *pstr_adj_thr_elem,
- ixheaace_psy_out_channel pstr_psy_out[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **pstr_psy_out,
FLOAT32 *ptr_ch_bit_dist, ixheaace_qc_out_element *pstr_qc_out_el,
const WORD32 avg_bits, const WORD32 bitres_bits,
const WORD32 max_bitres_bits, const WORD32 side_info_bits,
diff --git a/encoder/ixheaace_enc_init.c b/encoder/ixheaace_enc_init.c
index c744297..5abcb2a 100644
--- a/encoder/ixheaace_enc_init.c
+++ b/encoder/ixheaace_enc_init.c
@@ -155,18 +155,23 @@ static VOID ixheaace_determine_bandwidth(const WORD32 proposed_bandwidth, const
WORD32 ia_enhaacplus_enc_aac_enc_pers_size(WORD32 num_aac_chan, WORD32 aot) {
WORD32 num_bytes;
- num_bytes = sizeof(iexheaac_encoder_str);
- num_bytes += num_aac_chan * sizeof(ixheaace_psy_out_channel);
- num_bytes += num_aac_chan * sizeof(ixheaace_psy_data);
- num_bytes += num_aac_chan * sizeof(ixheaace_temporal_noise_shaping_data);
+ num_bytes = IXHEAACE_GET_SIZE_ALIGNED(sizeof(iexheaac_encoder_str), BYTE_ALIGN_8);
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_psy_out_channel), BYTE_ALIGN_8));
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_psy_data), BYTE_ALIGN_8));
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_temporal_noise_shaping_data), BYTE_ALIGN_8));
if (aot == AOT_AAC_LC || aot == AOT_SBR || aot == AOT_PS) {
- num_bytes += num_aac_chan * BLK_SWITCH_OFFSET_LC_128 * sizeof(FLOAT32);
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(BLK_SWITCH_OFFSET_LC_128 * sizeof(FLOAT32), BYTE_ALIGN_8));
} else if (aot == AOT_AAC_LD || aot == AOT_AAC_ELD) {
- num_bytes += num_aac_chan * BLK_SWITCH_OFFSET_LD * sizeof(FLOAT32);
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(BLK_SWITCH_OFFSET_LD * sizeof(FLOAT32), BYTE_ALIGN_8));
}
- num_bytes += num_aac_chan * sizeof(ixheaace_qc_out_channel);
- num_bytes = IXHEAACE_GET_SIZE_ALIGNED(num_bytes, BYTE_ALIGN_8);
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_qc_out_channel), BYTE_ALIGN_8));
return num_bytes;
}
@@ -219,25 +224,29 @@ VOID ia_enhaacplus_enc_init_aac_tabs(ixheaace_aac_tables *pstr_aac_tabs) {
static VOID ia_enhaacplus_enc_aac_set_persist_buf(WORD8 *ptr_base, WORD32 num_chan, WORD32 aot) {
iexheaac_encoder_str *pstr_exheaac_encoder;
- WORD8 *ptr_curr_mem = (WORD8 *)((WORD8 *)ptr_base + sizeof(iexheaac_encoder_str));
+ WORD8 *ptr_curr_mem = ptr_base +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(iexheaac_encoder_str), BYTE_ALIGN_8);
WORD32 i;
pstr_exheaac_encoder = (iexheaac_encoder_str *)ptr_base;
for (i = 0; i < num_chan; i++) {
pstr_exheaac_encoder->psy_out.psy_out_ch[i] = (ixheaace_psy_out_channel *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_psy_out_channel);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_psy_out_channel), BYTE_ALIGN_8);
}
for (i = 0; i < num_chan; i++) {
pstr_exheaac_encoder->psy_kernel.psy_data[i] = (ixheaace_psy_data *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_psy_data);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_psy_data), BYTE_ALIGN_8);
}
for (i = 0; i < num_chan; i++) {
pstr_exheaac_encoder->psy_kernel.temporal_noise_shaping_data[i] =
(ixheaace_temporal_noise_shaping_data *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_temporal_noise_shaping_data);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_temporal_noise_shaping_data), BYTE_ALIGN_8);
}
for (i = 0; i < num_chan; i++) {
@@ -247,21 +256,24 @@ static VOID ia_enhaacplus_enc_aac_set_persist_buf(WORD8 *ptr_base, WORD32 num_ch
case AOT_PS:
pstr_exheaac_encoder->psy_kernel.psy_data[i]->ptr_mdct_delay_buf =
(FLOAT32 *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(FLOAT32) * BLK_SWITCH_OFFSET_LC_128;
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(FLOAT32) * BLK_SWITCH_OFFSET_LC_128, BYTE_ALIGN_8);
break;
case AOT_AAC_LD:
case AOT_AAC_ELD:
pstr_exheaac_encoder->psy_kernel.psy_data[i]->ptr_mdct_delay_buf =
(FLOAT32 *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(FLOAT32) * BLK_SWITCH_OFFSET_LD;
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(FLOAT32) * BLK_SWITCH_OFFSET_LD, BYTE_ALIGN_8);
break;
}
}
for (i = 0; i < num_chan; i++) {
pstr_exheaac_encoder->qc_out.qc_channel[i] = (ixheaace_qc_out_channel *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_qc_out_channel);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_qc_out_channel), BYTE_ALIGN_8);
}
}
diff --git a/encoder/ixheaace_enc_main.c b/encoder/ixheaace_enc_main.c
index 1c25924..46c7bd5 100644
--- a/encoder/ixheaace_enc_main.c
+++ b/encoder/ixheaace_enc_main.c
@@ -136,11 +136,10 @@ IA_ERRORCODE ia_enhaacplus_enc_aac_core_encode(
err_code = ia_enhaacplus_enc_psy_main(
time_sn_stride, pstr_element_info, ptr_time_signal, aot,
- pstr_aac_encoder->psy_kernel.psy_data[pstr_element_info->channel_index[0]],
- pstr_aac_encoder->psy_kernel
- .temporal_noise_shaping_data[pstr_element_info->channel_index[0]],
+ pstr_aac_encoder->psy_kernel.psy_data,
+ pstr_aac_encoder->psy_kernel.temporal_noise_shaping_data,
&pstr_aac_encoder->psy_kernel.psy_conf_long, &pstr_aac_encoder->psy_kernel.psy_conf_short,
- pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]],
+ pstr_aac_encoder->psy_out.psy_out_ch,
&pstr_aac_encoder->psy_out.psy_out_element,
pstr_aac_encoder->psy_kernel.p_scratch_tns_float,
(FLOAT32 *)pstr_aac_encoder->pstr_aac_scratch->shared_buffer1,
@@ -155,23 +154,22 @@ IA_ERRORCODE ia_enhaacplus_enc_aac_core_encode(
pstr_aac_encoder->config.core_sample_rate, flag_last_element, frame_len_long);
for (ch = 0; ch < pstr_element_info->n_channels_in_el; ch++) {
- pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]][ch].ms_digest =
+ pstr_aac_encoder->psy_out.psy_out_ch[ch]->ms_digest =
pstr_aac_encoder->psy_out.psy_out_element.tools_info.ms_digest;
memcpy(
- &pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]][ch].ms_used[0],
+ &pstr_aac_encoder->psy_out.psy_out_ch[ch]->ms_used[0],
&pstr_aac_encoder->psy_out.psy_out_element.tools_info.ms_mask[0],
MAXIMUM_GROUPED_SCALE_FACTOR_BAND *
- sizeof(pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]][ch]
- .ms_used[0]));
+ sizeof(pstr_aac_encoder->psy_out.psy_out_ch[ch]->ms_used[0]));
}
err_code = ia_enhaacplus_enc_qc_main(
&pstr_aac_encoder->qc_kernel, pstr_element_info->n_channels_in_el,
&pstr_aac_encoder->qc_kernel.element_bits,
- pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]],
+ pstr_aac_encoder->psy_out.psy_out_ch,
&pstr_aac_encoder->psy_out.psy_out_element,
- pstr_aac_encoder->qc_out.qc_channel[pstr_element_info->channel_index[0]],
+ pstr_aac_encoder->qc_out.qc_channel,
&pstr_aac_encoder->qc_out.qc_element, MIN(anc_data_bytes_left, anc_data_bytes),
pstr_aac_tabs, adts_flag, aot, stat_bits_flag, flag_last_element, frame_len_long,
pstr_aac_encoder->pstr_aac_scratch->shared_buffer5, is_quant_spec_zero,
@@ -184,7 +182,7 @@ IA_ERRORCODE ia_enhaacplus_enc_aac_core_encode(
if (pstr_element_info->el_type == ID_CPE) {
if (!pstr_aac_encoder->config.num_stereo_preprocessing) {
iaace_update_stereo_pre_process(
- pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]],
+ pstr_aac_encoder->psy_out.psy_out_ch,
&pstr_aac_encoder->qc_out.qc_element, &pstr_aac_encoder->str_stereo_pre_pro,
pstr_aac_encoder->psy_out.psy_out_element.weight_ms_lr_pe_ratio);
}
diff --git a/encoder/ixheaace_fd_quant.c b/encoder/ixheaace_fd_quant.c
index 4be4670..6d43ab1 100644
--- a/encoder/ixheaace_fd_quant.c
+++ b/encoder/ixheaace_fd_quant.c
@@ -170,7 +170,7 @@ static WORD32 iusace_count_static_bits(ia_usac_data_struct *ptr_usac_data,
stat_bits += ptr_usac_data->str_scratch.ptr_num_fac_bits[i];
}
- stat_bits += ptr_usac_data->num_sbr_bits;
+ stat_bits += (ptr_usac_data->num_sbr_bits + ptr_usac_data->num_drc_bits);
return stat_bits;
}
diff --git a/encoder/ixheaace_ms_stereo.c b/encoder/ixheaace_ms_stereo.c
index bf2f1e2..48ecfce 100644
--- a/encoder/ixheaace_ms_stereo.c
+++ b/encoder/ixheaace_ms_stereo.c
@@ -45,19 +45,19 @@
#include "ixheaace_ms_stereo.h"
#include "ixheaace_common_utils.h"
-VOID iaace_ms_apply(ixheaace_psy_data *ptr_psy_data, FLOAT32 *ptr_spec_left,
+VOID iaace_ms_apply(ixheaace_psy_data **ptr_psy_data, FLOAT32 *ptr_spec_left,
FLOAT32 *ptr_spec_right, WORD32 *ptr_ms_select, WORD32 *ptr_ms_used,
const WORD32 sfb_count, const WORD32 sfb_per_group,
const WORD32 max_sfb_per_grp, const WORD32 *ptr_sfb_offset,
FLOAT32 *ptr_weight_ms_lr_pe_ratio) {
- FLOAT32 *ptr_sfb_enegry_left = ptr_psy_data[0].sfb_energy.long_nrg;
- FLOAT32 *ptr_sfb_energy_right = ptr_psy_data[1].sfb_energy.long_nrg;
- const FLOAT32 *ptr_sfb_energy_mid = ptr_psy_data[0].sfb_energy_ms.long_nrg;
- const FLOAT32 *ptr_sfb_energy_side = ptr_psy_data[1].sfb_energy_ms.long_nrg;
- FLOAT32 *ptr_sfb_thr_left = ptr_psy_data[0].sfb_threshold.long_nrg;
- FLOAT32 *ptr_sfb_thr_right = ptr_psy_data[1].sfb_threshold.long_nrg;
- FLOAT32 *ptr_sfb_spread_energy_left = ptr_psy_data[0].sfb_sreaded_energy.long_nrg;
- FLOAT32 *ptr_sfb_spread_energy_right = ptr_psy_data[1].sfb_sreaded_energy.long_nrg;
+ FLOAT32 *ptr_sfb_enegry_left = ptr_psy_data[0]->sfb_energy.long_nrg;
+ FLOAT32 *ptr_sfb_energy_right = ptr_psy_data[1]->sfb_energy.long_nrg;
+ const FLOAT32 *ptr_sfb_energy_mid = ptr_psy_data[0]->sfb_energy_ms.long_nrg;
+ const FLOAT32 *ptr_sfb_energy_side = ptr_psy_data[1]->sfb_energy_ms.long_nrg;
+ FLOAT32 *ptr_sfb_thr_left = ptr_psy_data[0]->sfb_threshold.long_nrg;
+ FLOAT32 *ptr_sfb_thr_right = ptr_psy_data[1]->sfb_threshold.long_nrg;
+ FLOAT32 *ptr_sfb_spread_energy_left = ptr_psy_data[0]->sfb_sreaded_energy.long_nrg;
+ FLOAT32 *ptr_sfb_spread_energy_right = ptr_psy_data[1]->sfb_sreaded_energy.long_nrg;
WORD32 sfb, sfb_offsets, j;
WORD32 grp = 0;
WORD32 ms_counter = 0;
diff --git a/encoder/ixheaace_ms_stereo.h b/encoder/ixheaace_ms_stereo.h
index 12e7425..834b1ad 100644
--- a/encoder/ixheaace_ms_stereo.h
+++ b/encoder/ixheaace_ms_stereo.h
@@ -20,7 +20,7 @@
#pragma once
-VOID iaace_ms_apply(ixheaace_psy_data *ptr_psy_data, FLOAT32 *ptr_spec_left,
+VOID iaace_ms_apply(ixheaace_psy_data **ptr_psy_data, FLOAT32 *ptr_spec_left,
FLOAT32 *ptr_spec_right, WORD32 *ptr_ms_select, WORD32 *ptr_ms_used,
const WORD32 sfb_count,
diff --git a/encoder/ixheaace_psy_mod.c b/encoder/ixheaace_psy_mod.c
index 013c1db..02ef9ca 100644
--- a/encoder/ixheaace_psy_mod.c
+++ b/encoder/ixheaace_psy_mod.c
@@ -174,17 +174,17 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main_init(ixheaace_psy_kernel *pstr_h_psy, WO
}
static VOID ia_enhaacplus_enc_advance_psy_long_ms(
- ixheaace_psy_data psy_data[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_data **psy_data,
ixheaace_psy_configuration_long *pstr_psy_conf_long) {
ia_enhaacplus_enc_calc_band_energy_ms(
- psy_data[0].ptr_spec_coeffs, psy_data[1].ptr_spec_coeffs, pstr_psy_conf_long->sfb_offsets,
+ psy_data[0]->ptr_spec_coeffs, psy_data[1]->ptr_spec_coeffs, pstr_psy_conf_long->sfb_offsets,
pstr_psy_conf_long->sfb_active, pstr_psy_conf_long->sfb_cnt,
- psy_data[0].sfb_energy_ms.long_nrg, &psy_data[0].sfb_energy_sum_ms.long_nrg,
- psy_data[1].sfb_energy_ms.long_nrg, &psy_data[1].sfb_energy_sum_ms.long_nrg);
+ psy_data[0]->sfb_energy_ms.long_nrg, &psy_data[0]->sfb_energy_sum_ms.long_nrg,
+ psy_data[1]->sfb_energy_ms.long_nrg, &psy_data[1]->sfb_energy_sum_ms.long_nrg);
}
static VOID ia_enhaacplus_enc_advance_psy_short_ms(
- ixheaace_psy_data psy_data[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_data **psy_data,
ixheaace_psy_configuration_short *pstr_psy_conf_short, WORD32 ccfl) {
WORD32 w;
WORD32 frame_len_short = FRAME_LEN_SHORT_128;
@@ -196,11 +196,11 @@ static VOID ia_enhaacplus_enc_advance_psy_short_ms(
WORD32 w_offset = w * frame_len_short;
ia_enhaacplus_enc_calc_band_energy_ms(
- psy_data[0].ptr_spec_coeffs + w_offset, psy_data[1].ptr_spec_coeffs + w_offset,
+ psy_data[0]->ptr_spec_coeffs + w_offset, psy_data[1]->ptr_spec_coeffs + w_offset,
pstr_psy_conf_short->sfb_offsets, pstr_psy_conf_short->sfb_active,
- pstr_psy_conf_short->sfb_cnt, psy_data[0].sfb_energy_ms.short_nrg[w],
- &psy_data[0].sfb_energy_sum_ms.short_nrg[w], psy_data[1].sfb_energy_ms.short_nrg[w],
- &psy_data[1].sfb_energy_sum_ms.short_nrg[w]);
+ pstr_psy_conf_short->sfb_cnt, psy_data[0]->sfb_energy_ms.short_nrg[w],
+ &psy_data[0]->sfb_energy_sum_ms.short_nrg[w], psy_data[1]->sfb_energy_ms.short_nrg[w],
+ &psy_data[1]->sfb_energy_sum_ms.short_nrg[w]);
}
}
@@ -461,11 +461,11 @@ static IA_ERRORCODE ia_enhaacplus_enc_advance_psy_long(
IA_ERRORCODE ia_enhaacplus_enc_psy_main(
WORD32 time_sn_stride, ixheaace_element_info *pstr_elem_info, const FLOAT32 *ptr_time_signal,
- WORD32 aot, ixheaace_psy_data psy_data[IXHEAACE_MAX_CH_IN_BS_ELE],
- ixheaace_temporal_noise_shaping_data tns_data[IXHEAACE_MAX_CH_IN_BS_ELE],
+ WORD32 aot, ixheaace_psy_data **psy_data,
+ ixheaace_temporal_noise_shaping_data **tns_data,
ixheaace_psy_configuration_long *pstr_psy_conf_long,
ixheaace_psy_configuration_short *pstr_psy_conf_short,
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element, FLOAT32 *ptr_scratch_tns,
FLOAT32 *ptr_shared_buffer1, WORD8 *ptr_shared_buffer5, ixheaace_aac_tables *pstr_aac_tables,
WORD32 frame_len_long)
@@ -482,66 +482,71 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
if (aot == AOT_AAC_LC || aot == AOT_SBR || aot == AOT_PS) {
if (pstr_elem_info->el_type != ID_LFE) {
for (ch = 0; ch < num_channels; ch++) {
- iaace_block_switching(&psy_data[ch].blk_switch_cntrl,
+ iaace_block_switching(&psy_data[ch]->blk_switch_cntrl,
ptr_time_signal + pstr_elem_info->channel_index[ch], frame_len_long,
num_channels);
}
} else {
- psy_data[0].blk_switch_cntrl.win_seq = psy_data[1].blk_switch_cntrl.win_seq = LONG_WINDOW;
+ for (ch = 0; ch < num_channels; ch++) {
+ psy_data[ch]->blk_switch_cntrl.win_seq = LONG_WINDOW;
+ }
}
/* synch left and right block type */
- iaace_sync_block_switching(&psy_data[0].blk_switch_cntrl, &psy_data[1].blk_switch_cntrl,
- num_channels);
+ if (num_channels == NUM_CHANS_MONO) {
+ iaace_sync_block_switching(&psy_data[0]->blk_switch_cntrl, NULL, num_channels);
+ }
+ else {
+ iaace_sync_block_switching(&psy_data[0]->blk_switch_cntrl, &psy_data[1]->blk_switch_cntrl,
+ num_channels);
+ }
} else if (aot == AOT_AAC_LD || aot == AOT_AAC_ELD) {
- { psy_data[0].blk_switch_cntrl.win_seq = psy_data[1].blk_switch_cntrl.win_seq = LONG_WINDOW; }
-
for (ch = 0; ch < num_channels; ch++) {
- psy_data[ch].blk_switch_cntrl.win_seq_ld = LONG_WINDOW;
- psy_data[ch].blk_switch_cntrl.next_win_seq_ld = LONG_WINDOW;
- psy_data[ch].blk_switch_cntrl.win_seq = LONG_WINDOW;
- psy_data[ch].blk_switch_cntrl.nxt_win_seq = LONG_WINDOW;
- psy_data[ch].blk_switch_cntrl.total_groups_cnt = 1;
+ psy_data[ch]->blk_switch_cntrl.win_seq_ld = LONG_WINDOW;
+ psy_data[ch]->blk_switch_cntrl.next_win_seq_ld = LONG_WINDOW;
+ psy_data[ch]->blk_switch_cntrl.win_seq = LONG_WINDOW;
+ psy_data[ch]->blk_switch_cntrl.nxt_win_seq = LONG_WINDOW;
+ psy_data[ch]->blk_switch_cntrl.total_groups_cnt = 1;
}
}
/* transform */
for (ch = 0; ch < num_channels; ch++) {
if (aot == AOT_AAC_LC || aot == AOT_SBR || aot == AOT_PS) {
ixheaace_transform_real_lc_ld(
- psy_data[ch].ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
- time_sn_stride, psy_data[ch].ptr_spec_coeffs, psy_data[ch].blk_switch_cntrl.win_seq,
+ psy_data[ch]->ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
+ time_sn_stride, psy_data[ch]->ptr_spec_coeffs, psy_data[ch]->blk_switch_cntrl.win_seq,
frame_len_long, ptr_shared_buffer5);
} else if (aot == AOT_AAC_LD) {
if (frame_len_long == FRAME_LEN_480) {
ia_enhaacplus_enc_transform_real(
- psy_data[ch].ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
- time_sn_stride, psy_data[ch].ptr_spec_coeffs, pstr_aac_tables->pstr_mdct_tab,
+ psy_data[ch]->ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
+ time_sn_stride, psy_data[ch]->ptr_spec_coeffs, pstr_aac_tables->pstr_mdct_tab,
ptr_scratch_tns, ptr_shared_buffer5, frame_len_long);
} else {
ixheaace_transform_real_lc_ld(
- psy_data[ch].ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
- time_sn_stride, psy_data[ch].ptr_spec_coeffs, psy_data[ch].blk_switch_cntrl.win_seq,
+ psy_data[ch]->ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
+ time_sn_stride, psy_data[ch]->ptr_spec_coeffs, psy_data[ch]->blk_switch_cntrl.win_seq,
frame_len_long, ptr_shared_buffer5);
}
} else if (aot == AOT_AAC_ELD) {
if (frame_len_long == FRAME_LEN_480) {
ia_enhaacplus_enc_transform_real(
- psy_data[ch].ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
- time_sn_stride, psy_data[ch].ptr_spec_coeffs, pstr_aac_tables->pstr_mdct_tab,
+ psy_data[ch]->ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
+ time_sn_stride, psy_data[ch]->ptr_spec_coeffs, pstr_aac_tables->pstr_mdct_tab,
ptr_scratch_tns, ptr_shared_buffer5, frame_len_long);
} else {
ia_enhaacplus_enc_transform_real_eld(
- psy_data[ch].ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
- time_sn_stride, psy_data[ch].ptr_spec_coeffs, ptr_shared_buffer5, frame_len_long);
+ psy_data[ch]->ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
+ time_sn_stride, psy_data[ch]->ptr_spec_coeffs, ptr_shared_buffer5, frame_len_long);
}
}
}
for (ch = 0; ch < num_channels; ch++) {
- if (psy_data[ch].blk_switch_cntrl.win_seq != SHORT_WINDOW) {
+ if (psy_data[ch]->blk_switch_cntrl.win_seq != SHORT_WINDOW) {
error_code = ia_enhaacplus_enc_advance_psy_long(
- &psy_data[ch], &tns_data[ch], pstr_psy_conf_long, &psy_out_ch[ch], ptr_scratch_tns,
- &tns_data[1 - ch], ch, aot, ptr_shared_buffer1, pstr_aac_tables, frame_len_long);
+ psy_data[ch], tns_data[ch], pstr_psy_conf_long, psy_out_ch[ch], ptr_scratch_tns,
+ tns_data[1 - ch], ch, aot, ptr_shared_buffer1, pstr_aac_tables, frame_len_long);
if (error_code != IA_NO_ERROR) {
return error_code;
@@ -550,7 +555,7 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
for (sfb = pstr_psy_conf_long->sfb_cnt - 1; sfb >= 0; sfb--) {
for (line = pstr_psy_conf_long->sfb_offsets[sfb + 1] - 1;
line >= pstr_psy_conf_long->sfb_offsets[sfb]; line--) {
- if (psy_data[ch].ptr_spec_coeffs[line] != 0) {
+ if (psy_data[ch]->ptr_spec_coeffs[line] != 0) {
break;
}
}
@@ -567,8 +572,8 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
}
} else {
error_code = ia_enhaacplus_enc_advance_psy_short(
- &psy_data[ch], &tns_data[ch], pstr_psy_conf_short, &psy_out_ch[ch], ptr_scratch_tns,
- &tns_data[1 - ch], ch, aot, ptr_shared_buffer1, pstr_aac_tables, frame_len_long / 8);
+ psy_data[ch], tns_data[ch], pstr_psy_conf_short, psy_out_ch[ch], ptr_scratch_tns,
+ tns_data[1 - ch], ch, aot, ptr_shared_buffer1, pstr_aac_tables, frame_len_long / 8);
if (error_code != IA_NO_ERROR) {
return error_code;
@@ -584,15 +589,15 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
/* Group short data (max_sfb for short blocks is determined here) */
if (aot == AOT_AAC_LC || aot == AOT_SBR || aot == AOT_PS) {
for (ch = 0; ch < num_channels; ch++) {
- if (psy_data[ch].blk_switch_cntrl.win_seq == SHORT_WINDOW) {
- iaace_group_short_data(psy_data[ch].ptr_spec_coeffs, ptr_scratch_tns,
- &psy_data[ch].sfb_threshold, &psy_data[ch].sfb_energy,
- &psy_data[ch].sfb_energy_ms, &psy_data[ch].sfb_sreaded_energy,
+ if (psy_data[ch]->blk_switch_cntrl.win_seq == SHORT_WINDOW) {
+ iaace_group_short_data(psy_data[ch]->ptr_spec_coeffs, ptr_scratch_tns,
+ &psy_data[ch]->sfb_threshold, &psy_data[ch]->sfb_energy,
+ &psy_data[ch]->sfb_energy_ms, &psy_data[ch]->sfb_sreaded_energy,
pstr_psy_conf_short->sfb_cnt, pstr_psy_conf_short->sfb_offsets,
pstr_psy_conf_short->sfb_min_snr, grouped_sfb_offset[ch],
&max_sfb_per_grp[ch], grouped_sfb_min_snr[ch],
- psy_data[ch].blk_switch_cntrl.total_groups_cnt,
- psy_data[ch].blk_switch_cntrl.group_len, frame_len_long);
+ psy_data[ch]->blk_switch_cntrl.total_groups_cnt,
+ psy_data[ch]->blk_switch_cntrl.group_len, frame_len_long);
}
}
}
@@ -604,17 +609,18 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
max_sfb_per_grp[0] = max_sfb_per_grp[1] = MAX(max_sfb_per_grp[0], max_sfb_per_grp[1]);
- if (psy_data[0].blk_switch_cntrl.win_seq != SHORT_WINDOW) {
+ if (psy_data[0]->blk_switch_cntrl.win_seq != SHORT_WINDOW) {
iaace_ms_apply(
- psy_data, psy_data[0].ptr_spec_coeffs, psy_data[1].ptr_spec_coeffs,
+ psy_data, psy_data[0]->ptr_spec_coeffs, psy_data[1]->ptr_spec_coeffs,
&pstr_psy_out_element->tools_info.ms_digest, pstr_psy_out_element->tools_info.ms_mask,
pstr_psy_conf_long->sfb_cnt, pstr_psy_conf_long->sfb_cnt, max_sfb_per_grp[0],
pstr_psy_conf_long->sfb_offsets, &pstr_psy_out_element->weight_ms_lr_pe_ratio);
} else {
- iaace_ms_apply(psy_data, psy_data[0].ptr_spec_coeffs, psy_data[1].ptr_spec_coeffs,
+ iaace_ms_apply(psy_data, psy_data[0]->ptr_spec_coeffs, psy_data[1]->ptr_spec_coeffs,
&pstr_psy_out_element->tools_info.ms_digest,
pstr_psy_out_element->tools_info.ms_mask,
- psy_data[0].blk_switch_cntrl.total_groups_cnt * pstr_psy_conf_short->sfb_cnt,
+ psy_data[0]->blk_switch_cntrl.total_groups_cnt *
+ pstr_psy_conf_short->sfb_cnt,
pstr_psy_conf_short->sfb_cnt, max_sfb_per_grp[0], grouped_sfb_offset[0],
&pstr_psy_out_element->weight_ms_lr_pe_ratio);
}
@@ -624,39 +630,41 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
/* Build output */
if (aot == AOT_AAC_LC || aot == AOT_SBR || aot == AOT_PS) {
for (ch = 0; ch < num_channels; ch++) {
- if (psy_data[ch].blk_switch_cntrl.win_seq != SHORT_WINDOW) {
+ if (psy_data[ch]->blk_switch_cntrl.win_seq != SHORT_WINDOW) {
ia_enhaacplus_enc_build_interface(
- psy_data[ch].ptr_spec_coeffs, &psy_data[ch].sfb_threshold, &psy_data[ch].sfb_energy,
- &psy_data[ch].sfb_sreaded_energy, psy_data[ch].sfb_energy_sum,
- psy_data[ch].sfb_energy_sum_ms, psy_data[ch].blk_switch_cntrl.win_seq,
+ psy_data[ch]->ptr_spec_coeffs, &psy_data[ch]->sfb_threshold,
+ &psy_data[ch]->sfb_energy,
+ &psy_data[ch]->sfb_sreaded_energy, psy_data[ch]->sfb_energy_sum,
+ psy_data[ch]->sfb_energy_sum_ms, psy_data[ch]->blk_switch_cntrl.win_seq,
ia_enhaacplus_enc_block_type_to_window_shape_lc[psy_data[ch]
- .blk_switch_cntrl.win_seq],
+ ->blk_switch_cntrl.win_seq],
pstr_psy_conf_long->sfb_cnt, pstr_psy_conf_long->sfb_offsets, max_sfb_per_grp[ch],
- pstr_psy_conf_long->sfb_min_snr, psy_data[ch].blk_switch_cntrl.total_groups_cnt,
- psy_data[ch].blk_switch_cntrl.group_len, &psy_out_ch[ch]);
+ pstr_psy_conf_long->sfb_min_snr, psy_data[ch]->blk_switch_cntrl.total_groups_cnt,
+ psy_data[ch]->blk_switch_cntrl.group_len, psy_out_ch[ch]);
} else {
ia_enhaacplus_enc_build_interface(
- psy_data[ch].ptr_spec_coeffs, &psy_data[ch].sfb_threshold, &psy_data[ch].sfb_energy,
- &psy_data[ch].sfb_sreaded_energy, psy_data[ch].sfb_energy_sum,
- psy_data[ch].sfb_energy_sum_ms, SHORT_WINDOW, SINE_WINDOW,
- psy_data[ch].blk_switch_cntrl.total_groups_cnt * pstr_psy_conf_short->sfb_cnt,
+ psy_data[ch]->ptr_spec_coeffs, &psy_data[ch]->sfb_threshold,
+ &psy_data[ch]->sfb_energy,
+ &psy_data[ch]->sfb_sreaded_energy, psy_data[ch]->sfb_energy_sum,
+ psy_data[ch]->sfb_energy_sum_ms, SHORT_WINDOW, SINE_WINDOW,
+ psy_data[ch]->blk_switch_cntrl.total_groups_cnt * pstr_psy_conf_short->sfb_cnt,
grouped_sfb_offset[ch], max_sfb_per_grp[ch], grouped_sfb_min_snr[ch],
- psy_data[ch].blk_switch_cntrl.total_groups_cnt,
- psy_data[ch].blk_switch_cntrl.group_len, &psy_out_ch[ch]);
+ psy_data[ch]->blk_switch_cntrl.total_groups_cnt,
+ psy_data[ch]->blk_switch_cntrl.group_len, psy_out_ch[ch]);
}
}
} else if (aot == AOT_AAC_LD || aot == AOT_AAC_ELD) {
for (ch = 0; ch < num_channels; ch++) {
ia_enhaacplus_enc_build_interface(
- psy_data[ch].ptr_spec_coeffs, &psy_data[ch].sfb_threshold, &psy_data[ch].sfb_energy,
- &psy_data[ch].sfb_sreaded_energy, psy_data[ch].sfb_energy_sum,
- psy_data[ch].sfb_energy_sum_ms, LONG_WINDOW,
+ psy_data[ch]->ptr_spec_coeffs, &psy_data[ch]->sfb_threshold, &psy_data[ch]->sfb_energy,
+ &psy_data[ch]->sfb_sreaded_energy, psy_data[ch]->sfb_energy_sum,
+ psy_data[ch]->sfb_energy_sum_ms, LONG_WINDOW,
ia_enhaacplus_enc_block_type_to_window_shape_ld[psy_data[ch]
- .blk_switch_cntrl.win_seq_ld],
+ ->blk_switch_cntrl.win_seq_ld],
((aot == AOT_AAC_ELD) ? pstr_psy_conf_long->sfb_active : pstr_psy_conf_long->sfb_cnt),
pstr_psy_conf_long->sfb_offsets, max_sfb_per_grp[ch], pstr_psy_conf_long->sfb_min_snr,
- psy_data[ch].blk_switch_cntrl.total_groups_cnt, psy_data[ch].blk_switch_cntrl.group_len,
- &psy_out_ch[ch]);
+ psy_data[ch]->blk_switch_cntrl.total_groups_cnt,
+ psy_data[ch]->blk_switch_cntrl.group_len, psy_out_ch[ch]);
}
}
return error_code;
diff --git a/encoder/ixheaace_psy_mod.h b/encoder/ixheaace_psy_mod.h
index 59c8461..26a04d0 100644
--- a/encoder/ixheaace_psy_mod.h
+++ b/encoder/ixheaace_psy_mod.h
@@ -39,11 +39,11 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main_init(ixheaace_psy_kernel *pstr_h_psy, WO
IA_ERRORCODE ia_enhaacplus_enc_psy_main(
WORD32 time_sn_stride, /* total number of channels */
ixheaace_element_info *pstr_elem_info, const FLOAT32 *ptr_time_signal, WORD32 aot,
- ixheaace_psy_data psy_data[IXHEAACE_MAX_CH_IN_BS_ELE],
- ixheaace_temporal_noise_shaping_data tns_data[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_data **psy_data,
+ ixheaace_temporal_noise_shaping_data **tns_data,
ixheaace_psy_configuration_long *pstr_psy_conf_long,
ixheaace_psy_configuration_short *pstr_psy_conf_short,
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element, FLOAT32 *ptr_scratch_tns,
FLOAT32 *ptr_shared_buffer1, WORD8 *ptr_shared_buffer5, ixheaace_aac_tables *pstr_aac_tables,
WORD32 frame_len_long);
diff --git a/encoder/ixheaace_qc_main_hp.c b/encoder/ixheaace_qc_main_hp.c
index 0eae6e6..986bbb7 100644
--- a/encoder/ixheaace_qc_main_hp.c
+++ b/encoder/ixheaace_qc_main_hp.c
@@ -66,12 +66,11 @@
#include "ixheaace_qc_util.h"
#include "ixheaace_common_utils.h"
-#define OPT_QC_STACK
IA_ERRORCODE ia_enhaacplus_enc_qc_main(
ixheaace_qc_state *pstr_qc_state, WORD32 num_channels, ixheaace_element_bits *pstr_el_bits,
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element,
- ixheaace_qc_out_channel pstr_qc_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_qc_out_channel **pstr_qc_out_ch,
ixheaace_qc_out_element *pstr_qc_out_element, WORD32 ancillary_data_bytes,
ixheaace_aac_tables *pstr_aac_tables, WORD32 adts_flag, WORD32 aot, WORD32 stat_bits_flag,
WORD32 flag_last_element, WORD32 frame_len_long, WORD8 *ptr_scratch,
@@ -112,7 +111,7 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_main(
for (ch = 0; ch < num_channels; ch++) {
iaace_calc_form_fac_per_chan(ptr_stack->sfb_form_fac[ch],
- ptr_stack->sfb_num_relevant_lines[ch], &psy_out_ch[ch],
+ ptr_stack->sfb_num_relevant_lines[ch], psy_out_ch[ch],
ptr_stack->sfb_ld_energy[ch]);
}
@@ -146,44 +145,46 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_main(
iterations = 0;
gain = 0;
for (spec_idx = 0; spec_idx < frame_len_long; spec_idx++) {
- ptr_stack->exp_spec[spec_idx] = (FLOAT32)psy_out_ch[ch].ptr_spec_coeffs[spec_idx];
- ptr_stack->mdct_spec_float[spec_idx] = (FLOAT32)psy_out_ch[ch].ptr_spec_coeffs[spec_idx];
+ ptr_stack->exp_spec[spec_idx] = (FLOAT32)psy_out_ch[ch]->ptr_spec_coeffs[spec_idx];
+ ptr_stack->mdct_spec_float[spec_idx] = (FLOAT32)psy_out_ch[ch]->ptr_spec_coeffs[spec_idx];
}
do {
WORD32 max_val;
constraints_fulfilled = 1;
WORD32 quant_spec_is_zero = 1;
if (iterations > 0) {
- for (sfb_offs = 0; sfb_offs < psy_out_ch[ch].sfb_count;
- sfb_offs += psy_out_ch[ch].sfb_per_group) {
- for (sfb = 0; sfb < psy_out_ch[ch].max_sfb_per_grp; sfb++) {
- WORD32 scalefactor = pstr_qc_out_ch[ch].scalefactor[sfb + sfb_offs];
- gain = MAX(gain, pstr_qc_out_ch[ch].global_gain - scalefactor);
+ for (sfb_offs = 0; sfb_offs < psy_out_ch[ch]->sfb_count;
+ sfb_offs += psy_out_ch[ch]->sfb_per_group) {
+ for (sfb = 0; sfb < psy_out_ch[ch]->max_sfb_per_grp; sfb++) {
+ WORD32 scalefactor = pstr_qc_out_ch[ch]->scalefactor[sfb + sfb_offs];
+ gain = MAX(gain, pstr_qc_out_ch[ch]->global_gain - scalefactor);
iaace_quantize_lines(
- pstr_qc_out_ch[ch].global_gain - scalefactor,
- psy_out_ch[ch].sfb_offsets[sfb_offs + sfb + 1] -
- psy_out_ch[ch].sfb_offsets[sfb_offs + sfb],
- ptr_stack->exp_spec + psy_out_ch[ch].sfb_offsets[sfb_offs + sfb],
- pstr_qc_out_ch[ch].quant_spec + psy_out_ch[ch].sfb_offsets[sfb_offs + sfb],
- ptr_stack->mdct_spec_float + psy_out_ch[ch].sfb_offsets[sfb_offs + sfb]);
+ pstr_qc_out_ch[ch]->global_gain - scalefactor,
+ psy_out_ch[ch]->sfb_offsets[sfb_offs + sfb + 1] -
+ psy_out_ch[ch]->sfb_offsets[sfb_offs + sfb],
+ ptr_stack->exp_spec + psy_out_ch[ch]->sfb_offsets[sfb_offs + sfb],
+ pstr_qc_out_ch[ch]->quant_spec + psy_out_ch[ch]->sfb_offsets[sfb_offs + sfb],
+ ptr_stack->mdct_spec_float + psy_out_ch[ch]->sfb_offsets[sfb_offs + sfb]);
}
}
}
max_val = iaace_calc_max_val_in_sfb(
- psy_out_ch[ch].sfb_count, psy_out_ch[ch].max_sfb_per_grp, psy_out_ch[ch].sfb_per_group,
- psy_out_ch[ch].sfb_offsets, pstr_qc_out_ch[ch].quant_spec,
- pstr_qc_out_ch[ch].max_val_in_sfb);
+ psy_out_ch[ch]->sfb_count, psy_out_ch[ch]->max_sfb_per_grp,
+ psy_out_ch[ch]->sfb_per_group,
+ psy_out_ch[ch]->sfb_offsets, pstr_qc_out_ch[ch]->quant_spec,
+ pstr_qc_out_ch[ch]->max_val_in_sfb);
if (max_val > MAXIMUM_QUANT) {
constraints_fulfilled = 0;
}
- for (k = 0; ((k < psy_out_ch[ch].sfb_count) && (quant_spec_is_zero));
- k += psy_out_ch[ch].sfb_per_group) {
- for (i = 0; ((i < psy_out_ch[ch].max_sfb_per_grp) && (quant_spec_is_zero)); i++) {
- for (j = psy_out_ch[ch].sfb_offsets[i+k]; j < psy_out_ch[ch].sfb_offsets[i+k+1]; j++) {
- if (pstr_qc_out_ch[ch].quant_spec[j] != 0) {
+ for (k = 0; ((k < psy_out_ch[ch]->sfb_count) && (quant_spec_is_zero));
+ k += psy_out_ch[ch]->sfb_per_group) {
+ for (i = 0; ((i < psy_out_ch[ch]->max_sfb_per_grp) && (quant_spec_is_zero)); i++) {
+ for (j = psy_out_ch[ch]->sfb_offsets[i+k]; j < psy_out_ch[ch]->sfb_offsets[i+k+1]; j++)
+ {
+ if (pstr_qc_out_ch[ch]->quant_spec[j] != 0) {
quant_spec_is_zero = 0;
break;
}
@@ -191,10 +192,11 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_main(
}
}
err_code = ia_enhaacplus_enc_dyn_bitcount(
- pstr_qc_out_ch[ch].quant_spec, pstr_qc_out_ch[ch].max_val_in_sfb,
- pstr_qc_out_ch[ch].scalefactor, psy_out_ch[ch].window_sequence,
- psy_out_ch[ch].sfb_count, psy_out_ch[ch].max_sfb_per_grp, psy_out_ch[ch].sfb_per_group,
- psy_out_ch[ch].sfb_offsets, &pstr_qc_out_ch[ch].section_data,
+ pstr_qc_out_ch[ch]->quant_spec, pstr_qc_out_ch[ch]->max_val_in_sfb,
+ pstr_qc_out_ch[ch]->scalefactor, psy_out_ch[ch]->window_sequence,
+ psy_out_ch[ch]->sfb_count, psy_out_ch[ch]->max_sfb_per_grp,
+ psy_out_ch[ch]->sfb_per_group,
+ psy_out_ch[ch]->sfb_offsets, &pstr_qc_out_ch[ch]->section_data,
pstr_qc_state->side_info_tab_long, pstr_qc_state->side_info_tab_short,
pstr_aac_tables->pstr_huff_tab, pstr_qc_state->qc_scr.shared_buffer_2, aot,
&ch_dyn_bits);
@@ -225,7 +227,7 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_main(
ch_dyn_bits = max_ch_dyn_bits[ch];
}
if (!constraints_fulfilled) {
- pstr_qc_out_ch[ch].global_gain++;
+ pstr_qc_out_ch[ch]->global_gain++;
}
iterations++;
@@ -233,8 +235,8 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_main(
pstr_qc_out_element->dyn_bits_used += ch_dyn_bits;
- pstr_qc_out_ch[ch].grouping_mask = psy_out_ch[ch].grouping_mask;
- pstr_qc_out_ch[ch].win_shape = psy_out_ch[ch].window_shape;
+ pstr_qc_out_ch[ch]->grouping_mask = psy_out_ch[ch]->grouping_mask;
+ pstr_qc_out_ch[ch]->win_shape = psy_out_ch[ch]->window_shape;
}
pstr_adj_thr_elem->dyn_bits_last = pstr_qc_out_element->dyn_bits_used;
diff --git a/encoder/ixheaace_qc_util.h b/encoder/ixheaace_qc_util.h
index 6e971cd..117c6eb 100644
--- a/encoder/ixheaace_qc_util.h
+++ b/encoder/ixheaace_qc_util.h
@@ -32,9 +32,9 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_init(ixheaace_qc_state *pstr_qc_state, WORD32
IA_ERRORCODE ia_enhaacplus_enc_qc_main(
ixheaace_qc_state *pstr_qc_state, WORD32 num_channels, ixheaace_element_bits *pstr_el_bits,
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element,
- ixheaace_qc_out_channel pstr_qc_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_qc_out_channel **pstr_qc_out_ch,
ixheaace_qc_out_element *pstr_qc_out_element, WORD32 ancillary_data_bytes,
ixheaace_aac_tables *pstr_aac_tables, WORD32 adts_flag, WORD32 aot, WORD32 stat_bits_flag,
WORD32 flag_last_element, WORD32 frame_len_long, WORD8 *ptr_scratch,
diff --git a/encoder/ixheaace_sbr_frame_info_gen.c b/encoder/ixheaace_sbr_frame_info_gen.c
index 45eb3aa..1265470 100644
--- a/encoder/ixheaace_sbr_frame_info_gen.c
+++ b/encoder/ixheaace_sbr_frame_info_gen.c
@@ -945,6 +945,9 @@ ixheaace_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_env_frame,
ixheaace_freq_res *ptr_tuning_freq = (ixheaace_freq_res *)(ptr_v_tuning + 3);
ixheaace_freq_res freq_res_fix = pstr_sbr_env_frame->freq_res_fix;
+ if (pstr_sbr_env_frame->use_low_freq_res == 1) {
+ freq_res_fix = FREQ_RES_LOW;
+ }
if (is_ld_sbr) {
if ((!tran_flag && ptr_v_pre_transient_info[1]) &&
(num_time_slots - ptr_v_pre_transient_info[0] < 4)) {
@@ -1108,7 +1111,8 @@ ixheaace_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_env_frame,
case IXHEAACE_LD_TRAN: {
ixheaace_create_ld_transient_frame_info(&pstr_sbr_env_frame->sbr_frame_info,
&pstr_sbr_env_frame->sbr_grid, tran_pos,
- num_time_slots, 0);
+ num_time_slots,
+ pstr_sbr_env_frame->use_low_freq_res);
} break;
default:
break;
@@ -1122,7 +1126,8 @@ ixheaace_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_env_frame,
VOID ixheaace_create_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_env_frame,
WORD32 allow_spread, WORD32 num_env_static,
- WORD32 static_framing, ixheaace_freq_res freq_res_fix) {
+ WORD32 static_framing, ixheaace_freq_res freq_res_fix,
+ WORD32 use_low_freq_res) {
memset(pstr_sbr_env_frame, 0, sizeof(ixheaace_str_sbr_env_frame));
pstr_sbr_env_frame->frame_type_old = IXHEAACE_FIXFIX;
@@ -1132,6 +1137,7 @@ VOID ixheaace_create_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_e
pstr_sbr_env_frame->num_env_static = num_env_static;
pstr_sbr_env_frame->static_framing = static_framing;
pstr_sbr_env_frame->freq_res_fix = freq_res_fix;
+ pstr_sbr_env_frame->use_low_freq_res = use_low_freq_res;
pstr_sbr_env_frame->length_v_bord = 0;
pstr_sbr_env_frame->length_v_bord_follow = 0;
diff --git a/encoder/ixheaace_sbr_frame_info_gen.h b/encoder/ixheaace_sbr_frame_info_gen.h
index cc63173..7f74e4e 100644
--- a/encoder/ixheaace_sbr_frame_info_gen.h
+++ b/encoder/ixheaace_sbr_frame_info_gen.h
@@ -84,13 +84,15 @@ typedef struct {
WORD32 length_v_freq_follow;
ixheaace_str_sbr_grid sbr_grid;
ixheaace_str_frame_info_sbr sbr_frame_info;
+ WORD32 use_low_freq_res;
} ixheaace_str_sbr_env_frame;
typedef ixheaace_str_sbr_env_frame *ixheaace_pstr_sbr_env_frame;
VOID ixheaace_create_frame_info_generator(ixheaace_pstr_sbr_env_frame sbr_env_frame_handle,
WORD32 allow_spread, WORD32 num_env_static,
- WORD32 static_framing, ixheaace_freq_res freq_res_fix);
+ WORD32 static_framing, ixheaace_freq_res freq_res_fix,
+ WORD32 use_low_freq_res);
IA_ERRORCODE
ixheaace_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_env_frame,
diff --git a/encoder/ixheaace_sbr_main.c b/encoder/ixheaace_sbr_main.c
index 62919f2..a708db2 100644
--- a/encoder/ixheaace_sbr_main.c
+++ b/encoder/ixheaace_sbr_main.c
@@ -276,7 +276,8 @@ static IA_ERRORCODE ixheaace_create_env_channel(
}
ixheaace_create_frame_info_generator(&pstr_env->str_sbr_env_frame, params->spread, e,
- params->stat, pstr_env->enc_env_data.freq_res_fix);
+ params->stat, pstr_env->enc_env_data.freq_res_fix,
+ params->use_low_freq_res);
ixheaace_create_sbr_transient_detector(
&pstr_env->str_sbr_trans_detector, pstr_sbr_cfg->sample_freq,
@@ -502,8 +503,23 @@ VOID ixheaace_adjust_sbr_settings(const ixheaace_pstr_sbr_cfg pstr_config, UWORD
break;
}
}
+ pstr_config->use_low_freq_res = 0;
if (pstr_config->sbr_codec == ELD_SBR) {
pstr_config->send_header_data_time = -1;
+ if ((num_ch == NUM_CHANS_MONO) && (bit_rate <= 22000)) {
+ pstr_config->use_low_freq_res = 1;
+ }
+ if ((num_ch == NUM_CHANS_STEREO) && (bit_rate <= 48000)) {
+ pstr_config->use_low_freq_res = 1;
+ }
+ }
+ else {
+ if ((num_ch == NUM_CHANS_MONO) && (bit_rate <= 18000)) {
+ pstr_config->use_low_freq_res = 1;
+ }
+ if ((num_ch == NUM_CHANS_STEREO) && (bit_rate <= 28000)) {
+ pstr_config->use_low_freq_res = 1;
+ }
}
if (bit_rate <= 20000) {
pstr_config->parametric_coding = 0;
@@ -739,107 +755,120 @@ VOID ixheaace_sbr_set_scratch_ptr(ixheaace_pstr_sbr_enc pstr_env_enc, VOID *ptr_
WORD32 ixheaace_sbr_enc_pers_size(WORD32 num_ch, WORD32 use_ps, WORD32 harmonic_sbr) {
WORD32 num_bytes;
- num_bytes = sizeof(struct ixheaace_str_sbr_enc);
- num_bytes += sizeof(struct ixheaace_str_enc_channel) * num_ch;
- num_bytes += sizeof(ixheaace_pvc_enc);
- num_bytes += 2 * sizeof(FLOAT32) * num_ch * QMF_FILTER_LENGTH;
+ num_bytes = IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_sbr_enc), BYTE_ALIGN_8);
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_enc_channel), BYTE_ALIGN_8) *
+ num_ch);
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_pvc_enc), BYTE_ALIGN_8);
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(2 * sizeof(FLOAT32) * QMF_FILTER_LENGTH, BYTE_ALIGN_8) *
+ num_ch);
if (1 == harmonic_sbr) {
- num_bytes += sizeof(ixheaace_str_hbe_enc) * num_ch;
- num_bytes += sizeof(ixheaace_str_esbr_hbe_txposer) * num_ch;
- num_bytes += IXHEAACE_MAX_HBE_PERSISTENT_SIZE * num_ch;
- num_bytes += ESBR_RESAMP_SAMPLES * sizeof(FLOAT32);
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_str_hbe_enc), BYTE_ALIGN_8) * num_ch);
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_str_esbr_hbe_txposer), BYTE_ALIGN_8) *
+ num_ch);
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(IXHEAACE_MAX_HBE_PERSISTENT_SIZE, BYTE_ALIGN_8) *
+ num_ch);
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(ESBR_RESAMP_SAMPLES * sizeof(FLOAT32), BYTE_ALIGN_8);
}
- num_bytes += sizeof(FLOAT32) * num_ch * 5 * NO_OF_ESTIMATES * MAXIMUM_FREQ_COEFFS;
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(sizeof(FLOAT32) * 5 * NO_OF_ESTIMATES *
+ MAXIMUM_FREQ_COEFFS, BYTE_ALIGN_8) * num_ch);
- num_bytes += sizeof(FLOAT32) * num_ch * MAX_QMF_TIME_SLOTS * IXHEAACE_QMF_CHANNELS;
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(sizeof(FLOAT32) * MAX_QMF_TIME_SLOTS *
+ IXHEAACE_QMF_CHANNELS, BYTE_ALIGN_8) * num_ch);
if (use_ps) {
- num_bytes += sizeof(struct ixheaace_str_enc_channel);
- num_bytes += sizeof(struct ixheaace_ps_enc);
- num_bytes += sizeof(FLOAT32) * QMF_FILTER_LENGTH;
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_enc_channel), BYTE_ALIGN_8);
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_ps_enc), BYTE_ALIGN_8);
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(FLOAT32) * QMF_FILTER_LENGTH, BYTE_ALIGN_8);
- num_bytes += sizeof(WORD32) * 5 * NO_OF_ESTIMATES * MAXIMUM_FREQ_COEFFS;
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(WORD32) * 5 * NO_OF_ESTIMATES *
+ MAXIMUM_FREQ_COEFFS, BYTE_ALIGN_8);
/*shared between spectral_band_replication_envYBuffer_fix and IIC IDD PS data buffers*/
- num_bytes += sizeof(WORD32) * IXHEAACE_QMF_TIME_SLOTS * IXHEAACE_QMF_CHANNELS;
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(WORD32) * IXHEAACE_QMF_TIME_SLOTS *
+ IXHEAACE_QMF_CHANNELS, BYTE_ALIGN_8);
}
- num_bytes += sizeof(ixheaace_str_sbr_qmf_filter_bank);
- num_bytes = IXHEAACE_GET_SIZE_ALIGNED(num_bytes, BYTE_ALIGN_8);
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_str_sbr_qmf_filter_bank), BYTE_ALIGN_8);
return num_bytes;
}
VOID ia_enhaacplus_enc_sbr_set_persist_buf(WORD8 *ptr_base, WORD32 num_ch, WORD32 use_ps,
WORD32 harmonic_sbr) {
struct ixheaace_str_sbr_enc *pstr_env_enc;
- WORD8 *ptr_curr_mem = (WORD8 *)((WORD8 *)ptr_base + sizeof(struct ixheaace_str_sbr_enc));
+ WORD8 *ptr_curr_mem = ptr_base +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_sbr_enc), BYTE_ALIGN_8);
WORD32 i;
pstr_env_enc = (struct ixheaace_str_sbr_enc *)ptr_base;
for (i = 0; i < num_ch; i++) {
pstr_env_enc->pstr_env_channel[i] = (struct ixheaace_str_enc_channel *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(struct ixheaace_str_enc_channel);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_enc_channel), BYTE_ALIGN_8);
}
for (i = 0; i < num_ch; i++) {
pstr_env_enc->pstr_env_channel[i]->str_sbr_qmf.ptr_sbr_qmf_states_ana =
(FLOAT32 *)ptr_curr_mem;
- ptr_curr_mem +=
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(
sizeof(pstr_env_enc->pstr_env_channel[i]->str_sbr_qmf.ptr_sbr_qmf_states_ana[0]) *
- QMF_FILTER_LENGTH;
+ QMF_FILTER_LENGTH, BYTE_ALIGN_8);
}
if (!use_ps) {
pstr_env_enc->ptr_common_buffer1 = (WORD32 *)ptr_curr_mem;
- ptr_curr_mem += sizeof(pstr_env_enc->ptr_common_buffer1[0]) * num_ch * 5 * NO_OF_ESTIMATES *
- MAXIMUM_FREQ_COEFFS;
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(sizeof(pstr_env_enc->ptr_common_buffer1[0]) *
+ num_ch * 5 * NO_OF_ESTIMATES * MAXIMUM_FREQ_COEFFS, BYTE_ALIGN_8);
pstr_env_enc->ptr_common_buffer2 = (WORD32 *)ptr_curr_mem;
- ptr_curr_mem += sizeof(pstr_env_enc->ptr_common_buffer2[0]) * num_ch * MAX_QMF_TIME_SLOTS *
- IXHEAACE_QMF_CHANNELS;
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(sizeof(pstr_env_enc->ptr_common_buffer2[0]) *
+ num_ch * MAX_QMF_TIME_SLOTS * IXHEAACE_QMF_CHANNELS, BYTE_ALIGN_8);
} else {
pstr_env_enc->ptr_common_buffer1 = (WORD32 *)ptr_curr_mem;
- ptr_curr_mem += 2 * sizeof(pstr_env_enc->ptr_common_buffer1[0]) * 5 * NO_OF_ESTIMATES *
- MAXIMUM_FREQ_COEFFS;
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(2 * sizeof(pstr_env_enc->ptr_common_buffer1[0]) *
+ 5 * NO_OF_ESTIMATES * MAXIMUM_FREQ_COEFFS, BYTE_ALIGN_8);
pstr_env_enc->ptr_common_buffer2 = (WORD32 *)ptr_curr_mem;
- ptr_curr_mem += 2 * sizeof(pstr_env_enc->ptr_common_buffer2[0]) * IXHEAACE_QMF_TIME_SLOTS *
- IXHEAACE_QMF_CHANNELS;
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(2 * sizeof(pstr_env_enc->ptr_common_buffer2[0]) *
+ IXHEAACE_QMF_TIME_SLOTS * IXHEAACE_QMF_CHANNELS, BYTE_ALIGN_8);
}
// PVC encoder
pstr_env_enc->pstr_pvc_enc = (ixheaace_pvc_enc *)ptr_curr_mem;
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_pvc_enc);
+ ptr_curr_mem = ptr_curr_mem + IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_pvc_enc), BYTE_ALIGN_8);
// Harmonic SBR
if (1 == harmonic_sbr) {
for (i = 0; i < num_ch; i++) {
pstr_env_enc->pstr_env_channel[i]->pstr_hbe_enc = (ixheaace_str_hbe_enc *)ptr_curr_mem;
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_str_hbe_enc);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_str_hbe_enc), BYTE_ALIGN_8);
pstr_env_enc->pstr_env_channel[i]->pstr_hbe_enc->pstr_hbe_txposer =
(ixheaace_str_esbr_hbe_txposer *)ptr_curr_mem;
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_str_esbr_hbe_txposer);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_str_esbr_hbe_txposer), BYTE_ALIGN_8);
pstr_env_enc->pstr_env_channel[i]->pstr_hbe_enc->ptr_hbe_txposer_buffers =
(VOID *)ptr_curr_mem;
ptr_curr_mem = ptr_curr_mem + IXHEAACE_MAX_HBE_PERSISTENT_SIZE;
}
pstr_env_enc->ptr_hbe_resample_buf = (FLOAT32 *)ptr_curr_mem;
- ptr_curr_mem =
- ptr_curr_mem + (ESBR_RESAMP_SAMPLES * sizeof(pstr_env_enc->ptr_hbe_resample_buf[0]));
+ ptr_curr_mem = ptr_curr_mem + IXHEAACE_GET_SIZE_ALIGNED(
+ (ESBR_RESAMP_SAMPLES * sizeof(pstr_env_enc->ptr_hbe_resample_buf[0])), BYTE_ALIGN_8);
}
if (use_ps) {
pstr_env_enc->pstr_env_channel[1] = (struct ixheaace_str_enc_channel *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(struct ixheaace_str_enc_channel);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_enc_channel), BYTE_ALIGN_8);
memset(pstr_env_enc->pstr_env_channel[1], 0, sizeof(struct ixheaace_str_enc_channel));
pstr_env_enc->pstr_env_channel[1]->str_sbr_qmf.ptr_sbr_qmf_states_ana =
(FLOAT32 *)ptr_curr_mem;
- ptr_curr_mem +=
- sizeof(pstr_env_enc->pstr_env_channel[1]->str_sbr_qmf.ptr_sbr_qmf_states_ana[0]) *
- QMF_FILTER_LENGTH;
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(
+ sizeof(pstr_env_enc->pstr_env_channel[1]->str_sbr_qmf.ptr_sbr_qmf_states_ana[0]) *
+ QMF_FILTER_LENGTH, BYTE_ALIGN_8);
memset(pstr_env_enc->pstr_env_channel[1]->str_sbr_qmf.ptr_sbr_qmf_states_ana, 0,
sizeof(pstr_env_enc->pstr_env_channel[1]->str_sbr_qmf.ptr_sbr_qmf_states_ana[0]) *
QMF_FILTER_LENGTH);
pstr_env_enc->pstr_ps_enc = (struct ixheaace_ps_enc *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(struct ixheaace_ps_enc);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_ps_enc), BYTE_ALIGN_8);
memset(pstr_env_enc->pstr_ps_enc, 0, sizeof(struct ixheaace_ps_enc));
}
pstr_env_enc->pstr_synthesis_qmf_bank = (ixheaace_str_sbr_qmf_filter_bank *)(ptr_curr_mem);
diff --git a/encoder/ixheaace_sbr_main.h b/encoder/ixheaace_sbr_main.h
index e53b972..3603fdf 100644
--- a/encoder/ixheaace_sbr_main.h
+++ b/encoder/ixheaace_sbr_main.h
@@ -84,6 +84,7 @@ typedef struct ixheaace_str_sbr_cfg {
WORD32 sbr_harmonic;
WORD32 hq_esbr;
ixheaace_sbr_codec_type sbr_codec;
+ WORD32 use_low_freq_res;
} ixheaace_str_sbr_cfg, *ixheaace_pstr_sbr_cfg;
typedef struct ixheaace_str_sbr_enc *ixheaace_pstr_sbr_enc;
diff --git a/encoder/ixheaace_sf_estimation.c b/encoder/ixheaace_sf_estimation.c
index 17d48ba..1a39734 100644
--- a/encoder/ixheaace_sf_estimation.c
+++ b/encoder/ixheaace_sf_estimation.c
@@ -621,8 +621,8 @@ static VOID iaace_assimilate_multiple_scf(ixheaace_psy_out_channel *pstr_psy_out
}
VOID iaace_estimate_scfs_chan(
- ixheaace_psy_out_channel pstr_psy_out[IXHEAACE_MAX_CH_IN_BS_ELE],
- ixheaace_qc_out_channel pstr_qc_out_chan[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **pstr_psy_out,
+ ixheaace_qc_out_channel **pstr_qc_out_chan,
FLOAT32 sfb_form_factor_ch[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
FLOAT32 sfb_num_relevant_lines_ch[][MAXIMUM_GROUPED_SCALE_FACTOR_BAND], WORD32 num_channels,
WORD32 chn, WORD32 frame_len_long) {
@@ -648,19 +648,19 @@ VOID iaace_estimate_scfs_chan(
memset(ptr_exp_spec, 0, frame_len_long * sizeof(ptr_exp_spec[0]));
for (ch = chn; ch < chn + num_channels; ch++) {
- ixheaace_psy_out_channel *pstr_psy_out_chan = &pstr_psy_out[ch];
- pstr_qc_out_chan[ch].global_gain = 0;
+ ixheaace_psy_out_channel *pstr_psy_out_chan = pstr_psy_out[ch];
+ pstr_qc_out_chan[ch]->global_gain = 0;
- memset(pstr_qc_out_chan[ch].scalefactor, 0,
- sizeof(*pstr_qc_out_chan[ch].scalefactor) * pstr_psy_out[ch].sfb_count);
- memset(pstr_qc_out_chan[ch].quant_spec, 0,
- sizeof(*pstr_qc_out_chan[ch].quant_spec) * frame_len_long);
+ memset(pstr_qc_out_chan[ch]->scalefactor, 0,
+ sizeof(*pstr_qc_out_chan[ch]->scalefactor) * pstr_psy_out[ch]->sfb_count);
+ memset(pstr_qc_out_chan[ch]->quant_spec, 0,
+ sizeof(*pstr_qc_out_chan[ch]->quant_spec) * frame_len_long);
- ptr_scalefactor = pstr_qc_out_chan[ch].scalefactor;
- global_gain = &pstr_qc_out_chan[ch].global_gain;
+ ptr_scalefactor = pstr_qc_out_chan[ch]->scalefactor;
+ global_gain = &pstr_qc_out_chan[ch]->global_gain;
ptr_sfb_form_factor = &sfb_form_factor_ch[ch][0];
ptr_sfb_num_relevant_lines_ch = &sfb_num_relevant_lines_ch[ch][0];
- ptr_quant_spec = pstr_qc_out_chan[ch].quant_spec;
+ ptr_quant_spec = pstr_qc_out_chan[ch]->quant_spec;
for (i = 0; i < pstr_psy_out_chan->sfb_count; i++) {
thresh = pstr_psy_out_chan->ptr_sfb_thr[i];
@@ -739,7 +739,7 @@ VOID iaace_estimate_scfs_chan(
}
}
- for (i = 0; i < pstr_psy_out[ch].sfb_count; i++) {
+ for (i = 0; i < pstr_psy_out[ch]->sfb_count; i++) {
if ((ptr_scalefactor[i] != MIN_SHRT_VAL) &&
(min_scf + MAX_SCF_DELTA) < ptr_scalefactor[i]) {
ptr_scalefactor[i] = min_scf + MAX_SCF_DELTA;
diff --git a/encoder/ixheaace_sf_estimation.h b/encoder/ixheaace_sf_estimation.h
index ec085d0..954cb89 100644
--- a/encoder/ixheaace_sf_estimation.h
+++ b/encoder/ixheaace_sf_estimation.h
@@ -28,8 +28,8 @@ VOID iaace_calc_form_fac_per_chan(FLOAT32 *ptr_sfb_form_factor,
FLOAT32 *ptr_sfb_ld_energy);
VOID iaace_estimate_scfs_chan(
- ixheaace_psy_out_channel pstr_psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
- ixheaace_qc_out_channel pstr_qc_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **pstr_psy_out_ch,
+ ixheaace_qc_out_channel **pstr_qc_out_ch,
FLOAT32 sfb_form_factor_ch[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
FLOAT32 sfb_num_relevant_lines_ch[][MAXIMUM_GROUPED_SCALE_FACTOR_BAND], WORD32 num_channels,
WORD32 chn, WORD32 frame_len_long);
diff --git a/encoder/ixheaace_static_bits.c b/encoder/ixheaace_static_bits.c
index 9d23afd..3fe26bb 100644
--- a/encoder/ixheaace_static_bits.c
+++ b/encoder/ixheaace_static_bits.c
@@ -132,7 +132,7 @@ static WORD32 ia_enhaacplus_enc_count_tns_bits(
}
WORD32 ia_enhaacplus_enc_count_static_bitdemand(
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element, WORD32 channels, WORD32 aot, WORD32 adts_flag,
WORD32 stat_bits_flag, WORD32 flag_last_element) {
WORD32 static_bits = 0;
@@ -143,9 +143,9 @@ WORD32 ia_enhaacplus_enc_count_static_bitdemand(
static_bits += SI_ID_BITS + SI_SCE_BITS + SI_ICS_BITS;
- static_bits += ia_enhaacplus_enc_count_tns_bits(&(psy_out_ch[0].tns_info),
- psy_out_ch[0].window_sequence);
- switch (psy_out_ch[0].window_sequence) {
+ static_bits += ia_enhaacplus_enc_count_tns_bits(&(psy_out_ch[0]->tns_info),
+ psy_out_ch[0]->window_sequence);
+ switch (psy_out_ch[0]->window_sequence) {
case LONG_WINDOW:
case START_WINDOW:
case STOP_WINDOW:
@@ -166,10 +166,10 @@ WORD32 ia_enhaacplus_enc_count_static_bitdemand(
static_bits += SI_CPE_MS_MASK_BITS;
static_bits += ia_enhaacplus_enc_count_ms_mask_bits(
- psy_out_ch[0].sfb_count, psy_out_ch[0].sfb_per_group, psy_out_ch[0].max_sfb_per_grp,
+ psy_out_ch[0]->sfb_count, psy_out_ch[0]->sfb_per_group, psy_out_ch[0]->max_sfb_per_grp,
&pstr_psy_out_element->tools_info);
- switch (psy_out_ch[0].window_sequence) {
+ switch (psy_out_ch[0]->window_sequence) {
case LONG_WINDOW:
case START_WINDOW:
case STOP_WINDOW:
@@ -184,8 +184,8 @@ WORD32 ia_enhaacplus_enc_count_static_bitdemand(
}
for (ch = 0; ch < 2; ch++) {
- static_bits += ia_enhaacplus_enc_count_tns_bits(&(psy_out_ch[ch].tns_info),
- psy_out_ch[ch].window_sequence);
+ static_bits += ia_enhaacplus_enc_count_tns_bits(&(psy_out_ch[ch]->tns_info),
+ psy_out_ch[ch]->window_sequence);
}
break;
diff --git a/encoder/ixheaace_static_bits.h b/encoder/ixheaace_static_bits.h
index b1c969b..61cfbc9 100644
--- a/encoder/ixheaace_static_bits.h
+++ b/encoder/ixheaace_static_bits.h
@@ -21,6 +21,6 @@
#pragma once
WORD32 ia_enhaacplus_enc_count_static_bitdemand(
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element, WORD32 channels, WORD32 aot, WORD32 adts_flag,
WORD32 stat_bits_flag, WORD32 flag_last_element);
diff --git a/encoder/ixheaace_stereo_preproc.c b/encoder/ixheaace_stereo_preproc.c
index a14fe7e..d981406 100644
--- a/encoder/ixheaace_stereo_preproc.c
+++ b/encoder/ixheaace_stereo_preproc.c
@@ -237,17 +237,17 @@ VOID iaace_apply_stereo_preproc(ixheaace_stereo_pre_pro_pstr pstr_stereo_pre_pro
pstr_stereo_pre_pro->average_freq_energy_l + pstr_stereo_pre_pro->average_freq_energy_r;
}
-VOID iaace_update_stereo_pre_process(ixheaace_psy_out_channel *pstr_psy_out,
+VOID iaace_update_stereo_pre_process(ixheaace_psy_out_channel **pstr_psy_out,
ixheaace_qc_out_element *pstr_qc_out,
ixheaace_stereo_pre_pro_pstr pstr_stereo_pre_pro,
FLOAT32 weight_pe_fac) {
if (pstr_stereo_pre_pro->stereo_attenuation_flag) {
FLOAT32 delta = 0.1f;
- pstr_stereo_pre_pro->average_freq_energy_l = pstr_psy_out[0].sfb_sum_lr_energy;
- pstr_stereo_pre_pro->average_freq_energy_r = pstr_psy_out[1].sfb_sum_lr_energy;
- pstr_stereo_pre_pro->average_freq_energy_m = pstr_psy_out[0].sfb_sum_ms_energy;
- pstr_stereo_pre_pro->average_freq_energy_s = pstr_psy_out[1].sfb_sum_ms_energy;
+ pstr_stereo_pre_pro->average_freq_energy_l = pstr_psy_out[0]->sfb_sum_lr_energy;
+ pstr_stereo_pre_pro->average_freq_energy_r = pstr_psy_out[1]->sfb_sum_lr_energy;
+ pstr_stereo_pre_pro->average_freq_energy_m = pstr_psy_out[0]->sfb_sum_ms_energy;
+ pstr_stereo_pre_pro->average_freq_energy_s = pstr_psy_out[1]->sfb_sum_ms_energy;
pstr_stereo_pre_pro->smoothed_pe_sum_sum =
delta * pstr_qc_out->pe * weight_pe_fac +
diff --git a/encoder/ixheaace_stereo_preproc.h b/encoder/ixheaace_stereo_preproc.h
index 9ecb046..58fe76c 100644
--- a/encoder/ixheaace_stereo_preproc.h
+++ b/encoder/ixheaace_stereo_preproc.h
@@ -58,7 +58,7 @@ VOID iaace_apply_stereo_preproc(ixheaace_stereo_pre_pro_pstr pstr_stereo_pre_pro
WORD32 num_channels, ixheaace_element_info *pstr_elem_info,
FLOAT32 *ptr_time_data, WORD32 granule_len);
-VOID iaace_update_stereo_pre_process(ixheaace_psy_out_channel *pstr_psy_out,
+VOID iaace_update_stereo_pre_process(ixheaace_psy_out_channel **pstr_psy_out,
ixheaace_qc_out_element *pstr_qc_out,
ixheaace_stereo_pre_pro_pstr pstr_stereo_pre_pro,
FLOAT32 weight_pe_fac);