Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

Version 1 Current »

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.

  • No labels