We can model dynamic range compression as an amplitude-dependent
gain. Multiplying a signal by a constant gain (``volume control''),
on the other hand, is a linear operation. Let's check that the
scaling and superposition properties of linear systems are satisfied
by a constant gain: For any signals , and for any constants
, we must have
Since this is obviously true from the algebraic properties of real or
complex numbers, both scaling and superposition have been
verified. (For clarity, an explicit ``'' is used to indicate
multiplication.)
Dynamic range compression can also be seen as a time-varying
gain factor, so one might be tempted to classify it as a linear,
time-varying filter. However, this would be incorrect because the
gain , which multiplies the input, depends on the input
signal . This happens because the compressor must estimate the
current signal level in order to normalize it. Dynamic range
compression can be expressed symbolically as a filter of the form
where denotes a gain that depends on the ``current
amplitude'' of at time . Since many successive samples
of are needed to estimate current average amplitude level, we
cannot correctly write for the gain function, although we
could write something like
(borrowing matlab syntax), where
is the number of past samples needed to estimate the current amplitude level. In
general,
That is, the compression of the sum of two signals is not generally
the same as the addition of the two signals compressed
individually. Therefore, the superposition condition of linearity
fails. It is also clear that the scaling condition fails.
In general, any signal operation that includes a multiplication in
which both multiplicands depend on the input signal can be shown to be
nonlinear.