Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
INITIALIZATION/PREWINDOWING REMOVAL POSTPROCESSING FOR FAST RLS FILTER ADAPTATION
Document Type and Number:
WIPO Patent Application WO/2001/082474
Kind Code:
A2
Abstract:
The present invention, generally speaking, accelerates convergence of a fast RLS adaptation algorithm by, following processing of a burst of data, performing postprocessing to remove the effects of prewindowing, fictitious data initialization, or both. This postprocessing is part of a burst mode adaptation strategy in which data (signals) get processed in chunks (bursts). Such a burst mode processing approach is applicable whenever the continuous adaptation of the filter is not possible (algorithmic complexity too high to run in real time) or not required (optimal filter setting varies only slowly with time). Postprocessing consists of a series of 'downdating' operations (as opposed to updating) that in effect advance the beginning point of the data window. The beginning point is advanced beyond fictitious data used for initialization and beyond a prewindowing region. In other variations, downdating is applied to data within a prewindowing region only. The forgetting factor of conventional algorithms can be eliminated entirely. Performance equivalent to that of GWC RLS algorithms is achieved at substantially lower computational cost. In particular, a postprocessing Fast Kalman Algorithm in effect transforms an initialized/prewindowed least squares estimate into a Covariance Window least squares estimate. Various further refinements are possible. Initialization may be cancelled completely or only partially. For example, in order to reduce the dynamic range of algorithmic quantities, it may be advantageous to, in a subsequent initialization, add an increment to a forward error energy quantity calculated during a previous burst. Postprocessing may then be performed to cancel only the added increment. Also, to reduce the usual large startup error transient, the desired response data can be modified in a way that dampens the error transient. The modified desired response data are saved for use in later postprocessing. Furthermore, to allow for more rapid adaptation without the use of an exponential forgetting factor, a weighting factor less than one may be applied to the forward error energy quantity during initialization from one burst to the next. This allows for the most efficient use of data but limited adaptation within a burst, but more rapid adaptation from one burst to the next.

Inventors:
PAL DEBAJYOTI (US)
SLOCK DIRK (FR)
Application Number:
PCT/US2001/011724
Publication Date:
November 01, 2001
Filing Date:
April 19, 2001
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
VIRATA CORP (US)
PAL DEBAJYOTI (US)
SLOCK DIRK (FR)
International Classes:
H03H21/00; (IPC1-7): H03H/
Foreign References:
US5400394A1995-03-21
Other References:
See also references of EP 1279226A2
Attorney, Agent or Firm:
Peterson, James W. (Doane Swecker & Mathis, LLP, P.O. Box 140, Alexandria VA, US)
Download PDF:
Claims:
WHAT IS CLAIMED IS :
1. A method of performing recursive adaptation of a digital filter computed using at least a filter coefficient vector or matrix, a desired response data vector or matrix and an input data matrix, the method comprising : storing a burst of input data ; storing or deriving corresponding desired response data ; using prewindowing to initialize the desired response data vector and the input data matrix ; running a prewindowed fast RLStype adaptation algorithm on the burst of data to compute filter coefficients at the end of the burst of data ; and performing postprocessing to adjust the filter coefficients to remove the effects of prewindowing.
2. The method of Claim 1, wherein the filter coefficients are adjusted to be more nearly optimal in accordance with a covariance window Least Squares error criterion.
3. The method of Claim 1, wherein the digital filter is computed using a sample covariance matrix, the method further comprising : initializing the input data matrix with at least some fictitious nonzero data at positions in the input data matrix corresponding to instants i in time prior to i = 0 ; initializing at least one of the desired response data vector and the sample covariance matrix to agree with the input data matrix, including the fictitious data ; and after running the filter, performing postprocessing to adjust the filter coefficients to remove the effects of the fictitious data.
4. The method of Claim 3, further comprising : storing a different burst of data ; initializing the filter coefficient matrix to values derived from values obtained from running the filter on a previous burst of data ; using prewindowing to initialize the input data matrix ; running the filter on the different burst of data to compute filter coefficients at the end of the burst of data ; and performing postprocessing to adjust the filter coefficients to remove the effects of prewindowing.
5. The method of Claim 4, comprising initializing at least one algorithmic quantity by adjusting a value obtained from running the filter on the previous burst of data.
6. The method of Claim 5, wherein the algorithmic quantity is the forward prediction error energy.
7. The method of Claim 6, wherein the forward prediction error energy is adjusted upward to reduce the dynamic range of at least one quantity.
8. The method of Claim 7, further comprising, during postprocessing, removing an effect of some portion of the forward prediction error energy while preserving the effect of another portion of the forward prediction error energy.
9. The method of Claim 8, comprising removing the effect of an excess portion of the forward prediction error energy equal to an amount by which the forward prediction error energy was adjusted upward.
10. The method of Claim 6, wherein the forward prediction error energy is adjusted downward to reduce, from one burst to another, the influence of prior data, while using an exponential forgetting factor that is zero or substantially less than one.
11. The method of Claim 4, further comprising modifying desired response data vector values to reduce a pronounced error transient experienced during initial stages of processing a burst of data.
12. The method of Claim 11, further comprising saving modified desired response data vector values for use during postprocessing.
13. The method of Claim 12, further comprising using the saved modified desired response data vector values to remove the effect of modification of the values.
Description:
INITIALIZATION/PREWINDOWING REMOVAL POSTPROCESSING FOR FAST RLS FILTER ADAPTATION BACKGROUND OF THE INVENTION

1. Field of the Invention The present invention relates to adaptive filters and more particularly to fast recursive least squares (fast RLS) adaptive filters.

2. State of the Art Adaptive filters find widespread use in communications. A known class of adaptive filter is the fast RLS adaptive filter. This class of adaptive filter, or more accurately, this class of filter adaptation algorithm, is recognized for its properties of fast convergence and reduced computational complexity compared to earlier RLS algorithms (although the computational complexity is still very considerable).

In one aspect, the attractiveness of RLS algorithms lies in the ability to compute updated filter settings using a new data input together with the old filter settings. This"recursion"is performed differently in different variations of the algorithm. In one variation, designated by the term"growing window covariance" (GWC), the adaptation algorithm takes into account a growing window of data that begins at time zero, for example, and is incrementally extended at each sample time until the adaptation has concluded. In another variation, designated by the term "sliding window covariance" (SWC), the adaptation algorithm takes into account a window of data that at a particular point in the algorithm becomes fixed in size. In the SWC algorithm, once the size of the data window has been fixed, as updates are computed, they incorporate knowledge from a new sample and"disincorporate" knowledge from an oldest sample.

In general, various different methods of windowing the input data of an adaptive filter are known. In order to achieve a favorable mathematical structure for computational efficiency, the most common implementations of the fast RLS algorithm use prewindowing. The prewindowing method makes the assumption that the input data prior to time zero are zero. This assumption results in a"prewindowing transient"during which the error quantity is unusually large. In other words, prewindowing perturbs the algorithm, delaying convergence. The GWC version of RLS does not require prewindowing. Without prewindowing, however, the RLS algorithm becomes computationally more burdensome and more implementation-sensitive.

Initialization also perturbs the algorithm. As described in J. M. Cioffi and T.

Kailath,"Fast, recursive least squares transversal filters for adaptive filtering", IEEE Trans. on ASSP, ASSP-32 (2) : 304--337, April 1984, more rapid convergence may be obtained by initializing the input data matrix with a sparse"fictitious"data submatrix located within a region corresponding to negative time. A sample covariance matrix is then initialized so as to be in agreement with the fictitious data. A desired response data vector (or matrix) may also be initialized with some fictitious data to reflect prior information on the filter settings. These initialization techniques may be referred to as "soft constraint initialization". As compared to initializing the same quantities with zeros, the foregoing technique may significantly reduce the amount of perturbation experienced by the algorithm if the prior information is correct. Substantial perturbation remains, however, if the assumed prior information is incorrect, as is usually the case.

In order to overcome the deleterious effects of prewindowing and initialization, an exponential"forgetting factor"is commonly used. As more and more data is processed, the influence of old data becomes exponentially more attenuated. Besides forgetting"incorrect"data, however, the same forgetting also gets applied to actual data, with the result that the total amount of data available is used

less than efficiently. If this forgetting factor could be eliminated entirely, the result would be better estimation performance and fewer numerical problems.

Further background information concerning RLS adaptation algorithms may be found in the following references, incorporated herein by reference : T. Kailath, Lectures on Wiener and Kalman Filtering, Springer-Verlag, Wien--New York, 1981.

S. Haykin, Adaptive Filter Theory, Prentice-Hall, Englewood Cliffs, NJ, 1995, third edition.

B. Widrow and S. D. Stearns, Adaptive Signal Processing, Prentice-Hall, Englewood Cliffs, NJ, 1985.

B. Widrow and E. Walach,"On the Statistical Efficiency of the LMS Algorithm with Nonstationary Inputs", IEEE Trans. on Information Theory, IT-30 (2) : 211--221, March 1984, Special Issue on Adaptive Filtering.

D. T. M. Slock,"On the Convergence Behavior of the LMS and the Normalized LMS Algorithms", IEEE Trans. on Signal Processing, 41 (9) : 2811--2825, Sept. 1993.

S. M. Kay, Fundamentals of Statistical Signal Processing : Estimation Theory, Prentice Hall 1993.

E. Eleftheriou and D. Falconer,"Tracking Properties and Steady-State Performance of RLS Adaptive Filter Algorithms", IEEE Trans.

ASSP, ASSP-34 (5) : 1097--1110, Oct. 1986.

D. D. Falconer and L. Ljung,"Application of Fast Kalman Estimation to Adaptive Equalization", IEEE Trans. Com., COM-26 (10) : 1439--1446, Oct. 1978.

J. M. Cioffi and T. Kailath,"Fast, recursive least squares transversal filters for adaptive filtering", IEEE Trans. on ASSP, ASSP-32 (2) : 304--337, April 1984.

D. T. M. Slock and T. Kailath,"Numerically Stable Fast Transversal Filters for Recursive Least Squares Adaptive Filtering", IEEE Trans. Signal Proc., ASSP-39 (1) : 92--114, Jan. 1991.

D. T. M. Slock,"Backward Consistency Concept and Round-Off Error Propagation Dynamics in Recursive Least Squares Algorithms", Optical Engineering, 31 (6) : 1153--1169, June 1992.

J. M. Cioffi and T. Kailath,"Windowed Fast Transversal Filters Adaptive Algorithms with Normalization", IEEE Trans. on ASSP, ASSP-33 (3) : 607--625, June 1985.

J. M. Cioffi,"The Block-Processing FTF Adaptive Algorithm", IEEE Trans. on ASSP, ASSP 34 (1) : 77--90, Feb. 1986.

SUMMARY OF THE INVENTION The present invention, generally speaking, accelerates convergence of a fast RLS adaptation algorithm by, following processing of a burst of data, performing postprocessing to remove the effects of prewindowing, fictitious data initialization, or both. This postprocessing is part of a burst mode adaptation strategy in which data (signals) get processed in chunks (bursts). Such a burst mode processing approach is applicable whenever the continuous adaptation of the filter is not possible (algorithmic complexity too high to run in real time) or not required (optimal filter setting varies only slowly with time). Postprocessing consists of a series of"downdating" operations (as opposed to updating) that in effect advance the beginning point of the data window. The beginning point is advanced beyond fictitious data used for initialization and beyond a prewindowing region. In other variations, downdating is applied to data within a prewindowing region only. The forgetting factor of conventional algorithms can be eliminated entirely. Performance equivalent to that of GWC RLS algorithms is achieved at substantially lower computational cost. In particular, a postprocessing Fast Kalman Algorithm in effect transforms an initialized/prewindowed least squares estimate into a Covariance Window least

squares estimate. Various further refinements are possible. Initialization may be cancelled completely or only partially. For example, in order to reduce the dynamic range of algorithmic quantities, it may be advantageous to, in a subsequent initialization, add an increment to a forward error energy quantity calculated during a previous burst. Postprocessing may then be performed to cancel only the added increment. Also, to reduce the usual large startup error transient, the desired response data can be modified in a way that dampens the error transient. The modified desired response data are saved for use in later postprocessing. Furthermore, to allow for more rapid adaptation without the use of an exponential forgetting factor, a weighting factor less than one may be applied to the forward error energy quantity during initialization from one burst to the next. This allows for the most efficient use of data but limited adaptation within a burst, but more rapid adaptation from one burst to the next.

BRIEF DESCRIPTION OF THE DRAWING The present invention may be further understood from the following description in conjunction with the appended drawing. In the drawing : Figure 1 is a block diagram of an equalizer with which the present invention may be used ; and Figure 2 is a diagram illustrating initialization of the adaptive filters of the equalizer of Figure 1.

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS In the following description, details are described of an advantageous postprocessing algorithm that may be used to remove the effects of prewindowing and/or initialization and hence accelerate convergence of a fast RLS adaptation algorithm. For purposes of illustration only, the example of a fractionally-spaced (FS) decision feedback equalizer (DFE) is considered. Such an FS DFE finds particular application in xDSL modems ; however, the technique described is broadly applicable

to filter adaptation in all fields of application. In a concrete embodiment, an example is given of a fast RLS algorithm that can be used in conjunction with the postprocessing procedure. Many of the algorithmic details of the fast RLS algorithm and the postprocessing procedure are themselves familiar from the published literature. Different internal variables and recursive relations can be used to implement the same strategies. To explain the initialization removal operation, the interpretation of initialization as the result of processing fictitious data is explained in detail.

Fractionally-Spaced Decision Feedback Equalization Consider the channel equalization application depicted in Fig. 1. Bits get mapped into (scalar valued) symbols a ; c belonging to some finite alphabet (e. g. {-1, +1}), which then modulate (linearly) a certain pulse shape. The resulting signal gets transmitted over a channel that is assumed to be linear and time-invariant and hence can be represented by a certain channel impulse response. Noise and interference get added during the transmission. At the receiver, the signal gets lowpass filtered and sampled. Assume the sampling rate to be twice the symbol rate. Then the even and odd received samples can be considered as two symbol rate sequences, which together constitute one vector valued symbol rate sequence : where T is the symbol period and the time offset to determines the phase of the sampling operation.

The whole system taking the symbols ak as input and producing the 2 x 1 vector samples Yk as output is a discrete-time system operating at the symbol rate. The 2 x 1 transfer function H (z) indicated in Figure 1 represents the even and odd samples of the convolution of a transmission filter (pulse shape), channel transfer function and receiver filter. Consider now a Decision-Feedback Equalizer (DFE) with feedforward filter F (z) (1 x 2) and feedback filter 1-B (z). In Figure 1, F (z) is assumed to be potentially non-causal and hence leads the DFE to produce undelayed symbol estimates ak. However, in practice and in the equations below, the filter F (z) is assumed to be causal so that the DFE produces symbol estimates 5 with a certain delay d. Then the DFE output becomes : where the symbol estimate is delayed with respect to the received signal. An equalization error ãk-d can be formed by subtracting the equalizer output ak-d (symbol estimate) from the true symbol ak-d. The equalization error can be written as : where the b (i) are scalars and the f (i) are 1 x 2 vectors.

The true symbols ak-d are available during the so-called training period of the equalizer. After the training period, when processing actual data, the true symbol ak_d can be replaced by a decision âk_d based on the equalizer output #k-d. The decision is obtained (in the absence of channel coding) by passing the equalizer output through a slicer, as indicated in Fig. 1. The slicer takes the element from the symbol constellation that is closest to the equalizer output. Unless a decision error occurs, k-d = ak-d. The equalization error is used by adaptive filtering algorithms to adapt the equalizer filter settings. The adaptation of the equalizer with actual data through the use of #k-d is called the decision-directed mode. Define the following : dk-ak-d, Sk = ak-d-I where dk denotes the desired-response signal for the equalizer and Sk is the input signal to the feed- back filter. Note that sk = dk-1: the input to the feedback filter consists of past symbols/decisions.

With the T/2 feedforward filter spacing considered here, there results, in fast RLS terminology, 3 channels (symbol rate filter input streams) : past symbols (sk) and even and odd received samples (the two components of Yk) The filtering (equalization) error can be rewritten as : where W = [-b(1)###-b(nB) f(0)###f(nF-1)], Uk = Sk... sk_nB+a Yk Yk-nF script T denotes matrix transposition. The input data vector Uk is a column vector, whereas filter coefficient vectors such as W will be denoted by row vectors. This allows filter outputs to be written as W Uk without tranposes. N = nB + 2TIF = Nlb-F NJ f is the total filter order (total number of filter coefficients).

Prewindowed Least-Squares Data Structure To understand the origins of fast RLS algorithms, it is essential to pay particular attention to the structure of the data in the least-squares criterion used to determine the filter settings. The structure of the data for the prewindowed least-squares criterion applicable to the DFE filter coefficients is shown in Fig. 2. The top line indicates (discrete) time, progressing to the left, with variable time index i. Assume that the LS problem is formulated with the data available at time i = k. In the prewindowing formulation, it is assumed that the signals are zero before time 0. So the signals are assumed to start at time i =-0. For the equalizer application, if the filter adaptation is to start. as soon as training data are available, then the time origin should be chosen such that sO = a is the first available training sequence symbol.

The second line in Fig. 2 contains the desired-response signal in the row vector dk. The structure of dk reflects the prewindowing. Also indicated in d is an exponential forgetting/weighting factor A E (0, 1]. Actually, the data are weighted by v/-A so that the squared errors in the least-squares criterion to be considered below will be weighted by (4) 2 = À. The exponential weighting reduces the influence of past data exponentially fast so that the LS filter solution will be reflecting the characteristics of the most recent data, in case these characteristics vary with time. A corresponding . time constant is implied by the exponential weighting.

The matrix #N+3,k in Fig. 2 is the extended input data matrix. UN+3, k is a structured matrix.

For the DFE problem at hand, it consists of two structured submatrices. The top submatrix is filled with the signal si and has a Hankel structure (if A = 1) : elements along any anti-diagonal are constant. This Hankel structure is perturbed by the exponential weighting, which weighs consecutive columns more and more. The bottom submatrix of UN+3, k is block IIankel (if A = 1) and is filled with the 2 x 1 vector signal (blocks) yl. The data matrix UN + 3, k is called extended because it contains 'n, B+l rows of signal si and nF+l (block) rows of signal Yi so it has in fact nB+1+2 (nF+l) = N+3 rows (one extra row per input channel). The extended data matrix will be required for the fast RLS algorithms. If the bottom row with signal #k-nB and the bottom (block) row with signal Yk-nF are removed from UN+3, k, then there results the regular input data matrix UNk = Uk with N rows.

The columns of the matrix are the weighted input data vectors #### Ui which upon multiplication with the filter coefficient vector W gives the weighted DFE output A 2 W Ui at time i.

The n that is indicated in Fig. 2 denotes n = max {nB, nl.} (though the figure is drawn assuming that n = nF = n). The extended data vectors UN+3, i with time in the range i E [O, n-lu contain some samples of signal si and/or yi situated at negative time. Those samples are not available if sampling occurs beginning from time i = 0 onwards. In the prewindowing assumption, those samples are set equal to zero. This means that the data vectors UN+3,i contain zeros over the indicated time range, which can be called the prewindowing transient period. Hence, within this period of n discrete-time instants, the extended data vectors UN+3, i do not fully contain genuine data.

In order to make an RLS algorithm start from well-defined quantities, some initialization needs . to be provided. Such an initialization can be provided by introducing fictitious data at negative time as long as the prewindowing (data is zero before the fictitious data) and the particular structure of the (extended) input data matrix remain preserved. The structure of the fictitious data should preferably be such that the filter coefficients and all other quantities to be initialized at time k =-1 can be determined without computation. The simplest structure for such fictitious input data consists of one non-zero sample per input channel, positioned in such a way that there is no overlap between channels in the extended data matrix. The only non-zero input samples at negative time i < 0 are : This results in the following diagonal initial sample covariance matrix : R = = U IU l = blockdiag{µB#nB, # #nB+1 µF#nF # I2}, #n = diag{#n,.. where # denotes the Kronecker product (A X B = [AijB]). Figure 2 is simplified by defining µFF1/2=#-#### µF#. Also, whenever #### with variable i appears, the value for i is actually the value indicated in the top row of the figure, in the same column.

If the DFE filter coeflicients are to be initialized to a nonzero value, W l t 0, then the portion of the desired-response signal at negative time should reflect this: #-1 = W-1#-1.

The Least-Squares Filtering Problem An optimal (Wiener filtering) design of the filter W corresponds to minimizing the expected value (i. c., mean value or statistical average) of the squared filtering error (Minimum Mean Squared Error (MMSE) design) : W° = argmin E Ek (W). w The optimization of the MSE criterion however requires knowledge of the joint second-order statis- tics of the desired-response and input signals. In practice, these statistics are usually not available.

However, (portions of) the desired-response and input signals are usually available. So in practice the statistical averaging operation in the MSE criterion must be dropped or replaced by another averaging operation.

In the Least-Mean-Square (LMS) algorithm, the instantaneous squared error is taken as the criterion, and a simple steepest-descent optimization strategy with one iteration per sample period is applied. The LMS algorithm uses data quite inefficiently and hence requires quite a bit of data to converge to (approximately) the optimal filter setting W°.

In the Least-Squares (LS) approach, the statistical averaging is replaced by a temporal averaging.

So in the LS approach, the filter settings are determined by minimizing the temporally averaged squared filtering error or, equivalently, the sum of squared errors. If signals have been accumulated from time i = 0 to time i = k, then genuine data vectors are available in the time window 7t-1, ki (also called covariance window), and hence the filter coefficients W can be determined from the LS cost function : Note that for the actual data vectors Ui, the prewindowing transient period lasts one instant less than for the extended data vectors UN+3, i.

The LS criterion is often solved recursively, meaning that as a new signal sample becomes . available, the new filter solution is determined from the old one instead of solving the new LS criterion all over again. The resulting algorithm is called the Recursive LS (RLS) algorithm. In the context of the RLS algorithm, it is important to note that the solution of the LS criterion only becomes well-defined when the number of terms in the sum of squared errors becomes at least equal to the number of coefficients N to be determined. To make the criterion well-defined even with only one or even zero terms in the sum of squared errors, an initialization term gets added to the sum of squared errors to yield the augmented LS criterion where 1Q-1 is some positive definite symmetric matrix. Note that with zero terms in the sum of squares, the solution of this criterion yields W = The augmented LS cost function has an optimality property from the point of view of estimation theory, applied to the estimation of the filter coefficients Mi. Indeed, this LS criterion leads to the so-called Bayesian estimate of W if the optimal error signal ci (W°) is white Gaussian noise (with variance #0) that is independent of the input signal (s) and prior information exists on the filter settings 6Y'in the form of a Gaussian distribution with mean W_1 and covariance matrix 'R-'. So, the larger R_I, the closer p should be to the optimal filter °. In practice however, often little information is available on W'° and hence 14-I is often chosen arbitrarily (e. g. W-1 = 0) and R_1 is taken as small as possible (typically as small as the numerical implementation of the algorithm safely permits). In general, regardless of the initialization, the solution 14'k of the augmented LS cost function converges to the optimal solution W° as the amount of data k tends to infinity. This is because time averages converge to statistical averages for most signals.

In order to dampen even further the influence of the initialization (or in general, to permit the RLS algorithm to track possible changes with time in the joint statistics of input and desired- response signals), exponential weighting can be introduced. The effect of this is that the past gets forgotten exponentially fast. With an exponential weighting factor A 6 (0, 11 the LS criterion becomes With A < 1 however, the filter solution Wk will never exactly converge to the optimal filter Wo because even as k tends to infinity, the total effective amount of data in the cost function becomes constant, commensurate with the time constant of the exponential window. This is the price to be paid to be able to forget the past quickly. So if the goal is to optimize the filter setting at a certain finite time instant k, the forgetting factor A should be carefully designed, taking both estimation quality and numerical effects into account.

Finally, in order to more easily allow the derivation of a so-called fast RLS algorithm, the prewindowing transient period may be incorporated into the LS cost function, leading to : The optimal error signal in this case is : The orthogonality principle of LS leads to : #k#kT = 0 # #k#kT = #k#kT - #k#kT WkT = #k#kT. The =0 normal equations are hence : where Rk is an extended sample covariance matrix (as compared to the regular sample covariance matrix Rk = UkUk), and #k is the minimum value of the LS criterion. The solution to the normal equations is : <BR> <BR> <BR> Wk Rk = dkUk<BR> <BR> <BR> <BR> <BR> <BR> #k = #k#kT - Wk#k#kT = #k#kT - #k#kT(#k#kT)-1#k#kT.

Recursive Least-Squares (RLS) Algorithm From the recursive relations : the following recursion is obtained for Wk : Wk = Wk-1+(dk-Wk-1Uk)UkTRk-1 = Wk-1 + #kp Ck #kp=#k(Wk-1) Ck where c'is is ttie"predicted" (or a priori) error signal (predicted using the previous filter setting Wok-1) and Ck is the Kalman gain. Note that Ck is like ti/k with dk replaced by # = [1 0###] : Ck kRk UkTRk'. The quantity o-is called the pinning vector - it pins down the most recent sample, e. g., Ut au = Uk. The Kalman gain Ck is the filter for estimating a from Uk with error -Uk and error energy given by ( #k)#T = 1-CkUk = 1-UkTRk-1Uk = γk, which equals the last component of the corresponding error signal. The quantity yk E (0, 1] is often called the likelihood variable. It can be considered to be the RLS adaptation gain. Indeed, we get for the a posteriori (after updating tilk) error signal : Cp k <BR> <BR> #k = #k(Wk) = dk-WkUk=dk-Wk-1Uk-#kpCkUk<BR> <BR> <BR> <BR> <BR> =#kp(1 - CkUk) # #kpγk To find a recursion for Rk-1 the Matrix Inversion Lemma is applied on Rk = #Rk-1 + UkUkT, Which leads naturally to the introduction of Ck =UkT #-1Rk-1-1 = γk-1Ck = overnormalized Kalman gain.

The RLS algorithm can then be formulated, which is a recursion for Wk-1, R-1 < Wk, Rk-1 with initialization W-1, R-1-1 : Riccati equation.

The algorithm described above leads to the lowest complexity, but some algorithmic variations involving Ck instead of Ck are possible by exploiting the relations <BR> <BR> <BR> #kp γk #k = #kpCk = #k#k,<BR> <BR> <BR> #kTγk#k=CkTγk-1Ck.

An update equation for the LS error energy can also be obtained (if desired) : #k - ##k-1 + #k#kpT where the latter transposition operation is required only if cl would have been a vector signal (not the case for a DFE).

Fast RLS Algorithms Study of the input data structure reveals that permutation matrices PAm, PD (PA-1 = PAT, PD-1 = PDT) can be introduced to isolate the latest data or the oldest data in the extended data matrix t/N+3, k, with a regular data matrix Uk or Uk_l being the complementary part : This leads to the following''shift, time update"structure : which means that going from the old data Uk 1 to the new data Uk can be accomplished by shifting in new data uk (temporarily leading to an extended data matrix UN+3, k) and shifting out old data Uk. This shift time update structure allows for the derivation of fast RLS algorithms. These algorithms require the introduction of forward and backward prediction quantities to account for the introduction of new and the discarding of old data, as follows : Forward Prediction Backward Prediction Error Signal #k = #k - Ak #k-1 #k = Uk Dk Uk #k=#k#T irk=#k#T Filter Ak = #k#k-1TRk-1-1 Dk = #k#kTRk-1 Ak=[I3-Ak]PA <BR> <BR> <BR> <BR> <BR> ".<BR> <P> Error Energy αk=#k#kT=#k#kT ßk=#k#kT = #k#kQ The introduction of these prediction quantities allows for an alternative update of the Kalman gain and the likelihood variable that does not involve the Riccati equation. The update of the prediction quantities themselves can then be done in the same fashion as the update for the filter Wk and the error energy (k. The update of the Kalman gain and likelihood variable requires the introduction of an extended Kalman gain and likelihood variable <BR> <BR> <BR> <BR> <BR> <BR> <BR> CN+3, k = UN+3,kT RN+3,k-1 = γN+3,k#N+3,k,<BR> <BR> <BR> <BR> <BR> <BR> <BR> T I-1<BR> CN+3,k = UN+3,k1#-1RN+3,k-1-1, 1 γN+3,k = 1-CN+3,kUN+3,k =<BR> 1 + #N+3,kUN+3,k<BR> <BR> <BR> <BR> <BR> <BR> where UN+3,k = #N+3,k#T is the extended input data vector at time k.

Fast Kalman algorithm The first Fast RLS algorithm (introduced in 1976) was the Fast Kalman algorithm, shown in Table 1. The Fast Kalman algorithm works with Ck, the entries of which have a lower dynamic range than the entries of Ck, a desirable property for fixed-point implementation. In the table, the quantity CkPD denotes the entries in CN+3,k that are in the same (column) positions as the entries of 13 in Dk = [I3 -Dk]PD. Similarly, the quantity Ck will be used, which are the entries in CN+3,k that are in the same (column) positions as the entries of 13 in Ak = 113-Ak] PA. The table shows the computational complexity of the algorithm, measured by the number of multiplications or additions (or approximately the number of multiply-accumulates) that need to be performed.

These complexities are indicated for the general case of q channels. In the FS DFE example, q= 3.

Fast Transversal Filter (FTF) algorithm The Fast Transversal Filter algorithm (see Table 2) works with Ok (just like the RLS algorithm), which results in the lowest computational complexity. Whereas the FKA computes the backward prediction error rk as the output of the backward prediction filter Du-1, the FTF algorithm avoids this inner product and finds rk by the manipulation of scalar (in the single channel case) quantities. Tl Fast Kalman Algorithm x, + prediction part 1 ekp = Ak-1UN+q,k Ajk = Ak-1 -ekp[0 C-k-1] qN 3 ek = Ak UN+q,k qN 4 αk = #αk-1+ekekpT 2q2 5 CN+q : k = #0 Ck-1 PA = ekTαk-1Ak qN+O(q3) k k 7 Dk CkPD)-1 (Dk-1-rkpCN+q,k) (31- 8 [0 Ck# = CN+q,kPDT - CkPD Dk qN filtering part 9 #kp = dk - Wk-1 Uk N 10 Wk = Wk-1 + #kpCk N total complexity (9q+1)N+O(q3) Table 1 : The Fast Kalman Algorithm (FKA).

As a result, however, the FTF algorithm is numerically less stable than the FKA in the sense that round-off errors grow faster. It is possible to combine the two ways of computing the signal rk to create a measurement of the round-off error subsystem associated with the algorithm, and to feed back this error measurement, to stabilize the unstable error propagation subsystem of ttie algorithm.

Initialization of Fast RLS In the foregoing Fast RLS algorithm, the following initialization is performed. Filtering part : 1. Wk=_l = W_1 corresponding to d_l = W-1#-1(implicitly).

2. Usually, d = 0 and W_1 = 0.

Prediction part : T2 Fast Transversal Filter (FTF) Algorithm x, + prediction part 1 ekp = uk - Ak-1 Uk-1 qN 2 #kPA = ekpT # -1αk-1-1 2q2 3 CN+q, kPAT = [0 #k-1] + CA [Iq - Ak-1] γN+q,k-1 = γk-1-1 + #kPAj ekp q rkp = #ßk-1#kPDT 2q2 0 #k] = (#N+q,kPAT) (PAPDT) - #kPD [Iq - Dk-1] qN 8 k-^YN4q, k k 8 ek = ekp #39k-1 q 9 Ak = Ak-1 +ek #k-1 qN 10 αk-1 = #-1αk-1-1 -#kPAT γN+q,k#kPA (1#)q2+q 11 rk = rkp γk (1 ) q 12 Dk = Dk-1 + rk#k qN 13 ßk = #ßk-1 +rkprkT q2 filtering part 14 #kp = dk - Wk-1 Uk N 15 #k = #kpγk 1 16 Wk = Wk_, + ek Ck total complexity (2 #) (5q+2)N + 6q2 + 5q + 1 Table 2 : The Fast Transversal Filter (FTF) algorithm. are permutations of diagonal matrices.

2. Hence the LS estimate of any row from any other row (s) is 0.

3. For the filters, A-1 = D-1 = CL, =0.

4. For the error energies (the energy of the signal that is being estimated) : --I = 7 (TT = 1 Lowest Complexity Fast Kalman algorithm The FTF algorithm works with G8k whereas the FKA works with Ck. For Ck = UkT#-1Rk-1-1 in the prewindowing transient phase, the last non-zero coefficients for the different channels put together give which shows that for small initialization constants µB, µF, the overnormalized Kalman gain Ck will take on large values during the transient phase. The unnormalizc : d Kalman gain Ck =UkT Rk-1 suffers much less from this problem since the "denominator" Rk contains the latest data Uk. This problem of larger dynamic range for #k compared to Ck manifests itself more generally whenever a sudden increase in the input signal level occurs. This motivates (with an eye toward fixed-point implementation) the use of Ck over Ck. The algorithm shown in Table 3 uses Ck as in the FKA. It also computes the backward prediction error by straightforward filtering as in the FKA (as opposed to avoiding this inner product after the manner of the FTF algorithm). This leads to a less unstable algorithm. Finally, note that as a result the algorithm does not require pk (required in the FTF algorithm). These are the most important characteristics of the FKA, and hence the resulting fast RLS algorithm can appropriately be called an FKA, albeit the fastest version of the FKA. T3 Lowest Complexity FKA #, + prediction part 1 #kp = uk - Ak-1 Uk-1 qN A pT 1 2 γN+q,k = γk-1/(1+γk-1#kPa#kp) 4 1 # #-1αk-1-1 -#kPAT γN+q,k#kPA 5 Ak-1 + ekpCk-1 qN CN+q,kPAT = [0 Ck-1] + γN+q,k #kPA [Iq - Ak] 7 rkp = uk -Dk-1Uk qN 8 γkγN+q,k-1 = 1/(1-CkPDrkP) (1#) q 9 γk i= (γkγN+q,k-1)γN+q,k 1 10 [0 Ck] = (3039kγN+q,k-1) [(CN+q,kPAT) (PAPDT) - CKPD[Iq -Dk-1]] (q# 1) N CN+q, Dk = Dk-1 +rkp Ck qN filtering part 14 #kp = dk - Wk-1 Uk IS Wk = Wk-1 + #kpCk total complexity (2#) (6q+3)N+3q2+3q+2 Table 3 : Lowest complexity Fast Kalman Algorithm.

In Matlab notation (for portions of vectors) : cp' 10 in Table 3 can be rewritten as <BR> <BR> <BR> <BR> <BR> <BR> <BR> Ck = (γkγN+q,k-1) [(CN+q,kPAT) [1,4 : Nfb+2,2, 3, Nib+4 : N2] CkPD Dk-1].<BR> <P> J Since 7k7N+9. k > 1. the implementation of the multiplication with this number on a fixed-point processor may take more than one cycle.

The least complex computation of the LS filter estimate would be to solve the normal equations with the generalized Levinson algorithm. However, this may be more sensitive in a fixed-point Prewindowing/Initialization Removal Postprocessing It is clear that avoiding the prewindowing assumption and the initialization (when 14"-, is not particularly close to W°) would lead to much faster and better convergence. (The influence of the initialization can be made small by choosing Eie, yF small, but a fixed-point implementation, especially, will pose constraints on how small these quantities can be made.) With initialization and prewindowing, exponential weighting needs to be applied, not so much to adapt, to changing statistics, but simply to forget the initialization and the prewindowing. Without the perturbation of initialization or prewindowing, no exponential weighting would need to be applied. This would lead to better estimation performance and fewer numerical problems.

To be robust against changing statistics later on in time, tracking performance could still be obtained without exponential forgetting by processing the data in bursts and at each burst in- corporating as initialization the filter setting resulting from processing the previous burst with appropriate weighting. (In this case, the initialization would not have to be gotten rid off, only the prewindowing.) A straightforward way to avoid prewindowing is to use the Growing Window Covariance (GWC) version of the FKA. In this fast RLS algorithm, the LS problem corresponding to the covariance window in Fig. 2 is solved at each time instant k. This algorithm is more complex than the prewindowed version. Indeed, it requires the introduction of an additional filter G, the dual Kalman gain, which needs to be updated also at every time instant. The GWC FKA may also be more sensitive for a fixed-point implementation (due to larger dynamics of quantities).

As mentioned earlier, in many applications it may not be possible to run a fast RLS algorithm in real-time to get initial convergence, due to complexity considerations. On the other hand, it may . also be overkill to keep a fast RLS algorithm running to adapt to slow variations in the optimal filter settings. In this case, data should initially be acquired and stored. Then a fast RLS algorithm can be run off-line to converge on these data. The amount of data to be stored and processed should be such that it allows the LS filter estimate to have close to optimal performance (small excess MSE). For instance, an amount of data corresponding to k = 1ON should be largely sufficient, for equalization applications. If a covariance window is used, less data can be used if that leads to a more favorable memory/complexity/performance trade-off. If an FKA with initialization and prewindowing is used, however, much more data would normally be required to get comparable performance.

Now, given (as described above) that fast RLS algorithms with prewindowing have the lowest complexity, an effective strategy is to simply run the prewindowed FKA, possibly with relatively large initialization constants it to dampen the dynamics of the (fixed-point) quantities. This will be done over a burst of data such that the corresponding covariance window LS problem gives accept- able performance (so the data length is relatively short). At the end of the burst, a postprocessing FKA algorithm is run which will now remove the initial data vectors (hence the initialization con- st. ants in R l and the prewindowing). This will have a lower overall complexity than running a GWC version of the FKA.

Downdating RLS Algorithm To formulate the postprocessing algorithm, data matrices are needed which not only have an end time k but also a starting time j (j = -# in principle in the prewindowed case). With the initialization of Fig. 2, a starting time j =-oo is in fact equivalent to j =-N-q since all data prior to that instant are zero. So the filter becomes the solution of the following LS problem To obtain an RLS algorithm, the problem then is to find recursions to move j forward in time, until the prewindowing period is passed, so from about j = -N-q to j = n-1 where n = max{nB,nF} if both initialization and prewindowing need to be removed, or from 0 to n-1 if only prewindowing needs to be removed. Since the postprocessing consists of making the data window shorter by removing data at the beginning of the window, the resulting processing can be called downdating (as opposed to the usual updating).

From the recursive relations : the following recursion is obtained for Wj k : <BR> <BR> <BR> <BR> Wj+1,k = Wjm,k-#k-j(dj-Wj,kUj) UjTRj+1,k-1 = Wj,k-#k-j#j,k#j,k<BR> <BR> <BR> ##<BR> #j,k=#j(Wj,k) #j,k where Gj k is a (overnormalized) dual Kalman gain, this time not to reflect the effect of adding a data point at the end, but of removing a data point at the beginning. Furthermore, the (unnormalized) dual Kalman gain is Gj, k = (jT R-1 Note that Sk-iGjk is like lVjk with djk replaced by r = -jgj, k 7fu Ak-i The quantity T is called the dual pinning vector it pins down (and weighs) the oldest sample. The dual Kalman gain Gj, k is the filter for estimating T from Uj, k with error signal = # - #k-j Gj,k #j,k and error energy = (#-#k-j Gj,k#j,k)#T = #k-j #j,k where <BR> <BR> <BR> <BR> #j,k = 1 - #k-jGj,kUj = 1-#k-jUjTRj,kk0-1Uj= ########### = ################## # (0,1].<BR> <BR> <BR> j, k j @@@ @@j@@j+1,k@j Again, a relation of the form Gj,k = #j,k#j,k is obtained. To find a recursion for Rj,k,-1 the Matrix Inversion Lemma is again applied on Rj+1,k = Rj,k - #k-jUjUjT. The downdating RLS algorithm, which is a recursion for Wj,k, Rj,k-1# Wj+1,k, Rj+1,k-1 with initialization W-N-q,k Wk, R-N-q,k-1 = Rk-1 can then be formulated as follows : Riccati equation.

The corresponding downdate equation for the LS error energy (if desired) is given by : #j+1,k - #j,k - #j,k #k-j#j,k-1#j,kT where the latter transposition operation is required only if t, k is a vector signal (not the case for a DFE).

Downdating Fast Kalman Algorithm To find a downdating fast RLS algorithm, the shift structure in the data can again be exploited, of which the details are now : which means that going from the old data Uj_l, k-I to the new data Uj, k can be accomplished by shifting in new data uj, k (temporarily leading to an extended data matri out old data #j,k. To get a complete downdating strategy which will be used to downdate Gj-1,k to Gj,k, the regular time updating strategy (involving the regular Kalman gain Cj, k) is first used to downdate Gj_l k to Gj-1, k-1, and then the shift, structure is used (involving foward and backward prediction filters) to update Gj-1, k-I to Gj, k. The derivations are along the same lines as for the FKA/FTF algorithms. The resulting algorithm is shown in Table 4.

Just as the updating algorithm requires initialization, so also the downdating algorithm requires initialization. The following initialization (at j = -1, if the desired is to get rid of prewindowing only) may be used : W, A, D, C, ce y are initialized by their values obtained from the prewindowed algorithm, and G) jc = 0, (Li k = 1. The initialization can be placed earlier to get rid of the soft constraint initialization (W, R) also (This is done using the same initialization values, only the signal values to be processed during the downdating become more numerous). When downdating the soft constraint initialization, the complexity can be reduced by 3N-3 if the fact that the Ij contain only one non-zero entry gets exploited.

Prewindowing Suppression for the Filtering Section The filtering (equalization) error signal shows large values during the initial convergence of the algo- rithms. One would expect, however, that this would not be the case when the filter W is initialized to some setting W-1 that is relatively close to the optimal setting (as a result of previous adapta- tion). However, things are perturbed due to the prewindowing, which will lead good filter settings to produce a large error signal during the prewindowing transierlt. The prior art (Eleftheriou and Falconer) describes a solution to this problem. The solution consists of still using the prewindowcd input data vector for the prediction part of the fast RLS algorithm, so that a fast algorithm is possible, but to introduce a different data vector, calk, for the filtering section. U'k is the same as Uk except that it's not prewindowed. So differs from (Jk only during the prewindowing transient, in which period Uk contains some actual data from before time zero (assuming this data is available but. was simply not used due to the algorithmic constraints of prewindowed fast RLS algorithms).

So in this case, the filtering error signal is actually computed as ckp = dk - Wk-1 Uk' = (dk - Wk-1 (U'k - Uk)) - Wk-1 Uk = d'k - Wk-1Uk where Uk-Uk is non-zero, and d'k is different from dk, only during the prewindowing transient. So things happen as if the prewindowing assumption is still used, but with a (temporarily) modified desired-response signal dk which compensates as well as it can for the prewindowing assumption (since before updating at time k, Kl is our best estimate for W.'1'he filtering error thus computed does not get perturbed by prewindowing and hence does not show particularly large values during the prewindowing (not larger than what VV-l can deliver).

To incorporate this modification in the postprocessing, it suffices to use du instead of dk (Uk does not need to be used). Indeed, the filter estimate would have been exactly the same if prewindowing (Uk) in the filtering section was used, with dk as desired response signal.

Partial Cancellation of the Initialization It is trivially possible to cancel the initialization only partially. This may be desirable if the initial- ization constants were chosen on the basis of numerical considerations, whereas after cancellation, the objective is for the constants to take on (smaller) values that correspond to certain statistical estimation considerations (Bayesian point of view).

Indeed, if for the postprocessing purposes, IIF,/i, are set to values < AB, then after postprocessing the initialization will still influence the filter estimate, but now according to the constants µF - µ'F, µB - µ'B.

Updating and Tracking by Processing Data in Bursts To make up for the fact that the available processing power may be insufficient to run fast RLS algorithms in real time, data can be stored and processed in bursts of length and frequency such that the processing of a burst is finished before the next. burst of data arrives. To incorporate the results from processing previous data bursts, when processing the next burst, the (soft constraint) initialization mechanism can be used. To have an appropriate weighting of the previous results, the following initialization values can be used : put, A, D, C, 1J to 0, γ to 1, and leave a''and 14' unchanged. This corresponds to a pre-and postwindowed data matrix U l wit h block-diagonal (3 x 3 blocks) joli. The advantage of such a simple initialization is that the numerical errors associated with critical (unstable) quantities are flushed out. The appropriate weighting is provided by leaving x'unchanged. If A = 1 is used, then the filter estimate is the result of all the data bursts processed (not in the usual LS sense though, but in some weighted version of it). Forgetting, to track possible changes in the environment, can be introduced by taking A < 1. Alternatively, one can take A = 1 but weight α-1: α-1 # #1-1α-1 at initialization, where Ai is some burst-level forgetting factor. Or one can use a combination of both weighting mechanisms.

Obviously, when incorporating information from previous bursts, the initialization should not be removed by postprocessing (postprocessing should then only be applied to the prewindowing transient). T4 Downdating FKA #,+ prediction part 1 #j-1,k = Cj-1,kUj-1 N 2 γj,kγj-1,k-1 = 1 - #k-j+1γj-1k-1#j-1,k-1#j-1,k2 4 5 #j-1,k-1-1 = (γj,kiγj-1,k-1)j-1,k-1#-1 1 6 Gj-1,k-1 = #γj,kγj-1,k-1 Gj-1,ki +γj-1m,k-1#j-1,kCj,k 2N + 2 7 ej,k = uj-Aj,kUj-1 qN 8 Gj,kPA = ej,kTαj,k-1 q2 9 #N+q,j,k-1 = #j-1,k-1-1/(1 - #k-j#j-1,k-1-1 Gj,kPAej,k) (*1 #) q + 3 10 αj+1,k-1 = αj,k-1+#k-j#N+q,j,k-1 Gj,kPAT Gj,kPA q2+q+1 ilk 12 Aj+1,k = #j,k - #k-j#j-1,k-1-1 #j,k Gj-1,k-1 qN + q 13 rj,k = u'j - Dj,kUj qN 14 #j,k-1 = #N+q,j,k-1/(1+#k-j#N+q,j,k-1Gj,kPD rj,k) (1#) q+2 15 [0 Gj,k] = (GN+q,j,kPAT) (PAPDT) -Gj,kPD[Iq - Dj,k] qN 16 Dj+1,k = Dj,k - #k-j#-1j,krj,kGj,k qN + q + 1 filtering part 17 #j,k = dj - Wj,k Uj N total Wj+1,k = Wj,k - #k-j#j,k-1#j,kGj,k N + 1 ilk Table 4 : Postprocessing Fast Kalman Algorithm to transform the initialized/prewindowed LS esti- mate into a Covariance Window LS estimate.

Use of the described postprocessing fast Kalman algorithm shows that equivalent results as conventional algorithms can be obtained using from six to sixteen times less data than conventional algorithms.

It will be appreciated by those of ordinary skill in the art that the invention can be embodied in other specific forms without departing from the spirit or essential character thereof. The presently disclosed embodiments are therefore considered in all respects to be illustrative and not restrictive. The scope of the invention is indicated by the appended claims rather than the foregoing description, and all changes which come within the meaning and range of equivalents thereof are intended to be embraced therein.