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

Gain computer used to realize soft-knee peak limiters

Discussion

The limiter core provides a peak amplitude follower and input/output gain transfer function for use in AGC systems. It is designed to take as its input the output of the AbsModule. The module outputs the time varying gain on the mono output pin which is typically used as input to the AGCMultiplierModule. The peak following amplitude detector and the gain transfer function are calculated at the sample rate, which aids in reducing the gain of fast transients.

The module stores the gain computed for the last sample in the block to the currentGain state variable. This variable can be examined to track the behavior of the limiter.

Type Definition

typedef struct _ModuleAGCLimiterCore
{
    ModuleInstanceDescriptor instance;            // Common Audio Weaver module instance structure
    FLOAT32 threshold;                            // Amplitude level at which the AGC Limiter Core reduces its output gain value
    FLOAT32 gain;                                 // Value used to scale the output of the AGC Limiter Core
    FLOAT32 slope;                                // Internal derived variable which holds the slope of the compression curve
    FLOAT32 kneeDepth;                            // Knee depth controls the sharpness of the transition between no limiting and limiting
    FLOAT32 ratio;                                // Slope of the output attenuation when the signal is above threshold - derived from the standard compression ratio parameter by the formula slope = 1.0 - (1.0/ratio)
    FLOAT32 attackTime;                           // Envelope detector attack time constant
    FLOAT32 decayTime;                            // Envelope detector decay time constant
    FLOAT32 currentGain;                          // Instantaneous gain computed by the block
    FLOAT32 sharpnessFactor;                      // Internal derived variable which is used to implement the soft knee
    FLOAT32 attackCoeff;                          // Internal derived variable which implements the attackTime
    FLOAT32 decayCoeff;                           // Internal derived variable which implements the decayTime
    FLOAT32 envState;                             // Holds the instantaneous state of the envelope detector
} ModuleAGCLimiterCoreClass;

Variables

Properties

Name

Type

Usage

isHidden

Default value

Range

Units

threshold

float

parameter

0

-20

-60:0

dB

gain

float

parameter

0

0

-24:24

dB

slope

float

derived

0

0.75

0:100

dB/dB

kneeDepth

float

parameter

0

2

0.1:60

dB

ratio

float

parameter

0

4

0.1:100

attackTime

float

parameter

0

20

0.01:1000

msec

decayTime

float

parameter

0

100

0.01:1000

msec

currentGain

float

state

0

0

Unrestricted

dB

sharpnessFactor

float

derived

1

0.5

Unrestricted

attackCoeff

float

derived

1

0.001041

Unrestricted

decayCoeff

float

derived

1

0.0002083

Unrestricted

envState

float

state

1

0

Unrestricted

dB

Pins

Input Pins

Name: in

Description: audio input

Data type: float

Channel range: 1

Block size range: Unrestricted

Sample rate range: Unrestricted

Complex support: Real

Output Pins

Name: out

Description: audio output

Data type: float

MATLAB Usage

File Name: agc_limiter_core_module.m

 M=agc_limiter_core_module(NAME)
 Creates a limiter gain computer with soft knee for use in Audio
 Weaver. It is used in conjunction with the AGCMultiplier to 
 implement full limiter.
 
 Arguments:
    NAME - name of the module.

  • No labels