libxaac/encoder/drc_src/impd_drc_uni_drc_eq.h
2023-07-14 13:04:15 +05:30

172 lines
5.9 KiB
C

/******************************************************************************
* *
* Copyright (C) 2023 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*****************************************************************************
* Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
*/
#pragma once
#define MAX_EQ_CHANNEL_COUNT (8)
#define MAX_EQ_AUDIO_DELAY (1024)
#define MAX_EQ_FIR_FILTER_SIZE (128)
#define MAX_EQ_SUBBAND_COUNT (256)
#define MAX_EQ_INTERMEDIATE_2ND_ORDER_PARAMS_COUNT (32)
#define MAX_EQ_FILTER_SECTION_COUNT (8)
#define MAX_EQ_FILTER_ELEMENT_COUNT (4)
#define MAX_MATCHING_PHASE_FILTER_COUNT (32)
#define EQ_FILTER_DOMAIN_NONE 0
#define EQ_FILTER_DOMAIN_TIME (1)
#define EQ_FILTER_DOMAIN_SUBBAND (2)
#define CONFIG_REAL_POLE (0)
#define CONFIG_COMPLEX_POLE (1)
#define CONFIG_REAL_ZERO_RADIUS_ONE (2)
#define CONFIG_REAL_ZERO (3)
#define CONFIG_GENERIC_ZERO (4)
#define STEP_RATIO_F_LOW (20.0f)
#define FILTER_ELEMENT_FORMAT_POLE_ZERO (0)
#define FILTER_ELEMENT_FORMAT_FIR (1)
#ifndef M_PI
#define M_PI (3.14159265358979323846)
#endif
#define STEP_RATIO_COMPUTED (0.0739601776f)
typedef struct {
WORD32 delay;
FLOAT32 state[MAX_EQ_CHANNEL_COUNT][MAX_EQ_AUDIO_DELAY];
} ia_drc_audio_delay_struct;
typedef struct {
FLOAT32 radius;
FLOAT32 coeff[2];
} ia_drc_second_order_filter_params_struct;
typedef struct {
WORD32 coeff_count;
FLOAT32 coeff[MAX_EQ_FIR_FILTER_SIZE];
FLOAT32 state[MAX_EQ_CHANNEL_COUNT][MAX_EQ_FIR_FILTER_SIZE];
} ia_drc_fir_filter_struct;
typedef struct {
WORD32 eq_frame_size_subband;
WORD32 coeff_count;
FLOAT32 subband_coeff[MAX_EQ_SUBBAND_COUNT];
} ia_drc_subband_filter_struct;
typedef struct {
WORD32 filter_format;
WORD32 filter_param_count_for_zeros;
ia_drc_second_order_filter_params_struct
str_second_order_filter_params_for_zeros[MAX_EQ_INTERMEDIATE_2ND_ORDER_PARAMS_COUNT];
WORD32 filter_param_count_for_poles;
ia_drc_second_order_filter_params_struct
str_second_order_filter_params_for_poles[MAX_EQ_INTERMEDIATE_2ND_ORDER_PARAMS_COUNT];
ia_drc_fir_filter_struct str_fir_filter;
} ia_drc_intermediate_filter_params_struct;
typedef struct {
FLOAT32 state_in_1;
FLOAT32 state_in_2;
FLOAT32 state_out_1;
FLOAT32 state_out_2;
} ia_drc_filter_section_state_struct;
typedef struct {
FLOAT32 var_a1;
FLOAT32 var_a2;
FLOAT32 var_b1;
FLOAT32 var_b2;
ia_drc_filter_section_state_struct str_filter_section_state[MAX_EQ_CHANNEL_COUNT];
} ia_drc_filter_section_struct;
typedef struct {
WORD32 member_count;
WORD32 member_index[EQ_MAX_CHANNEL_GROUP_COUNT];
} ia_drc_cascade_alignment_group_struct;
typedef struct {
WORD32 is_valid;
WORD32 matches_filter_count;
WORD32 matches_filter[MAX_EQ_FILTER_SECTION_COUNT];
FLOAT32 gain;
WORD32 section_count;
ia_drc_filter_section_struct str_filter_section[MAX_EQ_FILTER_SECTION_COUNT];
ia_drc_audio_delay_struct str_audio_delay;
} ia_drc_phase_alignment_filter_struct;
typedef ia_drc_phase_alignment_filter_struct ia_drc_matching_phase_filter_struct;
typedef struct {
WORD32 matches_cascade_index;
WORD32 allpass_count;
ia_drc_matching_phase_filter_struct str_matching_phase_filter[MAX_MATCHING_PHASE_FILTER_COUNT];
} ia_drc_allpass_chain_struct;
typedef struct {
WORD32 section_count;
ia_drc_filter_section_struct str_filter_section[MAX_EQ_FILTER_SECTION_COUNT];
WORD32 fir_coeffs_present;
ia_drc_fir_filter_struct str_fir_filter;
ia_drc_audio_delay_struct str_audio_delay;
} ia_drc_pole_zero_filter_struct;
typedef struct {
FLOAT32 element_gain_linear;
WORD32 format;
ia_drc_pole_zero_filter_struct str_pole_zero_filter;
ia_drc_fir_filter_struct str_fir_filter;
WORD32 phase_alignment_filter_count;
ia_drc_phase_alignment_filter_struct str_phase_alignment_filter[MAX_EQ_FILTER_ELEMENT_COUNT];
} ia_drc_eq_filter_element_struct;
typedef struct {
WORD32 element_count;
ia_drc_eq_filter_element_struct str_eq_filter_element[MAX_EQ_FILTER_ELEMENT_COUNT];
ia_drc_matching_phase_filter_struct str_matching_phase_filter_element_0;
} ia_drc_eq_filter_block_struct;
typedef struct {
FLOAT32 cascade_gain_linear;
WORD32 block_count;
ia_drc_eq_filter_block_struct str_eq_filter_block[EQ_FILTER_BLOCK_COUNT_MAX];
WORD32 phase_alignment_filter_count;
ia_drc_phase_alignment_filter_struct
str_phase_alignment_filter[EQ_FILTER_BLOCK_COUNT_MAX * EQ_FILTER_BLOCK_COUNT_MAX];
} ia_drc_filter_cascade_t_domain_struct;
typedef struct {
WORD32 domain;
WORD32 audio_channel_count;
WORD32 eq_channel_group_count;
WORD32 eq_channel_group_for_channel[MAX_EQ_CHANNEL_COUNT];
ia_drc_filter_cascade_t_domain_struct str_filter_cascade_t_domain[EQ_MAX_CHANNEL_GROUP_COUNT];
ia_drc_subband_filter_struct str_subband_filter[EQ_MAX_CHANNEL_GROUP_COUNT];
} ia_drc_eq_set_struct;
IA_ERRORCODE impd_drc_derive_eq_set(ia_drc_eq_coefficients_struct *pstr_eq_coefficients,
ia_drc_eq_instructions_struct *pstr_eq_instructions,
const FLOAT32 audio_sample_rate, const WORD32 drc_frame_size,
const WORD32 sub_band_domain_mode,
ia_drc_eq_set_struct *pstr_eq_set, VOID *ptr_scratch,
WORD32 *scratch_used);
IA_ERRORCODE impd_drc_get_eq_complexity(ia_drc_eq_set_struct *pstr_eq_set,
WORD32 *eq_complexity_level);