It is common, however, for the system to be nonlinear. There are many possible causes for system nonlinearities, including characteristics of nonlinear components (such as conductors, capacitors and transistors), the input signal's frequency subrange, history and rate of change (also referred to “slew rate”), as well as external factors such as operating temperature.
Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.
A nonlinear adaptive filter is disclosed. In some embodiments, the nonlinear adaptive filter includes interfaces for receiving an input signal and a target signal. It further includes an adaptive filter module that is configured to generate relative location information pertaining to a relative location of the input signal within a possible range of inputs. A thermometer code address generator is used in some embodiments to generate the relative location information. The relative location information is used to determine input dependent filter parameters. In some embodiments, the relative location information includes a thermometer coded address vector, which is used to select input dependent filter parameters from a plurality of memory banks. In some embodiments, the input dependent filter parameters include filter coefficients that are used to generate an output signal. A feedback signal is generated based at least in part on an output signal and the target signal. Stored input dependent filter parameters are adapted based on the feedback signal.
yn=ã0(Xn)xn+ã1(Xn)xn−1+ . . . +ãN−1(Xn)xn−N+1 [1]
where Xn=[xn . . . xn−N+1].
The above nonlinear filter function has filter taps with coefficients ãk that depend on the present input sample as well as previous input samples. In some embodiments, each coefficient is implemented as a constant plus a nonlinear function of the signal. As will be discussed in detail below, these coefficients are adaptable to achieve the desired filter response, such as a filter response that is a nonlinear function.
An alternative expression for equation [1] is:
where Ãj=(xn−j)=[ãj,0(xn−j)ãj,1(xn−j) . . . ãj,N−1(xn−j)].
The above equations indicate that each filter tap coefficient can be expressed as a sum of sub-taps
and each sub-tap Ãj(xn−j) in turn is a different function of xn−j. Equivalently, the coefficient of the k-th filter tap can be expressed as:
Returning to
The values of filter coefficients ã0, ã1, ã2, and ã3 each depend on the present input sample as well as past input samples (sometimes also referred to as delayed input samples or the input signal's history). The coefficient values are computed based at least in part on sums of selected, pre-stored values. In this example, the values are selected from appropriate storage locations within a plurality of memory banks. System 200 includes memory banks 206a, 206b, 206c, and 206d that correspond to filter taps 0, 1, 2, and 3, respectively. Although four memory banks are shown for purposes of example, the number of memory banks depends on the number of filter taps N and may vary in other embodiments. The memory banks may be implemented using one or more memory devices of any appropriate type, such as registers, buffers, DRAM, SRAM, etc. The memory banks represent the logical organization of memory used to store filter parameters. In some embodiments, the memory banks are implemented using M physical memory devices where M does not necessarily correspond to N. For example, all four memory banks shown in system 200 may be implemented using a single memory device such as a single EEPROM or RAM chip.
According to this example, each memory bank stores N sets of values (N=number of taps) that contribute to the N filter coefficients. Each set of values is implemented as a coefficient vector that includes S entries. The value of S depends on the granularity or precision of the nonlinear function being implemented. For example, if the nonlinear function is such that for all input values βmin<xn−j≦β0 (where βmin is the minimum expected input value, and β0 is a predefined value), coefficient function Ãn−j(xn−j) maps to one set of vector values, and for all input values β0<xn−j<βmax (where βmax is the maximum expected input value), the coefficient function maps to another set of vector values, then the coefficient function is said to have a granularity of 2 and each set of coefficient vector includes two entries. In the example shown in
A thermometer code address generator 208 is used to facilitate the selection of the appropriate coefficient vector from the memory banks. The thermometer code address generator indicates the relative location of the input signal within the range of possible input signals. In some embodiments, the thermometer code address generator includes one or more comparators that compare the input with certain predefined subranges, and one or more multiplexers that map the output of the comparators to an appropriate address vector. The address vector indicates the relative location of the input signal within the possible input range. In some embodiments, the address vector has at most one sign change between any two adjacent entries.
The thermometer code address generator is configured to divide the possible range of inputs {right arrow over (β)}={βmin, βmax} into S subsubranges. The values in these subsubranges may be distributed evenly, logarithmically, exponentially, or in any other appropriate ways. Upon receiving an input value xn−j, the thermometer code address generator applies the following coding function to generate the appropriate output vector:
{right arrow over (x)}n−j=Sign(xn−j−{right arrow over (β)}) [4]
Based on the thermometer coder output, the set of values that corresponds to the fist positive location in vector {right arrow over (x)}n−j is selected from the memory bank. The output of the thermometer code address generator is delayed by delay blocks 210b, 210c, and 210d. The delayed values are used to select the appropriate stored coefficient vectors from corresponding memory banks. At each filter tap n−j, selected values from the filter banks (the “sub-taps”) are summed to generate the corresponding coefficient value ãn−j. In some alternative embodiments, the thermometer code address generator directly determines which coefficient values in the memory bank should be selected.
To generate a filter coefficient for a filter tap, the corresponding entries from the selected rows are summed. In this example, the 0-th entries of the selected rows (i.e., 11.3, 0.7, 2.0, 0.2) are the values selected and summed to generate coefficient ã0 for the tap 0. Similarly, 6.6, 1.4, 2.1, and 0.1 are the values selected and summed to generate coefficient ã0 for tap 1, and so on.
Returning to
A target signal ηn is received on interface 204. How the target signal is obtained depends on system configuration and is described in greater detail in
Ãj({right arrow over (X)}n)=Ãj({right arrow over (X)}n)+μεnXn [6]
where
{right arrow over (X)}n[{right arrow over (x)}n{right arrow over (x)}n−1 . . . {right arrow over (x)}n−N+1]
are the thermometer-coded values of the input signals.
The feedback loop for coefficients stored in memory bank 206d is illustrated in detail in
A filter system similar to 200 is a cost effective way of implementing the theoretically optimal Volterra series expansion and as well as Weiner-Hammerstein models that include memory dispersion. In some embodiments, a filter with N taps is used, where each tap k has the form of equation [3], i.e., the coefficient function
in which ãj,k(xn−j) is an arbitrarily complex nonlinear function of the variable xn-j. Using Volterra series expansion, ãj,k(xn−j) can be expressed to arbitrary precision using an mth order polynomial of xn−j. Similarly, all the xn−j's in tap k (where j=0, 1, . . . N−1) can also be expressed to arbitrary precision. For example, the coefficient ãj,k(xn−j) can be written as a 5th order polynomial
ãj,k(xn−j)=xn+xn2+xn3+xn4+xn5 [7]
where the weights of the coefficients are assumed to be 1 for the sake of simplicity but may vary in practice. Accordingly,
The kth coefficient ãk(Xn) expressed as equation [8] is multiplied by xn−k, forming a polynomial with cross terms comprising xn−k−j multiplied with xn−k for j=0, 1, . . . , N−1. Thus, the nonlinear function is a true Volterra expansion of arbitrarily high degree and has memory. For example, when k=0, the function includes all cross terms of xn, and for k=1 the function includes all cross terms of xn−1, and so on.
In some embodiments, rather than storing all the coefficients in memory, filter coefficient functions including construction functions such as Radial Basis Functions (RBF), cubic splines, or sinc functions are used to provide the coefficients. The construction functions include windowed interpolation functions that use weighting coefficients and distance from function origins to generate interpolation values. In a construction function, discrete sample values are summed to generate a smoothed approximation of a background function and values between sample points. The general format for a construction function is:
where ci are the centers of the RBF and wi are the coefficients.
An example of a RBF is:
where γ is a constant that determines the shape of the RBF. The coefficients are adapted according to the following:
Wn+1=Wn+μεnEn
where Wn=└wl,n . . . wL,n┘ and En=[Exp(−γ∥xn−cl∥) . . . Exp(−γ∥xn−cL∥)]
Thus, the filter can be implemented using RBF components instead of implementing the polynomial of equation [7] as an actual polynomial structure or storing the coefficients in a lookup table. This implementation allows for tradeoffs be made between the amount of memory and the number of multiplications required. For example, let
In some embodiments, the number of centers L is chosen depending on the desired accuracy and the multiplication requirements.
Note that when a signal x lies on the center c, the coefficient w corresponds to what is stored in memory since Exp (∥xn−ci∥)=1. This means that a RBF can be used in conjunction with stored values to provide interpolation between quantization levels of x. Since only a few adjacent locations contribute to the interpolated result at x, the amount of processing required by the RBF in this case is less than if no stored values were used.
In an N-tap filter embodiment similar to filter 200 described above, the output is obtained with a convolution function that requires N multiplications. The number of multiplications can be reduced in some embodiments by simplifying the expression for the coefficients.
Ã(Xn)=[ã0,0(xn)ã1,0(xn−1) . . . ãN−1,0(xn−N+1)] [11].
The output is expressed as:
yn=ã0,0(xn)+ã1,0(xn−1)+ . . . +ãN−1,0(xn−N+1) [12].
In other words, each filter tap k implements a corresponding function ãk of kxn−. Filter function [12] does not require any multiplication and is computationally inexpensive. To implement the filter, the possible range of inputs {right arrow over (β)}={βmin, βmax} is divided into S subranges based on the desired function granularity/precision. Each input subrange k maps to a corresponding function ãk(xn−k). Rather than storing vectors that correspond to the subranges as was shown in
The input xn received on input interface 402 is sent to a thermometer code address generator 404, which generates an appropriate output vector according to equation [4]. The vector is used to locate a value ã0,0(xn,j0) in memory bank 406a that maps to the input, where j0 depends on the subrange in which the input is located. Similarly, thermometer coded and delayed input samples are used to locate in memory banks 406b, 406c, and 406d function values ã1,0(xn−1,j1), ã2,0(xn−2,j2), and ã3,0(xn−3,j3), respectively.
Returning to
ãj,0(xn−1)=ãj,0(xn−1)+μεn [13]
At 508, an output signal is generated using the input dependent filter parameter. In embodiment 200, for example, the output signal is generated by multiplying the filter coefficients with the input samples and summing the results. In embodiment 400, the output signal is generated by summing results of the functions selected from the memory banks. At 510, a feedback signal is generated and fed back to the system. The feedback signal is based at least in part on the output signal and the target signal. In embodiment 200, the feedback signal is used to update the coefficients stored in the memory banks. In embodiment 400, the feedback signal is used to update the functions or function values stored in the memory banks.
In some embodiments, multiple adaptive nonlinear filters are cascaded to form filter functions that are nonlinear functions of nonlinear functions.
Let filter 602 be expressed as:
yn=ã0(Xn)xn+ã1(Xn)xn−1+ . . . +ãN−1(Xn)xn−N+1 [14]
where Xn=[xn . . . xn−N+1].
Filter 604 is expressed as:
wn{tilde over (b)}0(Yn)yn+{tilde over (b)}1(Yn)yn−1+ . . . +{tilde over (b)}N−1(Yn)yn−N+1 [15]
where Yn=[yn . . . yn−N+1].
Thus,
wn={tilde over (b)}0(Yn)ÃnXn+{tilde over (b)}1(Yn)Ãn−1Xn−1+ . . . +{tilde over (b)}N−1(Yn)Ãn−N+1Xn−N+1 [16]
Xn−j in equation [16] corresponds to vector └xn−j . . . xn−j−N+1┘, which has a length of N. The resulting cascaded filter function wn is a nonlinear function of [xn . . . xn−2N+1], which has a length of 2N−1. The cascaded filter of length 2N−1 requires less memory than a single uncascaded filter of length 2N. Suppose the input range is divided into S subranges, then 2N×S coefficients are required by a cascaded filter such as 600. In contrast, a single uncascaded filter of length 2N would require 2N×2N×S coefficient entries. Thus, the cascade filter comprising two length-N filters requires ½ of the amount of memory required by an uncascaded length-2N filter. More generally, a cascaded filters comprising L filter taps requires 1/L as much memory as an uncascaded filter of approximately the same length.
The feedback loops of filters 602 and 604 are similar to the feedback loop shown in
{tilde over (b)}j(Yn)={tilde over (b)}j(Yn)+μεnyn−j [17]
ãj(Xn)=ãj(Xn)+μεnxn−j [18]
In some embodiments, an adaptive nonlinear filter is configured to handle complex signals.
Filter 700 is expressed as:
{circumflex over (η)}In and {circumflex over (η)}Qn are subtracted from I and Q components of the target signal, ηIn and ηQn, respectively, to generate error signals εIn and εQn. The errors are fed back to update the stored coefficients. The feedback loops are similar to those of
2N multiplications are required to generate output term yIn and 2N additional multiplications are required for the updates associated with the memory banks storing the coefficients for the I component. Similarly, a total of 4N multiplications are also required to generate output term yQn and to update the memory banks storing the coefficients for the Q component.
In some embodiments, the adaptive nonlinear filter is configured to handle even or odd harmonic distortions in the target signal. Whether a harmonic distortion is even or odd depends on the frequency location of the distortion relative to the desired signal, i.e. whether the distortion occurs at an even or an odd multiple of the desired frequency.
{right arrow over (x)}n−j=Sign(|xn−j|−{right arrow over (β)}) [20]
Filters 800 and 900 further include sign operators 804 and 904, respectively. The sign operator extracts the sign of the input, outputting either −1 or 1. In both filter embodiments, the sign of the input is multiplied with the thermometer code address, and the multiplication result is used as the address for selecting an appropriate coefficient vector from the corresponding memory bank. Delay elements and additional memory banks are included to provide coefficients for additional filter taps. In even harmonic filter 800, selected values from the memory banks are summed to generate appropriate filter coefficients. In odd harmonic filter 900, the selected values are multiplied with their corresponding sign values before they are summed to generate the filter coefficients. The general expression for this type of N-tap filter is:
where sjn=1 for an even harmonic filter such as 800, and sjn=Sign (xn−j) for an odd harmonic filter such as 900. A converged output signal of 800 has even harmonics that are approximately equal to the even harmonics of the target signal, although its odd harmonics are not necessarily close to the odd harmonics of the target. The resulting output signal of 900 has odd harmonics that are approximately the same as the odd harmonics of the target signal, although its even harmonics are not necessarily the same as those of the target signal.
The filter coefficients are updated according to the following:
Sn∘Ãn+1−j=Sn∘Ãn−j+μεn|Xn| [22]
where
In some embodiments, an even harmonic filter and an odd harmonic filter are combined to form a composite filter that handles both even and odd harmonics. Components such as the absolute value operator, the thermometer code address generator, and the sign operator can be shared by the odd and even filter branches.
Nonlinear adaptive filters are used in many applications.
In example system 1000 of
In example system 1030 of
In example system 1060 of
Adaptive nonlinear filtering has been described. The technique allows nonlinear filter functions to be implemented using relatively simple elements such as memory banks and/or arithmetic operators, and has relatively inexpensive computational requirements.
Although the foregoing embodiments have been described in some detail for purposes of clarity of understanding, the invention is not limited to the details provided. There are many alternative ways of implementing the invention. The disclosed embodiments are illustrative and not restrictive.
This application is a continuation in part of U.S. patent application Ser. No. 11/061,850 entitled LOW-COMPLEXITY NONLINEAR FILTERS filed Feb. 18, 2005, now U.S. Pat. No. 7,613,759 which is incorporated herein by reference for all purposes. This application claims priority to U.S. Provisional Patent Application No. 60/998,057 entitled CANONICAL NONLINEAR FILTER filed Oct. 4, 2007 which is incorporated herein by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
4887306 | Hwang et al. | Dec 1989 | A |
5243624 | Paik et al. | Sep 1993 | A |
5311435 | Yocum et al. | May 1994 | A |
5483439 | Ono et al. | Jan 1996 | A |
5563954 | Ono et al. | Oct 1996 | A |
5775293 | Kresse | Jul 1998 | A |
5859773 | Keeler et al. | Jan 1999 | A |
6285971 | Shah et al. | Sep 2001 | B1 |
6765931 | Rabenko et al. | Jul 2004 | B1 |
6856191 | Bartuni | Feb 2005 | B2 |
6885323 | Batruni | Apr 2005 | B2 |
6999510 | Batruni | Feb 2006 | B2 |
7165465 | DeLair et al. | Jan 2007 | B2 |
7460916 | Batruni | Dec 2008 | B2 |
7467172 | Druck | Dec 2008 | B2 |
7689297 | Batruni | Mar 2010 | B2 |
7869550 | Batruni | Jan 2011 | B2 |
20020169585 | Jones et al. | Nov 2002 | A1 |
20020178133 | Zhao et al. | Nov 2002 | A1 |
20040164791 | Batruni | Aug 2004 | A1 |
20050212589 | Batruni | Sep 2005 | A1 |
20050212596 | Batruni | Sep 2005 | A1 |
20060061493 | Larson et al. | Mar 2006 | A1 |
20060122714 | Batruni | Jun 2006 | A1 |
20060176989 | Jensen | Aug 2006 | A1 |
20060215064 | Dawson et al. | Sep 2006 | A1 |
20060245583 | Mizushima et al. | Nov 2006 | A1 |
20080080644 | Batruni | Apr 2008 | A1 |
20080095264 | Deng et al. | Apr 2008 | A1 |
20090054999 | Batruni | Feb 2009 | A1 |
Number | Date | Country |
---|---|---|
1754315 | Mar 2006 | CN |
1870614 | Nov 2006 | CN |
Entry |
---|
U.S. Appl. No. 11/246,914 Office Action Mailed Jan. 22, 2008. |
U.S. Appl. No. 12/288,783 Office Action Mailed May 27, 2009. |
Chinese Office Action dated Mar. 12, 2012, issued in related Chinese Application No. CN 200880114456.3. |
Number | Date | Country | |
---|---|---|---|
20090094304 A1 | Apr 2009 | US |
Number | Date | Country | |
---|---|---|---|
60998057 | Oct 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11061850 | Feb 2005 | US |
Child | 12286733 | US |