Ulf@564: #ifndef AGC_H_ Ulf@564: #define AGC_H_ Ulf@564: Ulf@564: #include "CARFAC_common.h" Ulf@564: Ulf@564: class AGC_parameters { Ulf@564: public: Ulf@564: AGC_parameters(): Ulf@564: n_stages_(4), Ulf@564: time_constants_({0.002*1, 0.002*4, 0.002*16, 0.002*64}), Ulf@564: agc_stage_gain_(2), Ulf@564: decimation_({8, 2, 2, 2}), Ulf@564: agc1_scales_({1.0, 1.4, 2.0, 2.8}), Ulf@564: agc2_scales_({1.6, 2.25, 3.2, 4.5}), Ulf@564: detect_scale_(0.25), Ulf@564: agc_mix_coeff_(0.5){ Ulf@564: // do nothing more Ulf@564: } Ulf@564: Ulf@564: virtual ~AGC_parameters(){ Ulf@564: // do nothing Ulf@564: } Ulf@564: Ulf@564: int n_stages_; Ulf@564: FloatArray time_constants_; Ulf@564: float agc_stage_gain_; Ulf@564: FloatArray decimation_; Ulf@564: FloatArray agc1_scales_; Ulf@564: FloatArray agc2_scales_; Ulf@564: float detect_scale_; Ulf@564: float agc_mix_coeff_; Ulf@564: }; Ulf@564: Ulf@564: class AGC_coefficients { Ulf@564: public: Ulf@564: AGC_coefficients(AGC_parameters*, float, int); Ulf@564: virtual ~AGC_coefficients(); Ulf@564: Ulf@564: int n_ch_; Ulf@564: int n_agc_stages_; Ulf@564: float agc_stage_gain_; Ulf@564: FloatArray agc_epsilon_; Ulf@564: FloatArray decimation_; Ulf@564: FloatArray agc_polez1_; Ulf@564: FloatArray agc_polez2_; Ulf@564: FloatArray agc_spatial_iterations_; Ulf@564: FloatMatrix agc_spatial_fir_; Ulf@564: FloatArray agc_spatial_n_taps_; Ulf@564: FloatArray agc_mix_coeffs_; Ulf@564: float agc_gain_; Ulf@564: float detect_scale_; Ulf@564: Ulf@564: private: Ulf@564: AGC_coefficients(); Ulf@564: FloatArray Build_FIR_coeffs(float, float, int*, int*); Ulf@564: }; Ulf@564: Ulf@564: #endif /* AGC_H_ */