aboutsummaryrefslogtreecommitdiff
path: root/decoder/drc_src/impd_drc_dec.c
diff options
context:
space:
mode:
Diffstat (limited to 'decoder/drc_src/impd_drc_dec.c')
-rw-r--r--decoder/drc_src/impd_drc_dec.c601
1 files changed, 295 insertions, 306 deletions
diff --git a/decoder/drc_src/impd_drc_dec.c b/decoder/drc_src/impd_drc_dec.c
index 0e32e46..32da663 100644
--- a/decoder/drc_src/impd_drc_dec.c
+++ b/decoder/drc_src/impd_drc_dec.c
@@ -27,352 +27,341 @@
#include "impd_drc_filter_bank.h"
#include "impd_drc_multi_band.h"
+WORD32 impd_init_drc_params(WORD32 frame_size, WORD32 sample_rate,
+ WORD32 gain_delay_samples, WORD32 delay_mode,
+ WORD32 sub_band_domain_mode,
+ ia_drc_params_struct* ia_drc_params_struct) {
+ WORD32 k;
+ if (frame_size < 1 || frame_size > AUDIO_CODEC_FRAME_SIZE_MAX) {
+ return -1;
+ }
-WORD32 impd_init_drc_params(WORD32 frame_size,
- WORD32 sample_rate,
- WORD32 gain_delay_samples,
- WORD32 delay_mode,
- WORD32 sub_band_domain_mode,
- ia_drc_params_struct* ia_drc_params_struct)
-{
- WORD32 k;
- if (frame_size < 1|| frame_size > AUDIO_CODEC_FRAME_SIZE_MAX)
- {
- return -1;
- }
+ if (sample_rate < 1000) {
+ return -1;
+ }
- if (sample_rate < 1000)
- {
- return -1;
- }
+ ia_drc_params_struct->drc_frame_size = frame_size;
- ia_drc_params_struct->drc_frame_size = frame_size;
+ if (ia_drc_params_struct->drc_frame_size < 0.001f * sample_rate) {
+ return -1;
+ }
- if (ia_drc_params_struct->drc_frame_size < 0.001f * sample_rate)
- {
- return -1;
- }
+ ia_drc_params_struct->sample_rate = sample_rate;
- ia_drc_params_struct->sample_rate = sample_rate;
+ ia_drc_params_struct->delta_tmin_default = impd_get_delta_tmin(sample_rate);
- ia_drc_params_struct->delta_tmin_default = impd_get_delta_tmin(sample_rate);
+ if (ia_drc_params_struct->delta_tmin_default >
+ ia_drc_params_struct->drc_frame_size) {
+ return -1;
+ }
- if (ia_drc_params_struct->delta_tmin_default > ia_drc_params_struct->drc_frame_size)
- {
- return -1;
- }
+ if ((delay_mode != DELAY_MODE_REGULAR_DELAY) &&
+ (delay_mode != DELAY_MODE_LOW_DELAY)) {
+ return -1;
+ }
- if ((delay_mode != DELAY_MODE_REGULAR_DELAY) && (delay_mode != DELAY_MODE_LOW_DELAY))
- {
- return -1;
- }
+ ia_drc_params_struct->delay_mode = delay_mode;
- ia_drc_params_struct->delay_mode = delay_mode;
+ ia_drc_params_struct->drc_set_counter = 0;
+ ia_drc_params_struct->multiband_sel_drc_idx = -1;
- ia_drc_params_struct->drc_set_counter = 0;
- ia_drc_params_struct->multiband_sel_drc_idx = -1;
+ for (k = 0; k < SEL_DRC_COUNT; k++) {
+ ia_drc_params_struct->sel_drc_array[k].drc_instructions_index = -1;
+ ia_drc_params_struct->sel_drc_array[k].dwnmix_instructions_index = -1;
+ ia_drc_params_struct->sel_drc_array[k].drc_coeff_idx = -1;
+ }
- for (k = 0; k < SEL_DRC_COUNT; k++)
- {
- ia_drc_params_struct->sel_drc_array[k].drc_instructions_index = -1;
- ia_drc_params_struct->sel_drc_array[k].dwnmix_instructions_index = -1;
- ia_drc_params_struct->sel_drc_array[k].drc_coeff_idx = -1;
- }
+ if ((gain_delay_samples > MAX_SIGNAL_DELAY) || (gain_delay_samples < 0)) {
+ return -1;
+ } else {
+ ia_drc_params_struct->gain_delay_samples = gain_delay_samples;
+ }
- if ((gain_delay_samples > MAX_SIGNAL_DELAY) || (gain_delay_samples < 0))
- {
- return -1;
- }
- else
- {
- ia_drc_params_struct->gain_delay_samples = gain_delay_samples;
- }
-
- switch (sub_band_domain_mode)
- {
+ switch (sub_band_domain_mode) {
case SUBBAND_DOMAIN_MODE_OFF:
case SUBBAND_DOMAIN_MODE_QMF64:
case SUBBAND_DOMAIN_MODE_QMF71:
case SUBBAND_DOMAIN_MODE_STFT256:
- ia_drc_params_struct->sub_band_domain_mode = sub_band_domain_mode;
- break;
+ ia_drc_params_struct->sub_band_domain_mode = sub_band_domain_mode;
+ break;
default:
- return -1;
- break;
- }
+ return -1;
+ break;
+ }
- ia_drc_params_struct->parametric_drc_delay = 0;
- ia_drc_params_struct->eq_delay = 0;
+ ia_drc_params_struct->parametric_drc_delay = 0;
+ ia_drc_params_struct->eq_delay = 0;
- return 0;
+ return 0;
}
-
-WORD32 impd_select_drc_coefficients(ia_drc_config* drc_config,
- ia_uni_drc_coeffs_struct** drc_coefficients_drc,
- WORD32* drc_coefficients_selected)
-{
- WORD32 i;
- WORD32 cof1 = -1;
- WORD32 cof0 = -1;
- for(i=0; i<drc_config->drc_coefficients_drc_count; i++)
- {
- if (drc_config->str_p_loc_drc_coefficients_uni_drc[i].drc_location == 1)
- {
- if (drc_config->str_p_loc_drc_coefficients_uni_drc[i].version == 0)
- {
- cof0 = i;
- *drc_coefficients_selected = cof0;
- }
- else
- {
- cof1 = i;
- *drc_coefficients_selected = cof1;
- }
- }
- }
-
-
- if (cof1 >= 0) {
- *drc_coefficients_drc = &(drc_config->str_p_loc_drc_coefficients_uni_drc[cof1]);
+WORD32 impd_select_drc_coefficients(
+ ia_drc_config* drc_config, ia_uni_drc_coeffs_struct** drc_coefficients_drc,
+ WORD32* drc_coefficients_selected) {
+ WORD32 i;
+ WORD32 cof1 = -1;
+ WORD32 cof0 = -1;
+ for (i = 0; i < drc_config->drc_coefficients_drc_count; i++) {
+ if (drc_config->str_p_loc_drc_coefficients_uni_drc[i].drc_location == 1) {
+ if (drc_config->str_p_loc_drc_coefficients_uni_drc[i].version == 0) {
+ cof0 = i;
+ *drc_coefficients_selected = cof0;
+ } else {
+ cof1 = i;
+ *drc_coefficients_selected = cof1;
+ }
}
- else if (cof0 >= 0) {
- *drc_coefficients_drc = &(drc_config->str_p_loc_drc_coefficients_uni_drc[cof0]);
- }
- else {
- *drc_coefficients_drc = NULL;
- }
-
-
- return 0;
+ }
+
+ if (cof1 >= 0) {
+ *drc_coefficients_drc =
+ &(drc_config->str_p_loc_drc_coefficients_uni_drc[cof1]);
+ } else if (cof0 >= 0) {
+ *drc_coefficients_drc =
+ &(drc_config->str_p_loc_drc_coefficients_uni_drc[cof0]);
+ } else {
+ *drc_coefficients_drc = NULL;
+ }
+
+ return 0;
}
-
-WORD32 impd_init_selected_drc_set(ia_drc_config* drc_config,
- ia_drc_params_struct* ia_drc_params_struct,
- ia_parametric_drc_params_struct* p_parametric_drc_params,
- WORD32 audio_num_chan,
- WORD32 drc_set_id_selected,
- WORD32 downmix_id_selected,
- ia_filter_banks_struct* ia_filter_banks_struct,
- ia_overlap_params_struct* pstr_overlap_params
-
- , shape_filter_block* shape_filter_block
- )
-{
- WORD32 g, n, c, err = 0;
- WORD32 channel_count = 0;
- WORD32 i;
-
- ia_drc_instructions_struct* drc_instructions_uni_drc = NULL;
- ia_uni_drc_coeffs_struct* drc_coefficients_uni_drc = NULL;
- WORD32 selected_drc_is_multiband = 0;
- WORD32 drc_instructions_selected = -1;
- WORD32 downmix_instructions_selected = -1;
- WORD32 drc_coefficients_selected = -1;
- p_parametric_drc_params->parametric_drc_instance_count = 0;
-
- if (drc_config->drc_coefficients_drc_count && drc_config->str_p_loc_drc_coefficients_uni_drc->drc_frame_size_present)
- {
- if (drc_config->str_p_loc_drc_coefficients_uni_drc->drc_frame_size != ia_drc_params_struct->drc_frame_size)
- {
- return -1;
- }
- }
-
-
- for(n=0; n<drc_config->drc_instructions_count_plus; n++)
- {
- if (drc_config->str_drc_instruction_str[n].drc_set_id == drc_set_id_selected)
- break;
- }
- if (n == drc_config->drc_instructions_count_plus)
- {
- return -1;
+WORD32 impd_init_selected_drc_set(
+ ia_drc_config* drc_config, ia_drc_params_struct* ia_drc_params_struct,
+ ia_parametric_drc_params_struct* p_parametric_drc_params,
+ WORD32 audio_num_chan, WORD32 drc_set_id_selected,
+ WORD32 downmix_id_selected, ia_filter_banks_struct* ia_filter_banks_struct,
+ ia_overlap_params_struct* pstr_overlap_params
+
+ ,
+ shape_filter_block* shape_filter_block) {
+ WORD32 g, n, c, err = 0;
+ WORD32 channel_count = 0;
+ WORD32 i;
+
+ ia_drc_instructions_struct* drc_instructions_uni_drc = NULL;
+ ia_uni_drc_coeffs_struct* drc_coefficients_uni_drc = NULL;
+ WORD32 selected_drc_is_multiband = 0;
+ WORD32 drc_instructions_selected = -1;
+ WORD32 downmix_instructions_selected = -1;
+ WORD32 drc_coefficients_selected = -1;
+ p_parametric_drc_params->parametric_drc_instance_count = 0;
+
+ if (drc_config->drc_coefficients_drc_count &&
+ drc_config->str_p_loc_drc_coefficients_uni_drc->drc_frame_size_present) {
+ if (drc_config->str_p_loc_drc_coefficients_uni_drc->drc_frame_size !=
+ ia_drc_params_struct->drc_frame_size) {
+ return -1;
}
- drc_instructions_selected = n;
- drc_instructions_uni_drc = &(drc_config->str_drc_instruction_str[drc_instructions_selected]);
-
- if (downmix_id_selected == ID_FOR_BASE_LAYOUT)
- {
- channel_count = drc_config->channel_layout.base_channel_count;
+ }
+
+ for (n = 0; n < drc_config->drc_instructions_count_plus; n++) {
+ if (drc_config->str_drc_instruction_str[n].drc_set_id ==
+ drc_set_id_selected)
+ break;
+ }
+ if (n == drc_config->drc_instructions_count_plus) {
+ return -1;
+ }
+ drc_instructions_selected = n;
+ drc_instructions_uni_drc =
+ &(drc_config->str_drc_instruction_str[drc_instructions_selected]);
+
+ if (downmix_id_selected == ID_FOR_BASE_LAYOUT) {
+ channel_count = drc_config->channel_layout.base_channel_count;
+ } else if (downmix_id_selected == ID_FOR_ANY_DOWNMIX) {
+ channel_count = audio_num_chan;
+ } else {
+ for (n = 0; n < drc_config->dwnmix_instructions_count; n++) {
+ if (drc_config->dwnmix_instructions[n].downmix_id == downmix_id_selected)
+ break;
}
- else if (downmix_id_selected == ID_FOR_ANY_DOWNMIX)
- {
- channel_count = audio_num_chan;
+ if (n == drc_config->dwnmix_instructions_count) {
+ return (UNEXPECTED_ERROR);
}
- else
- {
- for(n=0; n<drc_config->dwnmix_instructions_count; n++)
- {
- if (drc_config->dwnmix_instructions[n].downmix_id == downmix_id_selected)
- break;
- }
- if (n == drc_config->dwnmix_instructions_count)
- {
- return (UNEXPECTED_ERROR);
- }
- channel_count = drc_config->dwnmix_instructions[n].target_channel_count;
-
- downmix_instructions_selected = n;
+ channel_count = drc_config->dwnmix_instructions[n].target_channel_count;
+
+ downmix_instructions_selected = n;
+ }
+ drc_instructions_uni_drc->audio_num_chan = channel_count;
+
+ if (drc_instructions_uni_drc->drc_set_id <= 0) {
+ drc_coefficients_selected = 0;
+ } else {
+ err = impd_select_drc_coefficients(drc_config, &drc_coefficients_uni_drc,
+ &drc_coefficients_selected);
+ }
+
+ ia_drc_params_struct->sel_drc_array[ia_drc_params_struct->drc_set_counter]
+ .drc_instructions_index = drc_instructions_selected;
+ ia_drc_params_struct->sel_drc_array[ia_drc_params_struct->drc_set_counter]
+ .dwnmix_instructions_index = downmix_instructions_selected;
+ ia_drc_params_struct->sel_drc_array[ia_drc_params_struct->drc_set_counter]
+ .drc_coeff_idx = drc_coefficients_selected;
+
+ if ((drc_instructions_uni_drc->downmix_id[0] == ID_FOR_ANY_DOWNMIX) ||
+ (drc_instructions_uni_drc->dwnmix_id_count > 1)) {
+ WORD32 idx = drc_instructions_uni_drc->gain_set_index[0];
+ for (c = 0; c < drc_instructions_uni_drc->audio_num_chan; c++) {
+ drc_instructions_uni_drc->channel_group_of_ch[c] = (idx >= 0) ? 0 : -1;
}
- drc_instructions_uni_drc->audio_num_chan = channel_count;
-
- if (drc_instructions_uni_drc->drc_set_id <= 0)
- {
- drc_coefficients_selected = 0;
+ }
+
+ for (g = 0; g < drc_instructions_uni_drc->num_drc_ch_groups; g++) {
+ drc_instructions_uni_drc->num_chan_per_ch_group[g] = 0;
+ for (c = 0; c < drc_instructions_uni_drc->audio_num_chan; c++) {
+ if (drc_instructions_uni_drc->channel_group_of_ch[c] == g) {
+ drc_instructions_uni_drc->num_chan_per_ch_group[g]++;
+ }
}
- else
- {
- err = impd_select_drc_coefficients(drc_config, &drc_coefficients_uni_drc, &drc_coefficients_selected);
+ }
+
+ if (drc_instructions_uni_drc->drc_set_effect &
+ (EFFECT_BIT_DUCK_OTHER | EFFECT_BIT_DUCK_SELF)) {
+ drc_instructions_uni_drc->multiband_audio_sig_count =
+ drc_instructions_uni_drc->audio_num_chan;
+ } else {
+ drc_instructions_uni_drc->multiband_audio_sig_count = 0;
+ for (c = 0; c < drc_instructions_uni_drc->audio_num_chan; c++) {
+ g = drc_instructions_uni_drc->channel_group_of_ch[c];
+ if (g < 0) {
+ drc_instructions_uni_drc->multiband_audio_sig_count++;
+ } else {
+ drc_instructions_uni_drc->multiband_audio_sig_count +=
+ drc_instructions_uni_drc->band_count_of_ch_group[g];
+ }
}
+ }
- ia_drc_params_struct->sel_drc_array[ia_drc_params_struct->drc_set_counter].drc_instructions_index = drc_instructions_selected;
- ia_drc_params_struct->sel_drc_array[ia_drc_params_struct->drc_set_counter].dwnmix_instructions_index = downmix_instructions_selected;
- ia_drc_params_struct->sel_drc_array[ia_drc_params_struct->drc_set_counter].drc_coeff_idx = drc_coefficients_selected;
-
- if ((drc_instructions_uni_drc->downmix_id[0] == ID_FOR_ANY_DOWNMIX) || (drc_instructions_uni_drc->dwnmix_id_count > 1))
- {
- WORD32 idx = drc_instructions_uni_drc->gain_set_index[0];
- for (c=0; c<drc_instructions_uni_drc->audio_num_chan; c++)
- {
- drc_instructions_uni_drc->channel_group_of_ch[c] = (idx >= 0) ? 0 : -1;
- }
+ for (g = 0; g < drc_instructions_uni_drc->num_drc_ch_groups; g++) {
+ if (g == 0) {
+ drc_instructions_uni_drc->parametric_drc_look_ahead_samples_max = 0;
}
-
- for (g=0; g<drc_instructions_uni_drc->num_drc_ch_groups; g++) {
- drc_instructions_uni_drc->num_chan_per_ch_group[g] = 0;
- for (c=0; c<drc_instructions_uni_drc->audio_num_chan; c++) {
- if (drc_instructions_uni_drc->channel_group_of_ch[c] == g) {
- drc_instructions_uni_drc->num_chan_per_ch_group[g]++;
- }
+ if (drc_instructions_uni_drc->ch_group_parametric_drc_flag[g] == 0) {
+ if (drc_instructions_uni_drc->band_count_of_ch_group[g] > 1) {
+ if (ia_drc_params_struct->multiband_sel_drc_idx != -1) {
+ return (UNEXPECTED_ERROR);
}
- }
-
- if (drc_instructions_uni_drc->drc_set_effect & (EFFECT_BIT_DUCK_OTHER | EFFECT_BIT_DUCK_SELF)) {
- drc_instructions_uni_drc->multiband_audio_sig_count = drc_instructions_uni_drc->audio_num_chan;
+ selected_drc_is_multiband = 1;
+ }
} else {
- drc_instructions_uni_drc->multiband_audio_sig_count = 0;
- for (c=0; c<drc_instructions_uni_drc->audio_num_chan; c++) {
- g = drc_instructions_uni_drc->channel_group_of_ch[c];
- if (g < 0) {
- drc_instructions_uni_drc->multiband_audio_sig_count++;
- } else {
- drc_instructions_uni_drc->multiband_audio_sig_count += drc_instructions_uni_drc->band_count_of_ch_group[g];
- }
+ WORD32 gain_set_index =
+ drc_instructions_uni_drc->gain_set_idx_of_ch_group_parametric_drc[g];
+ WORD32 parametric_drc_id =
+ drc_config->str_drc_config_ext.str_drc_coeff_param_drc
+ .str_parametric_drc_gain_set_params[gain_set_index]
+ .parametric_drc_id;
+ WORD32 parametric_drc_look_ahead_samples = 0;
+ ia_parametric_drc_instructions_struct* str_parametric_drc_instructions;
+
+ for (i = 0;
+ i < drc_config->str_drc_config_ext.parametric_drc_instructions_count;
+ i++) {
+ if (parametric_drc_id ==
+ drc_config->str_drc_config_ext.str_parametric_drc_instructions[i]
+ .parametric_drc_id)
+ break;
+ }
+ if (i ==
+ drc_config->str_drc_config_ext.parametric_drc_instructions_count) {
+ return (UNEXPECTED_ERROR);
+ }
+ str_parametric_drc_instructions =
+ &drc_config->str_drc_config_ext.str_parametric_drc_instructions[i];
+
+ p_parametric_drc_params->parametric_drc_idx
+ [p_parametric_drc_params->parametric_drc_instance_count] = i;
+ p_parametric_drc_params->gain_set_index
+ [p_parametric_drc_params->parametric_drc_instance_count] =
+ gain_set_index;
+ if (drc_instructions_uni_drc->drc_apply_to_dwnmix == 0) {
+ p_parametric_drc_params->dwnmix_id_from_drc_instructions
+ [p_parametric_drc_params->parametric_drc_instance_count] =
+ ID_FOR_BASE_LAYOUT;
+ } else {
+ if (drc_instructions_uni_drc->dwnmix_id_count > 1) {
+ p_parametric_drc_params->dwnmix_id_from_drc_instructions
+ [p_parametric_drc_params->parametric_drc_instance_count] =
+ ID_FOR_ANY_DOWNMIX;
+ } else {
+ p_parametric_drc_params->dwnmix_id_from_drc_instructions
+ [p_parametric_drc_params->parametric_drc_instance_count] =
+ drc_instructions_uni_drc->downmix_id[0];
}
- }
-
- for (g=0; g<drc_instructions_uni_drc->num_drc_ch_groups; g++)
- {
- if (g==0) {
- drc_instructions_uni_drc->parametric_drc_look_ahead_samples_max = 0;
+ }
+ p_parametric_drc_params->audio_num_chan = channel_count;
+ for (i = 0; i < p_parametric_drc_params->audio_num_chan; i++) {
+ if (drc_instructions_uni_drc->channel_group_of_ch[i] == g) {
+ p_parametric_drc_params->channel_map
+ [p_parametric_drc_params->parametric_drc_instance_count][i] = 1;
+ } else {
+ p_parametric_drc_params->channel_map
+ [p_parametric_drc_params->parametric_drc_instance_count][i] = 0;
}
- if (drc_instructions_uni_drc->ch_group_parametric_drc_flag[g] == 0) {
- if (drc_instructions_uni_drc->band_count_of_ch_group[g] > 1)
- {
- if (ia_drc_params_struct->multiband_sel_drc_idx != -1)
- {
- return (UNEXPECTED_ERROR);
- }
- selected_drc_is_multiband = 1;
- }
+ }
+ drc_instructions_uni_drc->parametric_drc_look_ahead_samples[g] = 0;
+ if (str_parametric_drc_instructions->parametric_drc_look_ahead_flag) {
+ parametric_drc_look_ahead_samples = (WORD32)(
+ (FLOAT32)
+ str_parametric_drc_instructions->parametric_drc_look_ahead *
+ (FLOAT32)p_parametric_drc_params->sampling_rate * 0.001f);
+ } else {
+ if (str_parametric_drc_instructions->parametric_drc_type ==
+ PARAM_DRC_TYPE_FF) {
+ parametric_drc_look_ahead_samples = (WORD32)(
+ 10.0f * (FLOAT32)p_parametric_drc_params->sampling_rate * 0.001f);
+ } else if (str_parametric_drc_instructions->parametric_drc_type ==
+ PARAM_DRC_TYPE_LIM) {
+ parametric_drc_look_ahead_samples = (WORD32)(
+ 5.0f * (FLOAT32)p_parametric_drc_params->sampling_rate * 0.001f);
} else {
- WORD32 gain_set_index = drc_instructions_uni_drc->gain_set_idx_of_ch_group_parametric_drc[g];
- WORD32 parametric_drc_id = drc_config->str_drc_config_ext.str_drc_coeff_param_drc.str_parametric_drc_gain_set_params[gain_set_index].parametric_drc_id;
- WORD32 parametric_drc_look_ahead_samples = 0;
- ia_parametric_drc_instructions_struct* str_parametric_drc_instructions;
-
- for(i=0; i<drc_config->str_drc_config_ext.parametric_drc_instructions_count; i++)
- {
- if (parametric_drc_id == drc_config->str_drc_config_ext.str_parametric_drc_instructions[i].parametric_drc_id) break;
- }
- if (i == drc_config->str_drc_config_ext.parametric_drc_instructions_count)
- {
- return (UNEXPECTED_ERROR);
- }
- str_parametric_drc_instructions = &drc_config->str_drc_config_ext.str_parametric_drc_instructions[i];
-
- p_parametric_drc_params->parametric_drc_idx[p_parametric_drc_params->parametric_drc_instance_count] = i;
- p_parametric_drc_params->gain_set_index[p_parametric_drc_params->parametric_drc_instance_count] = gain_set_index;
- if (drc_instructions_uni_drc->drc_apply_to_dwnmix == 0) {
- p_parametric_drc_params->dwnmix_id_from_drc_instructions[p_parametric_drc_params->parametric_drc_instance_count] = ID_FOR_BASE_LAYOUT;
- } else {
- if (drc_instructions_uni_drc->dwnmix_id_count > 1) {
- p_parametric_drc_params->dwnmix_id_from_drc_instructions[p_parametric_drc_params->parametric_drc_instance_count] = ID_FOR_ANY_DOWNMIX;
- } else {
- p_parametric_drc_params->dwnmix_id_from_drc_instructions[p_parametric_drc_params->parametric_drc_instance_count] = drc_instructions_uni_drc->downmix_id[0];
- }
- }
- p_parametric_drc_params->audio_num_chan = channel_count;
- for (i=0; i<p_parametric_drc_params->audio_num_chan;i++) {
- if (drc_instructions_uni_drc->channel_group_of_ch[i] == g) {
- p_parametric_drc_params->channel_map[p_parametric_drc_params->parametric_drc_instance_count][i] = 1;
- } else {
- p_parametric_drc_params->channel_map[p_parametric_drc_params->parametric_drc_instance_count][i] = 0;
- }
- }
- drc_instructions_uni_drc->parametric_drc_look_ahead_samples[g] = 0;
- if (str_parametric_drc_instructions->parametric_drc_look_ahead_flag) {
- parametric_drc_look_ahead_samples = (WORD32)((FLOAT32)str_parametric_drc_instructions->parametric_drc_look_ahead*(FLOAT32)p_parametric_drc_params->sampling_rate*0.001f);
- } else {
- if (str_parametric_drc_instructions->parametric_drc_type == PARAM_DRC_TYPE_FF)
- {
- parametric_drc_look_ahead_samples = (WORD32)(10.0f*(FLOAT32)p_parametric_drc_params->sampling_rate*0.001f);
- }
- else if (str_parametric_drc_instructions->parametric_drc_type == PARAM_DRC_TYPE_LIM)
- {
- parametric_drc_look_ahead_samples = (WORD32)(5.0f*(FLOAT32)p_parametric_drc_params->sampling_rate*0.001f);
- } else
- {
- return (UNEXPECTED_ERROR);
- }
- }
- drc_instructions_uni_drc->parametric_drc_look_ahead_samples[g] = parametric_drc_look_ahead_samples;
- if (drc_instructions_uni_drc->parametric_drc_look_ahead_samples_max < drc_instructions_uni_drc->parametric_drc_look_ahead_samples[g])
- {
- drc_instructions_uni_drc->parametric_drc_look_ahead_samples_max = drc_instructions_uni_drc->parametric_drc_look_ahead_samples[g];
- }
- p_parametric_drc_params->parametric_drc_instance_count += 1;
- selected_drc_is_multiband = 0;
+ return (UNEXPECTED_ERROR);
}
+ }
+ drc_instructions_uni_drc->parametric_drc_look_ahead_samples[g] =
+ parametric_drc_look_ahead_samples;
+ if (drc_instructions_uni_drc->parametric_drc_look_ahead_samples_max <
+ drc_instructions_uni_drc->parametric_drc_look_ahead_samples[g]) {
+ drc_instructions_uni_drc->parametric_drc_look_ahead_samples_max =
+ drc_instructions_uni_drc->parametric_drc_look_ahead_samples[g];
+ }
+ p_parametric_drc_params->parametric_drc_instance_count += 1;
+ selected_drc_is_multiband = 0;
}
- ia_drc_params_struct->parametric_drc_delay += drc_instructions_uni_drc->parametric_drc_look_ahead_samples_max;
-
- if (selected_drc_is_multiband == 1)
- {
- ia_drc_params_struct->multiband_sel_drc_idx = ia_drc_params_struct->drc_set_counter;
- err = impd_init_all_filter_banks(drc_coefficients_uni_drc,
- &(drc_config->str_drc_instruction_str[drc_instructions_selected]),
- ia_filter_banks_struct);
- if (err)
- return (err);
-
- err = impd_init_overlap_weight (drc_coefficients_uni_drc,
- &(drc_config->str_drc_instruction_str[drc_instructions_selected]),
- ia_drc_params_struct->sub_band_domain_mode,
- pstr_overlap_params);
- if (err)
- return (err);
- }
- else
- {
- ia_gain_modifiers_struct* gain_modifiers = drc_config->str_drc_instruction_str->str_gain_modifiers_of_ch_group;
- for (g=0; g<drc_instructions_uni_drc->num_drc_ch_groups; g++)
- {
- if (gain_modifiers[g].shape_filter_flag == 1)
- {
- impd_shape_filt_block_init(&drc_coefficients_uni_drc->str_shape_filter_block_params[gain_modifiers[g].shape_filter_idx],
- &shape_filter_block[g]);
- }
- else
- {
- shape_filter_block[g].shape_flter_block_flag = 0;
- }
- }
+ }
+ ia_drc_params_struct->parametric_drc_delay +=
+ drc_instructions_uni_drc->parametric_drc_look_ahead_samples_max;
+
+ if (selected_drc_is_multiband == 1) {
+ ia_drc_params_struct->multiband_sel_drc_idx =
+ ia_drc_params_struct->drc_set_counter;
+ err = impd_init_all_filter_banks(
+ drc_coefficients_uni_drc,
+ &(drc_config->str_drc_instruction_str[drc_instructions_selected]),
+ ia_filter_banks_struct);
+ if (err) return (err);
+
+ err = impd_init_overlap_weight(
+ drc_coefficients_uni_drc,
+ &(drc_config->str_drc_instruction_str[drc_instructions_selected]),
+ ia_drc_params_struct->sub_band_domain_mode, pstr_overlap_params);
+ if (err) return (err);
+ } else {
+ ia_gain_modifiers_struct* gain_modifiers =
+ drc_config->str_drc_instruction_str->str_gain_modifiers_of_ch_group;
+ for (g = 0; g < drc_instructions_uni_drc->num_drc_ch_groups; g++) {
+ if (gain_modifiers[g].shape_filter_flag == 1) {
+ impd_shape_filt_block_init(
+ &drc_coefficients_uni_drc->str_shape_filter_block_params
+ [gain_modifiers[g].shape_filter_idx],
+ &shape_filter_block[g]);
+ } else {
+ shape_filter_block[g].shape_flter_block_flag = 0;
+ }
}
+ }
- ia_drc_params_struct->drc_set_counter++;
+ ia_drc_params_struct->drc_set_counter++;
- return (0);
+ return (0);
}