Overview
Automatic Gain Control gain calculator module
Type Definition
typedef struct _ModuleAGCCoreFract32 { ModuleInstanceDescriptor instance; // Common Audio Weaver module instance structure FLOAT32 targetLevel; // Target audio level FLOAT32 maxAttenuation; // Maximum attenuation of the AGC FLOAT32 maxGain; // Maximum gain of the AGC FLOAT32 ratio; // Slope of the output attenuation when the signal is above threshold FLOAT32 activationThreshold; // Activation threshold of the AGC. The AGC stops updating its gain when the instantaneous input level is below this value FLOAT32 smoothingTime; // Response time of the AGC. This controls the RMS smoothing interval and the time constant of the smoothly updating gain INT32 enableRecovery; // Boolean which enables the AGC's gain recovery. If enabled, the AGC slows returns 0 dB gain when the input is below the activation threshold FLOAT32 recoveryRate; // Rate at which the gain is adjusted when the input is below the activation threshold FLOAT32 currentGain; // Instantaneous gain of the smoothing operation. fract32 smoothingCoeffSampleFract32; // Sample-by-sample smoothing coefficient for the output gain adjustment. Set via smoothingTime. fract32 smoothingCoeffBlockFract32; // Block-by-block smoothing coefficient for the RMS measurement. Set via smoothingTime. fract32 targetGainFract32; // Target gain of the smoothing operation. fract32 energyFract32; // Smoothed energy measurement. fract32 oneOverNumSamplesFract32; // 1 divided by the number of samples in the input pin. Used internally by the algorithm in order to save a divide operation. fract32 oneOverSlopeFract32; // Used by the processing function to compute the amount of cut/boost. Equal to 1-1/ratio. FLOAT32 oneOverSlope; // Used by the processing function to compute the amount of cut/boost. Equal to 1-1/ratio. FLOAT32 smoothingCoeffSample; // Sample-by-sample smoothing coefficient for the output gain adjustment. Set via smoothingTime. FLOAT32 smoothingCoeffBlock; // Block-by-block smoothing coefficient for the RMS measurement. Set via smoothingTime. FLOAT32 recoveryRateUp; // Recovery rate coefficient when increasing the gain (it is always >= 1) FLOAT32 recoveryRateDown; // Recovery rate coefficient when decreasing the gain (it is always <= 1) FLOAT32 targetGain; // Target gain of the smoothing operation. FLOAT32 energy; // Smoothed energy measurement. FLOAT32 oneOverNumSamples; // 1 divided by the number of samples in the input pin. Used internally by the algorithm in order to save a divide operation. fract32 targetLevelFract32; // Target audio level fract32 maxGainFract32; // Maximum gain of the AGC fract32 maxAttenuationFract32; // Maximum attenuation of the AGC fract32 activationThresholdFract32; // Activation threshold of the AGC. The AGC stops updating its gain when the instantaneous input level is below this value fract32 recoveryRateUpFract32; // Recovery rate coefficient when increasing the gain (it is always >= 1) fract32 recoveryRateDownFract32; // Recovery rate coefficient when decreasing the gain (it is always <= 1) fract32 currentGainFract32; // Instantaneous gain of the smoothing operation. } ModuleAGCCoreFract32Class;
Variables
Properties
Name | Type | Usage | isHidden | Default value | Range | Units |
targetLevel | float | parameter | 0 | -20 | -50:0.1:50 | dB |
maxAttenuation | float | parameter | 0 | 100 | 0:100 | dB |
maxGain | float | parameter | 0 | 12 | 0:50 | dB |
ratio | float | parameter | 0 | 10 | 1:100 | dB/dB |
activationThreshold | float | parameter | 0 | -50 | -100:-20 | dB |
smoothingTime | float | parameter | 0 | 100 | 1:5000 | msec |
enableRecovery | int | parameter | 0 | 1 | 0:1 | |
recoveryRate | float | parameter | 0 | 2.4 | 1:20 | dB/sec |
currentGain | float | state | 0 | 0 | -12:12 | |
smoothingCoeffSampleFract32 | fract32 | derived | 0 | 0.0002083 | Unrestricted | |
smoothingCoeffBlockFract32 | fract32 | derived | 0 | 0.006644 | Unrestricted | |
targetGainFract32 | fract32 | state | 0 | 0 | Unrestricted | |
energyFract32 | fract32 | state | 0 | 0 | Unrestricted | |
oneOverNumSamplesFract32 | fract32 | derived | 0 | 0.03125 | Unrestricted | |
oneOverSlopeFract32 | fract32 | derived | 0 | 0.9 | Unrestricted | |
oneOverSlope | float | derived | 1 | 0.9 | Unrestricted | |
smoothingCoeffSample | float | derived | 1 | 0.0002083 | Unrestricted | |
smoothingCoeffBlock | float | derived | 1 | 0.006644 | Unrestricted | |
recoveryRateUp | float | derived | 1 | 1 | Unrestricted | |
recoveryRateDown | float | derived | 1 | 0.9998 | Unrestricted | |
targetGain | float | state | 1 | 0 | Unrestricted | |
energy | float | state | 1 | 0 | Unrestricted | |
oneOverNumSamples | float | derived | 1 | 0.03125 | Unrestricted | |
targetLevelFract32 | fract32 | derived | 1 | -0.1563 | Unrestricted | |
maxGainFract32 | fract32 | derived | 1 | 0.09375 | Unrestricted | |
maxAttenuationFract32 | fract32 | derived | 1 | 0.7813 | Unrestricted | |
activationThresholdFract32 | fract32 | derived | 1 | -0.3906 | Unrestricted | |
recoveryRateUpFract32 | fract32 | derived | 1 | 0.25 | Unrestricted | |
recoveryRateDownFract32 | fract32 | derived | 1 | 0.25 | Unrestricted | |
currentGainFract32 | fract32 | state | 1 | 0 | Unrestricted |
Pins
Input Pins
Name: in
Description: Audio input
Data type: fract32
Channel range: 1
Block size range: Unrestricted
Sample rate range: Unrestricted
Complex support: Real
Output Pins
Name: out
Description: audio output
Data type: fract32
MATLAB Usage
File Name: agc_core_fract32_module.m
M=agc_core_fract32_module(NAME) Audio Weaver modules which calculates the instantaneous gain needed by an automatic gain control AGC module. This module is used in conjunction with the agc_multiplier_module. The input format for this module is 1.31 and output format is 4.28. NAME - name of the module.