Nonlinearity is a problem present in many signal processing systems. For example, the channel and the devices can introduce nonlinearity to a transmitted signal, thus causing distortion in the output. A typical way of correcting the nonlinearity is by using a training signal with known signal characteristics such as amplitude, phase, frequency, data sequence, and modulation scheme. The nonlinearities in the system will introduce distortion. The received signal is a composite signal of a distorted component, and an undistorted component that corresponds to the ideal, undistorted training signal. During a training period, the training signal is available to the receiver. Filters in the receiver's signal processor are adjusted until the output matches the training signal. This training technique requires that the ideal, undistorted training signal be available during the training period. The technique is sometimes impractical since adding the training to the manufacturing process will increase the cost of the device. Further, system nonlinearities may vary due to factors such as variations in signal paths, power supply, temperature, signal dynamics, Nyquist zone of the signal, and/or aging of components. It is, however, often impractical to re-train the device since the undistorted training signal may no longer be available, it would be desirable, therefore, to be able to more easily compensate for system nonlinearity. It would also be useful if the solution would not significantly increase the cost of the device.
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 and/or signals.
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.
Signal separation and linearization is described. In some embodiments, based on an unknown distorted signal that is received, a reference component and a target component are separated from the unknown signal. Based on the separation, self-linearization is performed to compensate for nonlinear distortion and obtain an output signal that is substantially undistorted. As used herein, linearization refers to removing or compensating the nonlinearities in a signal. Self-linearization refers to calibration/linearization that does not require a training signal whose specific characteristics (such as frequency components, amplitudes, phases, data sequence, and/or modulation scheme) are already known to the module receiving the signal. In some embodiments, a persistence filter is included in an adaptive self-linearization module to generate the reference component and help performing separation.
It is assumed that the distortion signal can be expressed using a Taylor series. Even harmonics such as 304 and 306 are caused by distortion terms that are even powers of the signal (x2, x4, etc.). The even harmonics are relatively easy to remove since they are outside the fundamental frequency band of the desired signal. Odd harmonics such as 303, 305, and 307 are caused by distortion terms that are odd powers of the signal (x3, x5, etc.). It is more difficult to remove the odd harmonics since harmonic 303 lies within the fundamental frequency band of the desired signal. As will be shown in more detail below, the adaptive self-linearization module is able to approximately produce the distorted components, thereby approximately determine the ideal, undistorted signal 300. Adaptive self-linearization can be performed based on an unknown signal received while the device is operating (as opposed to using a known training signal). Further, an adaptive self-linearization module allows the device to be calibrated regardless of variations in the nonlinearity causing factors.
For example, let the received signal yn=1.001 xn +0.01 xn3, where xn is the desired undistorted component, and 0.001 xn +0.01 xn3 is the distorted component. A properly configured separation filter will produce a reference component ŷn that is approximately kxn (k being a value close to 1), and a target component ηn that is yn−kxn.
In some embodiments, the nonlinear signal extractor further includes a delay element to give the input the same amount of delay as the separation filter. In some embodiments, the nonlinear signal extractor optionally includes a band pass filter, a low pass filter, or a high pass filter. The additional filter is appropriate, for example, in applications where the frequency band of the reference component is known.
Returning to
The DSP's inputs include the reference component ŷn and a feedback error signal en that is the difference between the target component ηn and the DSP's output {circumflex over (η)}n. The DSP is configured to use ŷn as its input and ηn as its training signal to adapt its filter coefficients and drive the error signal to a predetermined level. The filter coefficients of the DSP's digital filters may be adapted using adaptive techniques including Least Mean Squares (LMS), Recursive Least Squares (RLS), or any other suitable adaptive techniques. The DSP adapts to implement a filter having a transfer function that is approximately the same as the nonlinear transfer function of the system, so that eventually the DSP's output {circumflex over (η)}n is about the same as ηn. In other words, the DSP's adapted transfer function approximately corresponds to the transfer function representing the relationship of the distorted component with respect to the undistorted component. Assuming that the distorted component at the fundamental frequency is relatively small (e.g., 0.001 xn as in the example discussed above), its effect is negligible and therefore is for all practical purposes ignored. In the above example, DSP 608 will adapt its filter parameters such that a transfer function of approximately 0.01 xn3 is obtained.
In the embodiment shown, the error signal of the DSP is expressed as:
en=ηn−WnTŶn (1)
where WnT=[wn wn−1 . . . wn−N+1 wn−N] are the nonlinear coefficients and ŶnT=[ŷn ŷn−1 . . . ŷn−N+1 ŷn−N] is the nonlinear filter's input vector.
The nonlinear coefficients are expressed using the following general form:
where
λj,n=sign(Aj,nTŶn+βj,n) (3)
Ŷn=[ŷn+Mŷn+M−1 . . . ŷn . . . ŷn . . . ŷn−M+1ŷn−M] (4)
Aj,nT=[αM,nαM−1,n . . . α0,n . . . α−M+1,nα−M,n] (5)
The coefficients have a time index n because the filter is adaptive and therefore time-varying. The nonlinear coefficients are adapted as follows:
Aj,n+1T=Aj,nT+μcj,nλj,nŶnenŷn (6)
βj,n+1=βj,n+μcj,nλj,nenŷn (7)
cj,n+1=cj,n+μ|Aj,nTŶ+βj,n|enŷn (8)
aj,n+1=aj,n+μŷnenŷn (9)
bj,n+1=bj,n+μenŷn (10)
Returning to
The persistence filter can be described using the following functions:
εn=yn−VnYn (11)
εn=yn−ŷn (12)
Vn+1=νVn+μεnYn (13)
where Yn=[yn+K yn+K−1 . . . yn . . . yn−K−1 yn−K], μ is the adaptation step size that controls the persistency factor of the filter and ν is the forgetting factor that controls the speed with which the filter adapts to changing signal dynamics.
The number of filter taps N (also referred to as the order of the filter) and the adaptive step size μ control the persistence filter's operations. A given filter order and step size combination may be particularly effective for emphasizing the received signal's linear component within a certain range of bandwidth and amplitude.
In some embodiments, the linearization process requires a large number of samples. The delay k sometimes corresponds to hundreds or even thousands of samples, resulting in delay on the order of tens or even hundreds of milliseconds. Some applications (e.g. telecommunication applications) may require the linearization process to have a lower latency.
In some embodiments, the reference component and the target component occupy separate frequency bands.
An adaptive self-linearization module such as 400 or 420 described above can be used to process the type of signal shown in
Based on reference component ŷn, DSP adapts its parameters to generate a replica of the distorted signal, ŷn. The adaptation is possible because the reference component and the distorted signal are correlated. ŷn is subtracted from the target component ηn to obtain the desired signal xn. A suitable adaptation technique such as LMS or RLS is used to adapt the DSP. Some embodiments base the adaptation on equations (1)-(10).
Referring to
In some embodiments, the offending signals causing distortion in the fundamental frequency band of the desired signal may reside in multiple frequency bands.
The persistence filter implementation shown in 702 of in
A technique for implementing a persistence filter with reduced complexity and low power consumption, without compromising convergence time is described below. The technique generates an output for every R time cycles. A reduction in the number of multipliers by a factor of R is achieved. For purposes of example, the following discussion illustrates the technique for R=4. The technique is also applicable for other reduction factor values.
A persistence filter can be described using equations (11)-(13). The fitter adapts its coefficients and drives its output to be close to the target input signal, until the error (i.e., the difference between the output and the target) meets some predetermined threshold. Based on the equations, a set of 4 linearly enhanced components at time cycles n, n+1, n+2, and n+3 are computed as follows:
ŷn=[ynyn−1 . . . yn−N]Vn (14)
ŷn+1=[yn+1yn . . . yn−N+1]Vn+1 (15)
ŷn+2=[yn+2yn+1 . . . yn−N+2]Vn+2 (16)
ŷn+3=[yn+3yn+2 . . . yn−N+3]Vn+3 (17)
Each linearly enhanced component ŷi is equivalent to an aggregate of a set of samples that is taken at time cycle i and that is scaled by the coefficients. At each sample time cycle, an update error ε is generated:
εn=yn−ŷn (18)
εn+1=yn+1−ŷn+1 (19)
εn+2=yn+2−ŷn+2 (20)
εn+3=yn+3−ŷn+3 (21)
For the sake of simplicity, assume that v=1. Based equation (13), the following coefficient updates are obtained:
Vn+1=Vn+μεnYn (22)
Vn+2=Vn+1+μεn+1Yn+1 (23)
Vn+3=Vn+2+μεn+2Yn+2 (24)
Vn+4=Vn+3+μεn+3Yn+3 (25)
Thus, Vn+4=Vn+μ(εnYn+εn+1Yn+1+εn+2Yn+2+εn+3Yn+3) (26)
Alternatively, the error of the persistence filter can be estimated at a lower rate but with greater accuracy by computing an error for every 4 sample time cycles rather than an error for every sample time cycle. Such a filter, referred to as an averaging persistence filter, can be modeled as follows:
where {circumflex over (ω)}n+3 is an aggregate of several linearly enhanced signals. In this example, {circumflex over (ω)}n+3 is an aggregate of 4 linearly enhanced signals ŷn, ŷn+1 ŷn+2, and ŷn+3. Each linearly enhanced signal can be viewed as an aggregate of a set of samples that is scaled by the set of coefficients (in other words, the linearly enhanced signal is the scalar product of an input samples vector (e.g., [yn yn−1 yn−2 . . . yn−N]) and a coefficient vector). The same set of coefficients Vn is used to scale 4 sets of input samples from different sample times. Further,
ωn+3=yn+yn+1+yn+2+yn+3 (28)
where ωn+3 is a sum of the desired target input signal over 4 consecutive samples.
An average error value is generated for every 4 input samples by taking the difference between the sum of the aggregated signals and the sum of the input signal samples:
ên+3=wn+3−ŵn+3 (29)
Accordingly, the filter coefficient vector is also updated every 4 samples:
Vn+4=Vn+μ(ên+3{tilde over (Y)}n) (30)
An averaging persistence filter that is updated every R samples and generates an output sample for every R input samples is simpler to implement than a standard persistence filter such as 702 that is updated every sample since the computing requirements of the former are reduced by a factor of R. Averaging over R samples also makes the error samples less noisy. Even though an error sample is generated every R input samples, averaging allows a larger step size μ to be used. As will be described in greater detail below, by storing extra data and using shared multipliers, the averaging persistence filter achieves power savings without sacrificing convergence speed. Although the averaging persistence filter is updated at I/R the input data rate and generates one output for every R input samples, the filter still converges at a speed that is proportional to the data rate of the input. In other words, the averaging persistence filter's speed of convergence is the same as a more complicated persistence filter such as 702) that generates an output for every input sample.
As shown in
In this example, the processor includes a delay line 758, which is configured to store 4 consecutive samples of the input signal. A shift register or other appropriate memory elements can be used to implement the delay line. The samples are summed by an adder 760. The sum is stored in another delay line 762, which can be implemented using a shift register or the like. The coefficients [ν1 . . . νN−1] are stored in memory elements 764a, 764h, etc., which may be parts of the same component or separate components. During each time cycle, selected coefficients are used to multiply with appropriate sums. Multipliers 768a, 768b, etc., are each shared by corresponding groups of 4 coefficients. The results are sent to an accumulator 766 to be aggregated.
In
In
In
In some embodiments, the averaging persistence filter is used to implement a separation block such as separation block 602 of
Adaptive self-linearization of a distorted signal using an averaging persistence filter has been described. The techniques described are generally applicable to nonlinear systems. The methods described may be implemented using filters, DSPs, as well as implemented as computer code that operates on general purpose processors.
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 of U.S. patent application Ser. No. 12/152,843, filed May 16, 2008, now U.S. Pat. No. 8,370,113, which claims priority to U.S. Provisional Patent Application No. 60/930,750, entitled “LOW-POWER AND LOW-COST ADAPTIVE SELF LINEARIZATION SYSTEM WITH FAST CONVERGENCE,” filed May 18, 2007, each of which is incorporated herein by reference for all purposes. U.S. patent application Ser. No. 12/152,843, is also a continuation in part of U.S. patent application Ser. No. 11/728,725 entitled, “ADAPTIVE SELF-LINEARIZATION WITH SEPARATION FILTER,” filed Mar. 26, 2007, now U.S. Pat. No. 7,917,337, which claims priority to U.S. Provisional Patent Application No. 60/848,425, entitled “ADAPTIVE SELF-LINEARIZATION: FULL SYSTEM OPERATION AND ARCHITECTURE” filed Sep. 29, 2006, and each of which is incorporated herein by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
4288872 | Tamburelli | Sep 1981 | A |
4412341 | Gersho et al. | Oct 1983 | A |
4701934 | Jasper | Oct 1987 | A |
4751730 | Galand et al. | Jun 1988 | A |
4763108 | Kobayashi | Aug 1988 | A |
4926472 | Batruni et al. | May 1990 | A |
4995104 | Gitlin | Feb 1991 | A |
5168459 | Hiller | Dec 1992 | A |
5239299 | Apple et al. | Aug 1993 | A |
5252930 | Blauvelt | Oct 1993 | A |
5294926 | Corcoran | Mar 1994 | A |
5390133 | Sohie | Feb 1995 | A |
5537443 | Yoshino et al. | Jul 1996 | A |
5568411 | Batruni | Oct 1996 | A |
5788635 | Wright et al. | Aug 1998 | A |
5793820 | Vander Mey | Aug 1998 | A |
5848105 | Gardner et al. | Dec 1998 | A |
5864754 | Hotto | Jan 1999 | A |
5877653 | Kim et al. | Mar 1999 | A |
5949283 | Proctor et al. | Sep 1999 | A |
6081215 | Kost et al. | Jun 2000 | A |
6246286 | Persson | Jun 2001 | B1 |
6301298 | Kuntz et al. | Oct 2001 | B1 |
6342810 | Wright et al. | Jan 2002 | B1 |
6359508 | Mucenieks | Mar 2002 | B1 |
6377116 | Mattsson et al. | Apr 2002 | B1 |
6388513 | Wright et al. | May 2002 | B1 |
6522282 | Elbornsson | Feb 2003 | B1 |
6560447 | Rahman et al. | May 2003 | B2 |
6570444 | Wright | May 2003 | B2 |
6577731 | Sugiyama | Jun 2003 | B1 |
6674335 | Ballantyne | Jan 2004 | B1 |
6765931 | Rabenko et al. | Jul 2004 | B1 |
6798843 | Wright et al. | Sep 2004 | B1 |
6819279 | Pupalaikis | Nov 2004 | B2 |
6856191 | Batruni | Feb 2005 | B2 |
6885241 | Huang et al. | Apr 2005 | B2 |
6885323 | Batruni | Apr 2005 | B2 |
6930547 | Chandrasekaran et al. | Aug 2005 | B2 |
6934341 | Sahlman | Aug 2005 | B2 |
6956517 | Baker et al. | Oct 2005 | B1 |
6999510 | Batruni | Feb 2006 | B2 |
7015752 | Saed | Mar 2006 | B2 |
7084791 | Cesura et al. | Aug 2006 | B2 |
7139327 | Vella-Coleiro et al. | Nov 2006 | B2 |
7142137 | Batruni | Nov 2006 | B2 |
7199736 | Batruni | Apr 2007 | B2 |
7253762 | Huang et al. | Aug 2007 | B2 |
7336729 | Agazzi | Feb 2008 | B2 |
7340224 | Marsili | Mar 2008 | B2 |
7342976 | McCallister | Mar 2008 | B2 |
7365662 | Marsili et al. | Apr 2008 | B2 |
7382985 | Roberts et al. | Jun 2008 | B2 |
7386409 | Mueller et al. | Jun 2008 | B2 |
7403875 | Vogel et al. | Jul 2008 | B2 |
7428262 | Zancho et al. | Sep 2008 | B2 |
7429892 | Batruni | Sep 2008 | B2 |
7466250 | Buisson | Dec 2008 | B2 |
7467172 | Druck | Dec 2008 | B2 |
7499501 | Chung et al. | Mar 2009 | B2 |
7602321 | Batruni | Oct 2009 | B2 |
7613759 | Batruni | Nov 2009 | B2 |
7660377 | Meyer | Feb 2010 | B2 |
7688235 | Batruni | Mar 2010 | B2 |
7693672 | Batruni | Apr 2010 | B2 |
7869550 | Batruni | Jan 2011 | B2 |
7903772 | Jensen | Mar 2011 | B2 |
7917337 | Batruni | Mar 2011 | B2 |
8032336 | Batruni | Oct 2011 | B2 |
8041757 | Batruni | Oct 2011 | B2 |
8077641 | Basu | Dec 2011 | B2 |
8184755 | Strait | May 2012 | B2 |
8259785 | Ooi | Sep 2012 | B2 |
8370113 | Batruni | Feb 2013 | B2 |
20040156038 | Cao | Aug 2004 | A1 |
20080270082 | Batruni | Oct 2008 | A1 |
20110314074 | Batruni | Dec 2011 | A1 |
20120029881 | Batruni | Feb 2012 | A1 |
Entry |
---|
Batruni, R.G., “Curling nonlinear distortion,” Embedded Systems Design, Embedded.com accessed on the world wide web at http://www.eetimes.com/design/embedded/4025701/Curing-nonlinear-distortion, accessed Jun. 13, 2011, 17 pages. |
Elbornsson et al., “Blind Adaptive Equalization of Mismatch Errors in a Time-Interleaved A/D Converter System,” IEEE Transactions on Circuits and Systems I: Regular Papers 51 (1):151-158, Institute of Electrical and Electronics Engineers, United States (2004). |
International Search Report and Written Opinion for International Application No. PCT/US07/20820, The International Bureau of WIPO, Geneva, Switzerland, mailed on Mar. 19, 2008. |
International Search Report and Written Opinion for International Application No. PCT/US07/20850, The International Bureau of WIPO, Geneva, Switzerland, mailed on May 5, 2008. |
International Search Report and Written Opinion for International Application No. PCT/US07/20910, The International Bureau of WIPO, Geneva, Switzerland, mailed on Sep. 16, 2008. |
International Search Report and Written Opinion for International Application No. PCT/US07/20915, The International Bureau of WIPO, Geneva, Switzerland, mailed on May 30, 2008. |
International Preliminary Report on Patentability and Written Opinion in International Patent Application No. PCT/US08/06424, The International Bureau of WIPO, Geneva, Switzerland, mailed on Nov. 24, 2009. |
International Search Report and Written Opinion for International Application No. PCT/US08/06424, The International Bureau of WIPO, Geneva, Switzerland, mailed on Sep. 8, 2008. |
International Preliminary Report on Patentability and Written Opinion in International Patent Application No. PCT/US08/06433, The International Bureau of WIPO, Geneva, Switzerland, mailed on Nov. 24, 2009. |
International Search Report and Written Opinion for International Application No. PCT/US8/069433, The International Bureau of WIPO, Geneva, Switzerland, mailed on Aug. 20, 2008. |
Office Action mailed Jul. 6, 2011, in Chinese Application No. 200780036052.2, issued Jul. 6, 2011. |
Supplementary European Search Report for EP Application No. 07838913.7-2215, European Patent Office, Munich, Germany, mailed Mar. 2, 2012. |
Office Action mailed May 27, 2010, in U.S. Appl. No. 11/728,725, Batruni, R.G., filed Mar. 26, 2007 (now U.S. Pat. No. 7,917,337). |
Office Action mailed Sep. 15, 2009, in U.S. Appl. No. 11/728,725, Batruni, R.G., filed Mar. 26, 2007 (now U.S. Pat. No. 7,917,337). |
Final Office Action mailed Apr. 29, 2009, in U.S. Appl. No. 11/728,725, Batruni, R.G., filed Mar. 26, 2007 (now U.S. Pat. No. 7,917,337). |
Office Action mailed Aug. 5, 2008, in U.S. Appl. No. 11/728,725, Batruni, R.G., filed Mar. 26, 2007 (now U.S. Pat. No. 7,917,337). |
Office Action mailed Jan. 3, 2008, in U.S. Appl. No. 11/728,725, Batruni, R.G., filed Mar. 26, 2007 (now U.S. Pat. No. 7,917,337). |
Office Action mailed Feb. 13, 2009, in U.S. Appl. No. 11/728,731, Batruni, R.G., filed Mar. 26, 2007 (now U.S. Pat. No. 7,693,672). |
Final Office Action mailed Aug. 21, 2008, in U.S. Appl. No. 11/728,731, Batruni, R.G., filed Mar. 26, 2007 (now U.S. Pat. No. 7,693,672). |
Office Action mailed Mar. 31, 2008, in U.S. Appl. No. 11/728,731, Batruni, R.G., filed Mar. 26, 2007 (now U.S. Pat. No. 7,693,672). |
Office Action mailed Oct. 27, 2008, in U.S. Appl. No. 11/904,613, Batruni, R.G., filed Sep. 27, 2007 (now U.S. Pat. No. 7,602,321). |
Office Action mailed Jun. 19, 2009, in U.S. Appl. No. 11/904,614, Batruni, R.G., filed Sep. 27, 2007 (now U.S. Pat. No. 7,688,235). |
Notice of Allowance mailed Jul. 6, 2011, in U.S. Appl. No. 12/154,157, Batruni, R.G., filed May 19, 2008 (now U.S. Pat. No. 8,032,336). |
Office Action mailed Jul. 29, 2010, in U.S. Appl. No. 12/154,157, Batruni, R.G., filed Sep. 27, 2007 (now U.S. Pat. No. 8,032,336). |
Office Action mailed Jun. 20, 2012, in U.S. Appl. No. 13/220,505, Batruni, R.G., filed Aug. 29, 2011 (now U.S. Pat. No. 8,032,336). |
Number | Date | Country | |
---|---|---|---|
20130089169 A1 | Apr 2013 | US |
Number | Date | Country | |
---|---|---|---|
60930750 | May 2007 | US | |
60848425 | Sep 2006 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12152843 | May 2008 | US |
Child | 13689294 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11728725 | Mar 2007 | US |
Child | 12152843 | US |