data:image/s3,"s3://crabby-images/63140/631404d05cc5ae1b63646768df60738d595666f9" alt=""
Least mean squares filter
Encyclopedia
Least mean squares algorithms are a class of adaptive filter
used to mimic a desired filter by finding the filter coefficients that relate to producing the least mean squares of the error signal (difference between the desired and the actual signal). It is a stochastic gradient descent
method in that the filter is only adapted based on the error at the current time. It was invented in 1960 by Stanford University
professor Bernard Widrow
and his first Ph.D. student, Ted Hoff.
data:image/s3,"s3://crabby-images/c19f2/c19f27d9f2e92404191308c80d75aa77429a6ad2" alt=""
Relationship to the least mean squares filter
The realization of the causal Wiener filter looks a lot like the solution to the least squares estimate, except in the signal processing domain. The least squares solution, for input matrix
and output vector data:image/s3,"s3://crabby-images/7aca8/7aca8449ef8d26cd98197bb859a71b771279bcae" alt=""
is
data:image/s3,"s3://crabby-images/ee6b5/ee6b54a8aff9007be1d1caeee40ee882593ca04c" alt=""
The FIR Wiener filter is related to the least mean squares filter, but minimizing its error criterion does not rely on cross-correlations or auto-correlations. Its solution converges to the Wiener filter solution.
Most linear adaptive filtering problems can be formulated using the block diagram above. That is, an unknown system
is to be identified and the adaptive filter attempts to adapt the filter
to make it as close as possible to
, while using only observable signals
,
and
; but
,
and
are not directly observable. Its solution is closely related to the Wiener filter
.
data:image/s3,"s3://crabby-images/9dd38/9dd3800824633f9f059ab9e7607337921877322a" alt=""
data:image/s3,"s3://crabby-images/3d2b8/3d2b89992f4adc9c52eb2289b9e8d43d2ac1203d" alt=""
data:image/s3,"s3://crabby-images/4dee2/4dee2d535fe0d33a71b53f84e9152c1611eab843" alt=""
data:image/s3,"s3://crabby-images/e0325/e03253f75b75a120debcd0e83f529f343644c266" alt=""
data:image/s3,"s3://crabby-images/09d7f/09d7fb08c34dd32f00ae1c5284180da22f613311" alt=""
which minimize a cost function.
We start by defining the cost function asdata:image/s3,"s3://crabby-images/c93f0/c93f09f9f350fe356fa3c77c48202086421c5404" alt=""
where
is the error at the current sample 'n' and
denotes the expected value
.
This cost function (
) is the mean square error, and it is minimized by the LMS. This is where the LMS gets its name. Applying steepest descent means to take the partial derivative
s with respect to the individual entries of the filter coefficient (weight) vectordata:image/s3,"s3://crabby-images/f64da/f64dac926856a7f2ba92bfa64b252b508f3ae870" alt=""
where
is the gradient
operator.data:image/s3,"s3://crabby-images/9c44a/9c44ae7fcc5f4778c56f07d004fabef1a5fd681a" alt=""
data:image/s3,"s3://crabby-images/9dcfa/9dcfaf0a1ca8bb5422de977190db40421e30376c" alt=""
Now,
is a vector which points towards the steepest ascent of the cost function. To find the minimum of the cost function we need to take a step in the opposite direction of
. To express that in mathematical termsdata:image/s3,"s3://crabby-images/6a87f/6a87fea24081a2bd63697886d19a87a4e545120b" alt=""
where
is the step size(adaptation constant). That means we have found a sequential update algorithm which minimizes the cost function. Unfortunately, this algorithm is not realizable until we know
.
Generally, the expectation above is not computed. Instead, to run the LMS in an online (updating after each new sample is received) environment, we use an instantaneous estimate of that expectation. See below.
must be approximated. This can be done with the following unbiased estimator
data:image/s3,"s3://crabby-images/c8d52/c8d52a7be938f73b23be0319114b98f49fe0a624" alt=""
where
indicates the number of samples we use for that estimate. The simplest case is data:image/s3,"s3://crabby-images/69176/69176eb3159c05e9c385a00af358c721b01a0659" alt=""
data:image/s3,"s3://crabby-images/550a5/550a5093882762922e66800c102ec6051e306b99" alt=""
For that simple case the update algorithm follows asdata:image/s3,"s3://crabby-images/b57d0/b57d06416c6112d3c2767457fffc0e76bc73fda6" alt=""
Indeed this constitutes the update algorithm for the LMS filter.
th order algorithm can be summarized as
where
denotes the Hermitian transpose of
.
is constant, and that the input signal
is wide-sense stationary.
Then
converges to
as
if and only ifdata:image/s3,"s3://crabby-images/2907f/2907f402a5d26334a65fbc230121725f4601fc76" alt=""
where
is the greatest eigenvalue of the autocorrelation
matrix
. If this condition is not fulfilled, the algorithm becomes unstable and
diverges.
Maximum convergence speed is achieved whendata:image/s3,"s3://crabby-images/0537b/0537b7816cdc477e7fd4254cdf68772e3f990591" alt=""
where
is the smallest eigenvalue of
.
Given that
is less than or equal to this optimum, the convergence speed is determined by
, with a larger value yielding faster convergence. This means that faster convergence can be achieved when
is close to
, that is, the maximum achievable convergence speed depends on the eigenvalue spread of
.
A white noise
signal has autocorrelation matrix
, where
is the variance of the signal. In this case all eigenvalues are equal, and the eigenvalue spread is the minimum over all possible matrices.
The common interpretation of this result is therefore that the LMS converges quickly for white input signals, and slowly for colored input signals, such as processes with low-pass or high-pass characteristics.
It is important to note that the above upperbound on
only enforces stability in the mean, but the coefficients of
can still grow infinitely large, i.e. divergence of the coefficients is still possible. A more practical bound isdata:image/s3,"s3://crabby-images/7fe27/7fe274d0a1e2f0f2fab7be7695873747631db3fc" alt=""
where
denotes the trace of
. This bound guarantees that the coefficients of
do not diverge (in practice, the value of
should not be chosen close to this upper bound, since it is somewhat optimistic due to approximations and assumptions made in the derivation of the bound).
. This makes it very hard (if not impossible) to choose a learning rate
that guarantees stability of the algorithm (Haykin 2002). The Normalised least mean squares filter (NLMS) is a variant of the LMS algorithm that solves this problem by normalising with the power of the input. The NLMS algorithm can be summarised as:
), then the optimal learning rate for the NLMS algorithm isdata:image/s3,"s3://crabby-images/68c1f/68c1fb3145787848be700135e7a26db9f084b215" alt=""
and is independent of the input
and the real (unknown) impulse response
. In the general case with interference (
), the optimal learning rate isdata:image/s3,"s3://crabby-images/728ad/728ade0968c81d186159ac3b1535abe01d971667" alt=""
The results above assume that the signals
and
are uncorrelated to each other, which is generally the case in practice.
, we can derive the expected misalignment for the next sample as:
Let
and data:image/s3,"s3://crabby-images/a847a/a847a2ee0608f50f822f44ea83f79f29ba415285" alt=""
Assuming independence, we have:
The optimal learning rate is found at
, which leads to:
Adaptive filter
An adaptive filter is a filter that self-adjusts its transfer function according to an optimization algorithm driven by an error signal. Because of the complexity of the optimization algorithms, most adaptive filters are digital filters. By way of contrast, a non-adaptive filter has a static...
used to mimic a desired filter by finding the filter coefficients that relate to producing the least mean squares of the error signal (difference between the desired and the actual signal). It is a stochastic gradient descent
Stochastic gradient descent
Stochastic gradient descent is an optimization method for minimizing an objective function that is written as a sum of differentiable functions.- Background :...
method in that the filter is only adapted based on the error at the current time. It was invented in 1960 by Stanford University
Stanford University
The Leland Stanford Junior University, commonly referred to as Stanford University or Stanford, is a private research university on an campus located near Palo Alto, California. It is situated in the northwestern Santa Clara Valley on the San Francisco Peninsula, approximately northwest of San...
professor Bernard Widrow
Bernard Widrow
Bernard Widrow is a U.S. professor of electrical engineering at Stanford University. He is the co-inventor of the Widrow–Hoff least mean squares filter adaptive algorithm with his then doctoral student Ted Hoff...
and his first Ph.D. student, Ted Hoff.
Problem formulation
data:image/s3,"s3://crabby-images/c19f2/c19f27d9f2e92404191308c80d75aa77429a6ad2" alt=""
Relationship to the least mean squares filter
The realization of the causal Wiener filter looks a lot like the solution to the least squares estimate, except in the signal processing domain. The least squares solution, for input matrix
data:image/s3,"s3://crabby-images/aa59e/aa59ee944a810839bfac9b32ffdb660f3e7d3f77" alt=""
data:image/s3,"s3://crabby-images/7aca8/7aca8449ef8d26cd98197bb859a71b771279bcae" alt=""
is
data:image/s3,"s3://crabby-images/ee6b5/ee6b54a8aff9007be1d1caeee40ee882593ca04c" alt=""
The FIR Wiener filter is related to the least mean squares filter, but minimizing its error criterion does not rely on cross-correlations or auto-correlations. Its solution converges to the Wiener filter solution.
Most linear adaptive filtering problems can be formulated using the block diagram above. That is, an unknown system
data:image/s3,"s3://crabby-images/9ff58/9ff582d117304cae6eaa32e91318619916285205" alt=""
data:image/s3,"s3://crabby-images/99f25/99f253763a09ecf7292d79132b82e61bde8e913b" alt=""
data:image/s3,"s3://crabby-images/e1bee/e1beeb6f007d8cae6d82d8cdd410f4511cfc852a" alt=""
data:image/s3,"s3://crabby-images/68bcb/68bcb86f79cc8a8a93e9104c50f1fc21fb143aa1" alt=""
data:image/s3,"s3://crabby-images/2ac1c/2ac1c7d05e3a4533de457811aa59859ff84b8aa6" alt=""
data:image/s3,"s3://crabby-images/ca7cc/ca7cc7b0ec79c5df8e5786ec919c6d53fd93fde8" alt=""
data:image/s3,"s3://crabby-images/44f3a/44f3aa4a05eb08aace198b11aa47365aa7f45452" alt=""
data:image/s3,"s3://crabby-images/5053c/5053c7a93cfb6b6a59b323cb7ddc79cbcea77322" alt=""
data:image/s3,"s3://crabby-images/9e322/9e322d57e26f825e0947569f1ee25501c67057a4" alt=""
Wiener filter
In signal processing, the Wiener filter is a filter proposed by Norbert Wiener during the 1940s and published in 1949. Its purpose is to reduce the amount of noise present in a signal by comparison with an estimation of the desired noiseless signal. The discrete-time equivalent of Wiener's work was...
.
definition of symbols
data:image/s3,"s3://crabby-images/9dd38/9dd3800824633f9f059ab9e7607337921877322a" alt=""
data:image/s3,"s3://crabby-images/3d2b8/3d2b89992f4adc9c52eb2289b9e8d43d2ac1203d" alt=""
data:image/s3,"s3://crabby-images/4dee2/4dee2d535fe0d33a71b53f84e9152c1611eab843" alt=""
data:image/s3,"s3://crabby-images/e0325/e03253f75b75a120debcd0e83f529f343644c266" alt=""
data:image/s3,"s3://crabby-images/09d7f/09d7fb08c34dd32f00ae1c5284180da22f613311" alt=""
Idea
The idea behind LMS filters is to use steepest descent to find filter weightsdata:image/s3,"s3://crabby-images/94b2d/94b2d1f0b0faa90df8abe5a6f7b50af282e06dc2" alt=""
We start by defining the cost function as
data:image/s3,"s3://crabby-images/c93f0/c93f09f9f350fe356fa3c77c48202086421c5404" alt=""
where
data:image/s3,"s3://crabby-images/31fff/31fffa7f04628ac294bd67f3d479c0c0a2d54fdb" alt=""
data:image/s3,"s3://crabby-images/54c4d/54c4d1207197c18cf7c180ed60a9d663c6da3a85" alt=""
Expected value
In probability theory, the expected value of a random variable is the weighted average of all possible values that this random variable can take on...
.
This cost function (
data:image/s3,"s3://crabby-images/fe23a/fe23ae871a7cb3898909424507ab12880a67b818" alt=""
Partial derivative
In mathematics, a partial derivative of a function of several variables is its derivative with respect to one of those variables, with the others held constant...
s with respect to the individual entries of the filter coefficient (weight) vector
data:image/s3,"s3://crabby-images/f64da/f64dac926856a7f2ba92bfa64b252b508f3ae870" alt=""
where
data:image/s3,"s3://crabby-images/0d395/0d3956d9c118fdcb1a4cc1dc390b5e2261d8b6b0" alt=""
Gradient
In vector calculus, the gradient of a scalar field is a vector field that points in the direction of the greatest rate of increase of the scalar field, and whose magnitude is the greatest rate of change....
operator.
data:image/s3,"s3://crabby-images/9c44a/9c44ae7fcc5f4778c56f07d004fabef1a5fd681a" alt=""
data:image/s3,"s3://crabby-images/9dcfa/9dcfaf0a1ca8bb5422de977190db40421e30376c" alt=""
Now,
data:image/s3,"s3://crabby-images/5a2c5/5a2c590cc7529f8f56d9ae0034e3c235f9d5bd75" alt=""
data:image/s3,"s3://crabby-images/afe69/afe69b0f4e368a1da2b2cb2a8dcb2a230ccb75c5" alt=""
data:image/s3,"s3://crabby-images/6a87f/6a87fea24081a2bd63697886d19a87a4e545120b" alt=""
where
data:image/s3,"s3://crabby-images/93fa3/93fa34ac5406aa5f33b76c8da887abf15ed3232c" alt=""
data:image/s3,"s3://crabby-images/2db92/2db92e36220679ff68f89df66cb47a8869eb7f97" alt=""
Generally, the expectation above is not computed. Instead, to run the LMS in an online (updating after each new sample is received) environment, we use an instantaneous estimate of that expectation. See below.
Simplifications
For most systems the expectation functiondata:image/s3,"s3://crabby-images/fa45b/fa45b07f9569d7719ebd318c215eb6a87f80e0b1" alt=""
Estimator
In statistics, an estimator is a rule for calculating an estimate of a given quantity based on observed data: thus the rule and its result are distinguished....
data:image/s3,"s3://crabby-images/c8d52/c8d52a7be938f73b23be0319114b98f49fe0a624" alt=""
where
data:image/s3,"s3://crabby-images/615e7/615e7009351e73e45ea1b10c893b7c10f1fdebc8" alt=""
data:image/s3,"s3://crabby-images/69176/69176eb3159c05e9c385a00af358c721b01a0659" alt=""
data:image/s3,"s3://crabby-images/550a5/550a5093882762922e66800c102ec6051e306b99" alt=""
For that simple case the update algorithm follows as
data:image/s3,"s3://crabby-images/b57d0/b57d06416c6112d3c2767457fffc0e76bc73fda6" alt=""
Indeed this constitutes the update algorithm for the LMS filter.
LMS algorithm summary
The LMS algorithm for adata:image/s3,"s3://crabby-images/d1b23/d1b239fb5a80f2935d3c3c9f89055831c134b768" alt=""
Parameters: | ![]() |
![]() |
|
Initialisation: | ![]() |
Computation: | For ![]() |
|![]() |
|
|![]() |
|
|![]() |
where
data:image/s3,"s3://crabby-images/c5601/c560122e5c21960acc96655b6aaa6dafb250721a" alt=""
data:image/s3,"s3://crabby-images/79476/79476c074c09bd7e312cb14ed230a3199541dd78" alt=""
Convergence and stability in the mean
Assume that the true filterdata:image/s3,"s3://crabby-images/c95eb/c95ebc380ab3c0462aecb7bfcf4002a2800800db" alt=""
data:image/s3,"s3://crabby-images/a13cf/a13cf93d4f9f7eb5b9885d6d2da45fb577ffb4c2" alt=""
Then
data:image/s3,"s3://crabby-images/ac31e/ac31ef840a70691c783be8854b4ee964051eff01" alt=""
data:image/s3,"s3://crabby-images/ead0c/ead0cf75c95204cc93a4d52e00fd8f29a98cfab6" alt=""
data:image/s3,"s3://crabby-images/f4e0d/f4e0d51463e6fab225ba47fc5d06b1c848ac79c7" alt=""
data:image/s3,"s3://crabby-images/2907f/2907f402a5d26334a65fbc230121725f4601fc76" alt=""
where
data:image/s3,"s3://crabby-images/65cf8/65cf8da9460f843eb72fc1435c9be45568edecf2" alt=""
Autocorrelation
Autocorrelation is the cross-correlation of a signal with itself. Informally, it is the similarity between observations as a function of the time separation between them...
matrix
data:image/s3,"s3://crabby-images/f05f9/f05f9fb7843bcd144f75eea0ec9c5ac2ac52a067" alt=""
data:image/s3,"s3://crabby-images/346b3/346b365a15d9af556fb686b96c432f0470e800b3" alt=""
Maximum convergence speed is achieved when
data:image/s3,"s3://crabby-images/0537b/0537b7816cdc477e7fd4254cdf68772e3f990591" alt=""
where
data:image/s3,"s3://crabby-images/946d3/946d383a5244db97b4f1d3ab4e0305e74c946c2d" alt=""
data:image/s3,"s3://crabby-images/27e8f/27e8fa953d3e6cd22145f95fc4c02433d6fb71cc" alt=""
Given that
data:image/s3,"s3://crabby-images/14320/14320c7dfe5f7fb37e9ab09a8964c4ae39386931" alt=""
data:image/s3,"s3://crabby-images/663b6/663b6db99c31c3c34e13bb77e2f2acfbcbc05f28" alt=""
data:image/s3,"s3://crabby-images/93378/9337836909cac6b48101009306dc901411ff21eb" alt=""
data:image/s3,"s3://crabby-images/f7c6b/f7c6b9e00f0216baaa691faf9da56d7e7c050091" alt=""
data:image/s3,"s3://crabby-images/83c85/83c852797693efbfe841d45e7c53c67c7a16173d" alt=""
A white noise
White noise
White noise is a random signal with a flat power spectral density. In other words, the signal contains equal power within a fixed bandwidth at any center frequency...
signal has autocorrelation matrix
data:image/s3,"s3://crabby-images/c7d49/c7d49cd714a2a95a26832271ca279387dd454a8c" alt=""
data:image/s3,"s3://crabby-images/baa83/baa83d8fbaa2dda49238d11c5204dbb0f15db085" alt=""
The common interpretation of this result is therefore that the LMS converges quickly for white input signals, and slowly for colored input signals, such as processes with low-pass or high-pass characteristics.
It is important to note that the above upperbound on
data:image/s3,"s3://crabby-images/912e7/912e7b15ab506aca82a584230469f3c137a83fae" alt=""
data:image/s3,"s3://crabby-images/a734d/a734dced5fe5f4228777130ca10aae5b307d499f" alt=""
data:image/s3,"s3://crabby-images/7fe27/7fe274d0a1e2f0f2fab7be7695873747631db3fc" alt=""
where
data:image/s3,"s3://crabby-images/e5143/e5143e0af263f02418d5dacd4d703fb2d70acdc2" alt=""
data:image/s3,"s3://crabby-images/153ef/153efdea0e7326b10c2dc441a15228c1c49122f4" alt=""
data:image/s3,"s3://crabby-images/ce6ff/ce6ff951252752fdfb4789a83a5b2b5ddf96b78f" alt=""
data:image/s3,"s3://crabby-images/0ef7d/0ef7daa0c614b24f3caec1571d4258d7bcd3732b" alt=""
Normalised least mean squares filter (NLMS)
The main drawback of the "pure" LMS algorithm is that it is sensitive to the scaling of its inputdata:image/s3,"s3://crabby-images/68ad7/68ad74933657e299d50170ac2b0f097fec5af736" alt=""
data:image/s3,"s3://crabby-images/8f38d/8f38d2a3b756c45592804836911525db03c54802" alt=""
Parameters: | ![]() |
![]() |
|
Initialization: | ![]() |
Computation: | For ![]() |
|![]() |
|
|![]() |
|
|![]() |
Optimal learning rate
It can be shown that if there is no interference (data:image/s3,"s3://crabby-images/9bf07/9bf077ae5f912b3be48bfef6b4c3fbf43df3dfea" alt=""
data:image/s3,"s3://crabby-images/68c1f/68c1fb3145787848be700135e7a26db9f084b215" alt=""
and is independent of the input
data:image/s3,"s3://crabby-images/c0cbc/c0cbcba4f00385fa4885aab49ed716c611e60a0f" alt=""
data:image/s3,"s3://crabby-images/08330/08330164129676774549d6753c2787cd6c5ea3d6" alt=""
data:image/s3,"s3://crabby-images/dc082/dc082a6581612cb288bcaf39d150e2a2f6ef6921" alt=""
data:image/s3,"s3://crabby-images/728ad/728ade0968c81d186159ac3b1535abe01d971667" alt=""
The results above assume that the signals
data:image/s3,"s3://crabby-images/6df7b/6df7b7d8bd6b3cea136815bf63c17d27628dddbf" alt=""
data:image/s3,"s3://crabby-images/66d37/66d37553603333dc53cf31f30e04cbfecba0eff1" alt=""
Proof
Let the filter misalignment be defined asdata:image/s3,"s3://crabby-images/9983d/9983dcfdac1e36ab4a4e2588986edeb2275a6094" alt=""
Let
data:image/s3,"s3://crabby-images/a311e/a311eecc88469d025b242444fedb0a76d604b4ec" alt=""
data:image/s3,"s3://crabby-images/a847a/a847a2ee0608f50f822f44ea83f79f29ba415285" alt=""
Assuming independence, we have:
The optimal learning rate is found at
data:image/s3,"s3://crabby-images/85f1a/85f1a64979e224b1f18e42e62d5a751469cadd58" alt=""
See also
- Recursive least squares
- For statistical techniques relevant to LMS filter see Least squaresLeast squaresThe method of least squares is a standard approach to the approximate solution of overdetermined systems, i.e., sets of equations in which there are more equations than unknowns. "Least squares" means that the overall solution minimizes the sum of the squares of the errors made in solving every...
. - Similarities between Wiener and LMSSimilarities between Wiener and LMSThe Least mean squares filter solution converges to the Wiener filter solution, assuming that the unknown system is LTI and the noise is stationary. Both filters can be used to identify the impulse response of an unknown system, knowing only the original input signal and the output of the unknown...
- Multidelay block frequency domain adaptive filterMultidelay block frequency domain adaptive filterThe Multidelay block frequency domain adaptive filter algorithm is a block-based frequency domain implementation of the Least mean squares filter algorithm.- Introduction :...
- Kernel adaptive filterKernel adaptive filterKernel adaptive filtering is an adaptive filtering technique for general nonlinear problems. It is a natural generalization of linear adaptive filtering in reproducing kernel Hilbert spaces. Kernel adaptive filters are online kernel methods, closely related to some artificial neural networks such...
External links
- LMS Algorithm in Adaptive Antenna Arrays www.antenna-theory.com
- LMS Noise cancellation demo www.advsolned.com