This document pertains generally, but not by way of limitation, to integrated circuits and communication systems, and particularly, but not by way of limitation to digital predistortion for wideband input signals.
Radiofrequency (RF) communications, such as for mobile telephony, may use an RF power amplifier (PA) circuit in an RF transmitter to produce the RF signal for transmission over the air to an RF receiver. The PA circuit may have a nonlinear gain characteristic, such as gain compression occurring at higher power output levels, which can lead to signal distortion at such higher power levels.
U.S. Pat. No. 6,342,810, for example, mentions a method of compensating for amplifier nonlinearities by using predistortion to apply an inverse model of the amplifier's transfer characteristic to an input signal of the amplifier. A goal of such predistortion is to reduce distortion due to the PA circuit gain nonlinearity.
The present inventors have recognized, among other things, that allowing a power amplifier (PA) circuit to operate including in its nonlinear (e.g., gain compression) region, such as by using predistortion compensation, can provide one or more benefits, such as to improve amplifier efficiency and performance, reduce power consumption, reduce waste heat generation, and reduce or avoid the need for active or passive cooling of the PA circuit, but that using the PA circuit with wideband input signals may present additional challenges that that can increase distortion and noise in a PA circuit.
A PA circuit operated at least in part in its nonlinear region produces distortions across a wide frequency band. For example, when a PA circuit is used to amplify a carrier-modulated input signal, the PA circuit generates distortion terms centered at the carrier frequency and at harmonics of the carrier frequency. When the input signal has a bandwidth that is less than the carrier frequency, predistortion compensation may be used to correct for distortion terms centered at the carrier frequency, while distortion terms at the carrier frequency harmonics are removed by low-pass filtering. When the input signal is a wideband or ultrawide band signal with a bandwidth similar to or larger than the carrier frequency, however, the input signal frequency band may overlap with distortion terms at one or more of the carrier frequency harmonics. This may make it may difficult to use low-pass filtering to remove harmonic distortion terms without also degrading the input signal.
Among other things, this document explains how predistortion compensation can be used to correct distortion terms at the carrier frequency and to correct distortion terms at one or more carrier frequency harmonics. For example, the input signal may be and/or be converted to a complex signal (e.g., a complex baseband signal) and predistortion compensation may operate completely or partially in complex terms. Complex operation may provide certain advantages including, for example, lower clock rates, and simpler compatibility with existing communications links. Various other advantages will be apparent to those skilled in the art.
This overview is intended to provide an overview of subject matter of the present patent application. It is not intended to provide an exclusive or exhaustive explanation of the invention. The detailed description is included to provide further information about the present patent application.
In the drawings, which are not necessarily drawn to scale, like numerals may describe similar components in different views. Like numerals having different letter suffixes may represent different instances of similar components. The drawings illustrate generally, by way of example, but not by way of limitation, various embodiments discussed in the present document.
U.S. Patent Application Ser. No. ______ (Attorney Docket No. 3867.160US1), entitled “MIXED-MODE DIGITAL PREDISTORTION,” and filed concurrently herewith is incorporated herein by reference in its entirety.
A DPD adaptation or training circuit 106 may train the DPD circuit 102, for example, as described herein. An output of the PA 112 may be sampled by an analog-to-digital converter (ADC) 114 to generate a complex baseband feedback signal {tilde over (y)}(n). In the example shown in
In the example of
In a simple example, the DUC 104 receives four channel signals, each having a bandwidth B, and each centered at a frequency B/2. The first channel signal may remain centered at B/2. The DUC 104 may translate the second channel signal to generate a translated second channel signal centered at 3B/2. The DUC 104 may translate the third channel signal to generate a translated third channel signal centered at 5B/2 and may translate the fourth channel signal to generate a translated fourth channel signal centered at 7B/2. The DUC 104 may combine the first channel signal, the translated second channel signal, the translated third channel signal, and the translated third channel signal to generate the complex baseband signal. The resulting complex baseband signal may have a bandwidth of 4B. Although this example includes four channel signals, more or fewer channel signals may be acted on by the DUC 104. Also, in some examples, the channels may be stacked in any suitable order. Further, although the channel input signals received by the DUC 104 are described as being received at the DUC 104 in complex baseband, in some examples, the DUC 104 may receive real channel signals and convert the real channel signals to the complex baseband signal output. Also, in some examples, the output of the DUC 104 may be expressed as a real signal and may be converted to complex form by a subsequent circuit component.
The example of
The signal and distortion terms show in
As shown in
Higher order distortion, when present, may behave in a similar manner. For example, 6th order distortion may manifest as 6th order distortion terms in harmonic frequency zones 0, 2, 4, and 6, with the 0th harmonic frequency zone term having the highest intensity and higher harmonic frequency zone terms having lower intensities. Also, 7th order distortion may manifest as 7th order distortion terms in harmonic frequency zones 1, 3, 5, and 7, with the 1st harmonic frequency zone term having the highest intensity and higher harmonic frequency zone terms having lower intensities.
Different PA and complex baseband signal combinations may generate distortion terms at different orders. The DPD circuit 102 may be configured to correct for some or all of the distortion terms generated by the PA 112. In some examples, the complex baseband signal {tilde over (x)}(n) may be a wideband signal having a bandwidth that is larger than the carrier frequency, for example, ten times larger than the frequency of the carrier. In some examples, the DPD circuit 102 may not consider distortion terms at harmonic frequency bands that fall outside of the bandwidth of the complex baseband signal {tilde over (x)}(n). Also, in some examples, the DPD circuit 102 may not consider distortion terms with magnitudes low enough to be ignored (e.g. below the noise floor of the output signal).
The DPD circuit 102 may be configured to generate the pre-distorted complex baseband signal {tilde over (v)}(n) considering a model of the terms generated by the PA 112. The DPD circuit 102 may utilize any model suitable for nonlinear systems. In some examples, the DPD circuit 102 may be generated based on a Volterra series model. A Volterra series model may model distortion terms generated by the PA 112 considering the complex baseband signal and memory effects. For example, a representation of the Volterra series for a band limited nonlinear system (e.g., only terms around the 1st harmonic frequency zone is given by Equation [1] below:
In Equation [1], {tilde over (x)} is the complex baseband signal and {tilde over (y)} the complex baseband output. The value {tilde over (x)}* is the complex conjugate of the complex baseband signal. In some examples, the Volterra series may be reduced to a memory polynomial, for example, as shown by Equation [2] below:
In some examples including only odd distortion terms, Equation [2] may be further reduced as indicated by Equation [3] below:
A memory effect occurs when the PA output depends at least in part on an input value (e.g., complex baseband signal value) at a previous time. In a PA circuit, memory effects can be caused by various physical phenomena such as heating at the power amplifier. For example, thermal behavior of the power amplifier 112, among other effects, may depend on the amplitude of the input |{tilde over (x)}|. Heat generated at the power amplifier may dissipate over time. Accordingly, distortion due to the temperature of the power amplifier may depend, at least in part on past values of the complex baseband signal {tilde over (x)}(n).
φk,k-2q=|{tilde over (x)}|2q({tilde over (x)}ejθ
In Equation 1, φk,k-2q is the basis function. Also, k is the order of the term modeled by the basis function and q is a variable indicating the harmonic frequency zone in which the modeled term occurs. For example, distortion of a given order k may comprise terms in harmonic frequency zones given by k−2q for values of q from zero through the floor function of k/2. The floor function, indicated by └argument┘, may return the largest integer less than or equal to its argument. TABLE 2 below illustrates basis functions for terms of order k=1, 2, 3, 4 and 5 at zones (k−2q)=0, 1, 2, 3, 4 and 5.
The polynomial approximation module 202 may comprise a basis generator circuit 204 configured to receive the complex baseband signal, indicated in
φkq=φk,k-2qe−jθ
In Equation [5], φkq is the frequency-translated basis function and ejθc is a carrier signal at the carrier frequency.
The polynomial approximation module 202 may also comprise a Finite Impulse Response (FIR) filter 205 having a number of taps 206a, 206b, 206n. Each tap 206a, 206b, 206n may correspond to a basis function. For example, each tap 206a, 206b, 206n may receive a value for a corresponding frequency-translated basis function and generate a complex baseband FIR response. The complex baseband FIR response for an example tap 206a 206b, 206n is given by Equation [6] below:
{tilde over (v)}
kq=Σm=0Mhkq(m)φkq(n−m) [6]
In Equation [6], {tilde over (v)}kq(n) is the complex baseband FIR response for a tap at a given sample n of the complex baseband signal. Also, hkq (m) may be a tap coefficient, which may be determined by the DPD adaption circuit 106, as described herein. In the example shown by Equation [6], the FIR filter 205 compensates for memory effect to a memory depth of M. For example, the tap coefficients are a function of m, where m is the number of samples prior to a given sample in. The memory depth M of the tap 206a, 206b, 206n may indicate the memory depth, or number of samples prior to the given sample n, that are considered to find the complex baseband FIR response for the given tap 206a, 206h, 206n at a given sample. Accordingly, a given tap 206a, 206b, 206n may comprise M tap coefficients hkq(m).
The complex baseband FIR response {tilde over (v)}kq(n) for each tap 206a, 206b, 206n may be summed at summer 208 to generate the pre-distorted complex baseband signal, {tilde over (v)}(n). In the example of
The pre-distorted term signal {tilde over (v)}k may be found by taking a Hilbert transform of the distorted signal xk at box 504. The Hilbert transform may be expressed as a linear sum of basis functions, as given by Equation [9] below:
Using a memory polynomial structure for predistortion, as given in general form by Equations [2] and [3], the real mode pre-distorted signal {tilde over (v)}(n) may be given by Equation [10] below:
v(n)=Σk=0KΣm=0Mhk(m)e{{tilde over (x)}(n−m)}k [10]
In some examples, Equation [10] may be generalized to the general memory polynomial or Volterra series form. For example, the generalized version of Equation [10] may be given by Equation [11] below:
(n)=Σk=0KΣm
The complex-mode equivalent of Equation [11] may be given by Equation [12] below:
{tilde over (v)}(n)=Σk=0KΣm=0Mhk(m){e{{tilde over (x)}(n−m)k}=Σk=0KΣm=0Mhk(m){tilde over (v)}k [12]
In view of Equation [9], the pre-distorted complex baseband signal {tilde over (v)}(n) over distortion of all orders k (e.g., all of the orders to be compensated by the DPD circuit 102) may be given by Equation [13] below:
The term hk(m)ak,k-2q may be set equal to hkq(m), to yield Equation [14] below:
From Equation [14], complex baseband FIR responses, as given by Equation [6], may be factored out to yield the expression of the pre-distorted complex baseband signal provided by Equation [7] above.
The complex LUT bank 600 may comprise a stage 602a, 602b, 602c, 602n for each value of q, where the values of q for a given complex LUT bank 600 are given by Equation [14] below:
In Equation [15], K is the highest order distortion term to be corrected by the complex LUT bank 600. The harmonic frequency zone to which a given stage 602a, 602b, 602c, 602n is configured may be given by Equation [16] below:
Harmonic Frequency Zone=2q+mod(K,2) [16]
For example, if the complex LUT bank 600 is to correct for odd-ordered distortion terms of the 5th order or less, then K may be equal to 5. Values for q and corresponding zones for each stage are provided below at TABLE 3. Allowable values for q may be provided by Equation [14]. Corresponding harmonic frequency zones may be provided by Equation [16].
Accordingly, a complex LUT bank 600 for the example when K=5 may include a first stage for the 1st harmonic frequency zone (e.g., centered at fc), a second stage for the 3rd harmonic frequency zone (e.g., centered at 3fc), and a third stage for the 5th harmonic frequency zone (e.g., centered at 5fc).
In some examples, the complex LUT bank 600 may be configured to correct for all distortion terms of orders meeting Equation [17] below:
mod(k,2)=mod(K,2) [17]
For example, if K is odd, then the complex LUT bank 600 may be configured to correct for terms having orders k that are less than K and also odd. Also, for example, if K is even, then the complex LUT bank 600 may be configured to correct for terms having orders k that are less than K and also even. If the DPD circuit 102 is to correct for both even and odd order distortion terms, two complex LUT banks 600 may be included. For example, a first complex LUT bank may be configured with K equal to the highest order even distortion term to be corrected. A second complex LUT bank may be configured with K equal to the highest order odd distortion term to be corrected.
Components of the stage 602c are shown in
The stage 602c may receive the complex baseband signal {tilde over (x)}(n) and may generate a harmonic frequency zone multiplier given by Equation [18] and a complex multiplier given by Equation [19]:
{tilde over (x)}(n)2q+mod(K,2) [18]
e
j(2q+mod(K,2)-1)θ
(n) [19]
For example, both the harmonic frequency zone multiplier and the complex multiplier may be based on a harmonic frequency zone exponent, which may be found according to Equation [16] above.
A magnitude module 606 may find a magnitude |{tilde over (x)}(n)| of the complex baseband signal {tilde over (x)}(n). The magnitude |{tilde over (x)}(n)| may be provided to a cascaded series of delay modules 608b, 608n, which may provide delayed magnitudes for the complex LUTs 604b, 604n. Each complex LUT 604a, 604b, 604i may receive a magnitude of the complex baseband signal. For example, a first complex LUT 604a at memory level zero may receive the magnitude |{tilde over (x)}(n)| from the magnitude module 606. A second complex LUT 604b at memory level one may receive a magnitude |{tilde over (x)}(n−1)| from the delay module 608b. The ith complex LUT 604i may receive a magnitude |{tilde over (x)}(n−M)|, where M is the memory depth. Each complex LUT 604a, 604b, 604i may select a LUT value mqK{|{tilde over (x)}((n)|} based on the received magnitude.
The LUT values, for example, may be given by Equation [20]:
As shown by Equation [18], the LUT value for a given magnitude may be a sum over the order of terms corrected by the complex LUT bank 600. LUT values for the respective complex LUTs 604a, 604b, 604i may be multiplied by the corresponding frequency zone multiplier at complex multipliers 611a, 611b, 611i. For example, the value of the frequency zone multiplier may be provided to a second set of cascaded delay modules 610a, 610b, 610i. Accordingly, each complex LUT value may be multiplied by a delayed version of the harmonic frequency zone multiplier, delayed by a number of samples equal to the memory depth of the complex LUT 604a, 604b, 604i. A summer 612 may sum the products of the complex multipliers 611a, 611b, 611i. The sum may be multiplied by the complex multiplier at 614, resulting in a harmonic frequency zone pre-distorted complex baseband signal for the harmonic frequency zone of the stage 602c, {tilde over (v)}2q+mod (K2)(n). A summer 616 for the complex LUT bank 600 may sum the harmonic frequency zone pre-distorted complex baseband signals generated by the stages 602a, 602b, 602i, resulting in the pre-distorted baseband signal {tilde over (v)}(n).
The LUT bank 600 may also be derived from the expression for the pre-distorted complex baseband signal {tilde over (v)}(n) given above in Equation [14]. For example, Equation [14] may be reorganized as given below by Equation [21]:
In Equation [21], φkq may be given by Equation [22] below:
φkq(n)=|{tilde over (x)}(n−m)2k{tilde over (x)}(n−m)2q+mod(K,2)ej(2q+mod(K,2)-1)θ
The delay in the NCO phase may be ignored, and θc(n−m) may be replaced by θc(n). This simplifications may result in a phase offset, which may be embedded into coefficients hkq(m) of Equation [21]. The pre-distorted complex baseband signal {tilde over (v)}(n) may then be expressed as set forth below in Equation [23]:
In Equation [23], mqK{|{tilde over (x)}(n)|} may be given by Equation [20] above. As described above, the value mqK{|{tilde over (x)}(n)|} may be implemented as a LUT with address |{tilde over (x)}(n)| as the address for the LUT.
{tilde over (y)}=[{tilde over (y)}
0
,{tilde over (y)}
1
, . . . ,{tilde over (y)}
N-1]H [24]
In Equation [24], the operator H indicates the Hermitian transpose. Similarly, a time alignment module 704 and DPD vector module 706 may generate a pre-distorted vector {tilde over (v)} from the pre-distorted complex baseband signal {tilde over (v)}(n). The pre-distorted complex baseband signal {tilde over (v)}(n) may be delayed by the time alignment module 704. For example, time alignment module 704 may delay the pre-distorted baseband signal {tilde over (v)}(n) by a delay time equivalent to the propagation delay of the pre-distorted baseband signal {tilde over (v)}(n) through the communication link 108, the DAC 110, PA 112, ADC 114 and communications link 116. In this way the pre-distorted vector {tilde over (v)} may align with the observed vector {tilde over (y)}. For example:
{tilde over (v)}=[{tilde over (v)}
0
,{tilde over (v)}
1
, . . . ,{tilde over (v)}
N-1]H [25]
The DPD vector module 706 may accumulate samples of the pre-distorted complex baseband signal {tilde over (v)}(n) to form the pre-distorted vector {tilde over (v)}, for example, as indicated by Equation [25] above.
A basis vector generation module 608 may receive the pre-distorted vector {tilde over (v)} and the carrier signal, given by e−jθ
ψkq=[φkq0,φkq1, . . . ,φkqM] [26]
As illustrated, elements of the complex basis vectors may be values for the complex basis functions φkq at various memory depths m. The values for the complex basis functions φkq may be found, for example, as indicated by Equation [27] below:
φkq=|{tilde over (v)}|2q({tilde over (v)}ejθ
The basis vector generation module 708 may provide the complex basis vectors ψkq to a basis matrix generation module 710, which may aggregate the complex basis vectors ψkq to generate a basis matrix Ψ, which may be given by Equation [28] below:
Ψ=[ψ11,ψ21, . . . ,ψKQ] [28]
The basis matrix Ψ and observed vector {tilde over (y)} may be provided to a linear solver module 712. The linear solver module 712 may generate a DPD coefficient vector h, for example, as illustrated by Equation [29] below:
h
h+μ(ΨHΨ+λI)−1ΨH(y−Ψh),λ>0,μ>0 [29]
In Equation [29], H indicates the Hermitian transpose operator; μ is a real scaler that may be chosen to trade off noise immunity against the adaption rate (e.g., the rate at which the DPD circuit is updated). The term A may be a regularization factor that may be chosen to improve the numerical conditioning of the calculations. The resulting coefficient matrix h may be given by Equation [30] below:
h=[h
11
,h
21
, . . . ,h
KQ] [30]
The coefficient h may include DPD tap coefficients that may be used with the polynomial approximation module 202.
In examples utilizing some or all of a complex LUT bank, such as 600, the PA circuit 100 may also include an LUT builder module 714. The LUT builder module 714 may be a component of the adaptation module 106 or an independent component.
Entries from
to
may be populated with zeros. An address/AM basis module 806 may be configured to generate an LUT address basis matrix X, given by Equation [32] below:
The dimensions of the basis matrix may be the memory depth of the LUT
In Equation [32], |{tilde over (x)}| is the LUT address index ranging over the complex baseband amplitude. A multiplier 808 may generate the inner product of the basis matrix X and the sub coefficient vector hKq(m). The result of the multiplier 808 may be used to populate the complex LUT 604a. Plot 802 shows examples for the multiplier values. Also, in some examples, LUT values may be given by Equation [33]:
The FIR filter 905 may have similar taps, but may omit taps with coefficients having
values equal to a harmonic frequency zone already corrected by a LUT node, such as 904. In this way, the FIR filter 905 may correct for one or more harmonic frequency zones, such as 906 and 908. In some examples, it may be more efficient to use LUT nodes to correct for lower harmonic frequency zones while FIR filter terms may more efficiently correct for higher harmonic frequency zones.
In some examples, where the memory depth is minimal but the nonlinear order is high, it may be more efficient to implement the DPD circuit 102 utilizing a LUT. Conversely, in some examples where the order is low, but the memory deep, the nonlinear FIR filter example as described in
In some examples, the bandwidth of nonlinear correction terms used by the DPD circuit 102 may be larger than the bandwidth of the input signal (e.g., the complex baseband signal {tilde over (x)}) and the output signal (e.g., an output signal {tilde over (y)}). This effect may be referred to as bandwidth expansion. For example, when all or part of the polynomial approximation module 202 is used, the basis function terms φkq may have a bandwidth that is an integer multiple of bandwidth of the complex baseband signal {tilde over (x)}.
φ3,1˜|x|2{tilde over (x)} [34]
The bandwidth 1005 may correspond to a basis function for a third order distortion term in the third harmonic frequency zone, given by Equation [35] below:
φ3,3˜{tilde over (x)}3 [35]
Both basis functions φ3,1 and φ3,3 are proportional to {tilde over (x)}3 and accordingly have a bandwidth that is about three times the bandwidth of the complex baseband signal. For example, both bandwidths 1004, 1006 are about 3 GHz, from −1.5 GHz to 1.5 GHz. Although the example of
Because the bandwidth of the basis function terms in the DPD circuit 102 are higher than either its input or its output, it may be necessary to increase the sample rate of (e.g., up-sample) the DPD circuit 102, for example, to avoid aliasing.
F
US
=K×F
S [36]
In Equation [37], Fus indicates the effective or up-sampled complex baseband signal sampling frequency. Fs is the original sampling frequency of the complex baseband signal {tilde over (x)} and K is the highest order term to be corrected by the DPD circuit 102. The interpolator circuit 1202 may utilize any suitable interpolation or up-sampling technique. For example, for each sample n of the complex baseband signal {tilde over (x)}, the interpolator circuit 1202 may add K copies of the sample n to generate the interpolated complex baseband signal. The DPD circuit 102 may operate on the up-sampled complex baseband signal. In this way, the DPD circuit 102 may represent the full bandwidth of the basis functions and/or other intermediate values generated in the DPD circuit 102 (e.g., without aliasing due to undersampling).
Acting on the up-sampled complex baseband signal, the DPD circuit 102 may generate an up-sampled pre-distorted complex baseband signal at the sampling rate Fus. The up-sampled pre-distorted complex baseband signal may be provided to a decimator 1204, which may down-sample the up-sampled pre-distorted complex baseband signal to generate the pre-distorted baseband signal {tilde over (v)}. In some examples, the decimator circuit 1204, may, for every sample n of the up-sampled pre-distorted baseband signal, remove K−1 samples from the up-sampled pre-distorted baseband signal. Any suitable decimation or down-sampling technique may be used, however.
For some types of distortion terms, up-sampling the complex baseband signal {tilde over (x)} and subsequently down-sampling the pre-distorted complex baseband signal {tilde over (v)} may degrade the effectiveness of predistortion. For example,
In some examples, because the real transform circuit 1402 converts the up-sampled pre-distorted baseband signal to a real expression, it may also double the bandwidth to 2KFs, introducing negative frequency content. As illustrated by the plot 1412, the real pre-distorted signal includes the negative frequency correction term 2f1-f2 of the up-sampled pre-distorted complex baseband and a positive frequency copy of the same correction term. The real pre-distorted signal may be provided to a Hilbert transform circuit 1406, which may find a Hilbert transform of the real pre-distorted signal. A Hilbert transform may return the complex or analytical equivalent of the input including positive frequency terms only. The result may be a corrected up-sampled pre-distorted signal, again at the up-sampled frequency KFs. The corrected up-sampled pre-distorted signal may be frequency translated by the carrier frequency at multiplier 1408, resulting in a corrected up-sampled pre-distorted baseband signal with the positive frequency terms translated to baseband. The corrected up-sampled pre-distorted complex baseband signal maybe provided to the decimator 1204, which may return the pre-distorted complex baseband signal.
A nonlinear path includes the interpolator circuit 1202, the DPD circuit 102 and the decimator circuit 1204, for example, as described with respect to
A linear path shown in
The arrangement shown in
In some examples, correction for higher-order harmonic frequency zones may be omitted without material degradation in the output signal. For example,
The plot 1600 illustrates that the magnitude of terms drops off in higher harmonic frequency zones. For example, the 5th order term 1606 may have a magnitude 20 dB lower than the magnitude of the 5th order term 1602 in the first harmonic frequency zone. Accordingly, in some examples, a PA circuit 100 may be configured to compensate for distortion terms of a particular order (e.g., 5th order) while omitting compensation for the highest frequency term in the order.
The modules 1702a, 1702b, 1702i may be configured to correct for less than all of the distortion terms of a particular order. For example, the modules 1702a, 1702b, 1702i may correct for at least some terms of an order higher than the highest harmonic frequency zone corrected for by the modules. For example, a DPD circuit 102 may include two modules, 1702a and 1702b. Module 1702a may correct for terms at the first harmonic frequency zone, including 5th and 3rd order terms. Module 1702b may correct for terms at the third harmonic frequency zone, including 5th and 3rd order terms. Additional modules correcting for higher harmonic frequency zones may be omitted or disabled. In this example, the 5th order term in the fifth harmonic frequency zone is not corrected. For example, the 5th order term in the fifth harmonic frequency zone may have a magnitude significantly lower than the other 5th order terms in the first and third harmonic frequency zones. The modules 1702a, 1702b, 1702i may also be configured for other frequency zone and distortion term combinations. In another example, the modules 1702a, 1702b 1702i may be configured to correct for 4th order terms in the zeroth and second harmonic frequency zones while omitting correction for the 4th order term in the fourth harmonic frequency zone. In another example, the modules 1702a, 1702b, 1702i may be configured to correct for 6th order terms in the zeroth, second, and fourth harmonic frequency zones while omitting correction for the 6th order term in the sixth harmonic frequency zone. In yet another example, the modules 1702a, 1702b, 1702i may be configured to correct for 7th order terms in the first, third and fifth harmonic frequency zones while omitting correction for the 7th order term in the seventh harmonic frequency zone.
Example 1 is a system comprising: a digital pre-distortion circuit programmed to: receive a complex baseband signal; and generate a pre-distorted signal, the generating of the pre-distorted signal comprising: applying to the complex baseband signal a first correction for an Nth order distortion of a power amplifier at an Ith harmonic frequency zone centered at about an Ith harmonic of a carrier frequency; and applying to the complex baseband signal a second correction for the Nth order distortion at a Jth harmonic frequency zone centered at about a Jth harmonic of the carrier frequency different than the Ith harmonic of a carrier frequency.
In Example 2, the subject matter of Example 1 optionally includes wherein the digital pre-distortion circuit is further programmed to: determine a value for a first complex basis function for the Nth order distortion at the Ith harmonic frequency zone based at least in part on the complex baseband signal; determine a value for a second complex basis function for the Nth order distortion at the Ith harmonic frequency zone based at least in part on the complex baseband signal; apply a first finite impulse response (FIR) filter to generate a first FIR response based at least in part on the value for the first complex basis function; and apply a second FIR filter to generate a second FIR response based at least in part on the value for the second complex basis function.
In Example 3, the subject matter of Example 2 optionally includes wherein the digital pre-distortion circuit is further programmed to before determining the value for the first complex basis function, translate the first complex basis function by the carrier frequency.
In Example 4, the subject matter of any one or more of Examples 2-3 optionally include wherein the digital pre-distortion circuit is further programmed to: receive a complex feedback signal based at least in part on an output of the power amplifier; compare the complex feedback signal to the pre-distorted signal, and determine a coefficient for the first FIR filter based at least in part on the compare of the complex feedback signal to the pre-distorted signal.
In Example 5, the subject matter of any one or more of Examples 2-4 optionally include wherein the digital pre-distortion circuit is further programmed to: receive a complex feedback signal based at least in part on an output of the power amplifier; generate a feedback matrix based at least in part on the complex feedback signal; generate an Ith harmonic frequency zone basis vector comprising a first plurality of complex basis function values, the first plurality of complex basis function values comprising the value for the first complex basis function; generate a Jth harmonic frequency zone basis vector comprising a second plurality of complex basis function values, the second plurality of complex basis function values comprising the value for the second complex basis function; generate a basis matrix comprising the first frequency zone basis vector and the second frequency zone basis vector; compare the basis matrix to the feedback matrix; and determine a coefficient for the first FIR filter based at least in part on the compare of the basis matrix to the feedback matrix.
In Example 6, the subject matter of any one or more of Examples 2-5 optionally include wherein the value for the first complex basis function is based at least in part on a first value of the complex baseband signal at a first time, wherein the digital pre-distortion circuit is further programmed to: apply a first tap of the first FIR filter to the first value of the complex baseband signal at the first time; and apply a second tap of the first FIR filter to a second value of the complex baseband signal at a second time that is before the first time.
In Example 7, the subject matter of any one or more of Examples 1-6 optionally include wherein the digital pre-distortion circuit is further programmed to: determine a first magnitude of the complex baseband signal at a first time; for the Ith harmonic frequency zone: generate an Ith harmonic frequency zone exponent based at least in part on an the Nth order distortion of the power amplifier; generate an Ith harmonic frequency zone multiplier for the first time based at least in part on the Ith harmonic frequency zone exponent; select a first look up table (LUT) value from a first tap LUT of the Ith harmonic frequency zone based at least in part on the first magnitude of the complex baseband signal; generate a first tap LUT product for the Ith harmonic frequency zone based at least in part on the first LUT value and the Ith harmonic frequency zone multiplier for the first time; and generate an Ith harmonic frequency zone output based at least in part on the first tap LUT product for the Ith harmonic frequency zone and an Ith harmonic frequency zone carrier component; for the Jth harmonic frequency zone: generate a Jth harmonic frequency zone exponent based at least in part on the Nth order distortion of the power amplifier; generate a Jth harmonic frequency zone multiplier based at least in part on the Jth harmonic frequency zone exponent; select a second LUT value from a first tap LUT of the Jth harmonic frequency zone based at least in part on the first magnitude of the complex baseband signal; generating a first tap LUT product for the Jth harmonic frequency zone based at least in part on the second LUT value and the Jth harmonic frequency zone multiplier; and generate a Jth harmonic frequency zone output based at least in part on the first tap LUT product for the Jth harmonic frequency zone and a Jth harmonic frequency zone carrier component.
In Example 8, the subject matter of Example 7 optionally includes wherein the generate of the Ith harmonic frequency zone multiplier for the first time comprises raising a first value of the complex baseband signal at the first time to the Ith harmonic frequency zone exponent.
In Example 9, the subject matter of any one or more of Examples 7-8 optionally include wherein the generate of the first tap LUT product for the Ith harmonic frequency zone comprises multiplying the first LUT value and the Ith harmonic frequency zone multiplier.
In Example 10, the subject matter of any one or more of Examples 7-9 optionally include wherein the digital pre-distortion circuit is further programmed to, for the Ith harmonic frequency zone: determine a second magnitude of the complex baseband signal at a second time before the first time; generate an Ith harmonic frequency zone multiplier for the second time based at least in part on the Ith harmonic frequency zone exponent and a second value of the complex baseband signal at the second time; select a third look up table (LUT) value from a second tap LUT of the Ith harmonic frequency zone based at least in part on the second magnitude of the complex baseband signal; and generate a second tap LUT product for the Ith harmonic frequency zone based at least in part on the third LUT value and the Ith harmonic frequency zone multiplier for the second time, wherein the Ith harmonic frequency zone output is also based at least on part on the second tap LUT product.
In Example 11, the subject matter of any one or more of Examples 7-10 optionally include wherein the digital pre-distortion circuit is further programmed to: receive a complex feedback signal based at least in part on an output of the power amplifier; compare the complex feedback signal to the pre-distorted signal; and populate the first tap LUT based at least in part on the comparing.
In Example 12, the subject matter of any one or more of Examples 1-11 optionally include wherein the digital pre-distortion circuit is further programmed to: generate an Ith harmonic frequency zone exponent for the Ith harmonic frequency zone based at least in part on the Nth order distortion of the power amplifier; generate a Ith harmonic frequency zone multiplier based at least in part on the Ith harmonic frequency zone exponent; select a LUT value from a first tap LUT of the Ith harmonic frequency zone based at least in part on a first magnitude of the complex baseband signal at a first time; generate a first tap LUT product for the Ith harmonic frequency zone based at least in part on the LUT value and the Ith harmonic frequency zone multiplier; and generate an Ith harmonic t frequency zone output based at least in part on the first tap LUT product for the Ith harmonic frequency zone and an Ith harmonic frequency zone carrier component; determine a value for a first complex basis function for the Nth order distortion of the power amplifier at a Jth harmonic frequency zone, wherein the first complex basis function is based at least in part on the complex baseband signal; and apply a first finite impulse response (FIR) filter to generate a first FIR response based at least in part on the value for the first complex basis function.
In Example 13, the subject matter of any one or more of Examples 1-12 optionally include wherein the digital pre-distortion circuit is further programmed to up-sample the complex baseband signal to generate an up-sampled complex baseband signal, wherein the applying of the first correction and the applying of the second correction is based at least in part on the up-sampled baseband signal.
In Example 14, the subject matter of any one or more of Examples 1-13 optionally include wherein the digital pre-distortion circuit is further programmed to: up-sample the complex baseband signal to an up-sampled frequency generate an up-sampled complex baseband signal, wherein the pre-distorted signal is at the up-sampled frequency; determine a real component of the pre-distorted signal; and apply a Hilbert transform to the real component of the pre-distorted signal.
In Example 15, the subject matter of any one or more of Examples 1-14 optionally include wherein the generating of the pre-distorted signal further comprises: up-sampling the complex baseband signal to generate an up-sampled complex baseband signal, wherein the applying the first correction and the applying the second correction are based at least in part on the up-sampled complex baseband signal; and applying to the complex baseband signal a third correction for a 1st order term of the power amplifier at a Kth harmonic frequency zone centered at the carrier frequency based at least in part on the complex baseband signal.
In Example 16, the subject matter of any one or more of Examples 1-15 optionally include wherein the Jth harmonic frequency zone is the highest frequency zone corrected by the digital pre-distortion circuit, and wherein N is greater than J.
Example 17 is a method comprising: receiving a complex baseband signal, and generating a pre-distorted signal, wherein the generating comprises: applying to the complex baseband signal a first correction for an Nth order distortion of a power amplifier at an Ith harmonic frequency zone centered at about an Ith harmonic of a carrier frequency; and applying to the complex baseband signal a second correction for the Nth order distortion at a Jth harmonic frequency zone centered at about a Jth harmonic of the carrier frequency different than the Ith harmonic of a carrier frequency.
In Example 18, the subject matter of Example 17 optionally includes determining a value for a first complex basis function for the Nth order distortion at the Ith harmonic frequency zone based at least in part on the complex baseband signal; determining a value for a second complex basis function for the Nth order distortion at the Ith harmonic frequency zone based at least in part on the complex baseband signal; applying a first finite impulse response (FIR) filter to generate a first FIR response based at least in part on the value for the first complex basis function; and applying a second FIR filter to generate a second FIR response based at least in part on the value for the second complex basis function.
In Example 19, the subject matter of any one or more of Examples 17-18 optionally include determining a first magnitude of the complex baseband signal at a first time; for the Ith harmonic frequency zone: generating an Ith harmonic frequency zone exponent based at least in part on an the Nth order distortion of the power amplifier; generating an Ith harmonic frequency zone multiplier for the first time based at least in part on the Ith harmonic frequency zone exponent; selecting a first look up table (LUT) value from a first tap LUT of the Ith harmonic frequency zone based at least in part on the first magnitude of the complex baseband signal; generating a first tap LUT product for the Ith harmonic frequency zone based at least in part on the first LUT value and the Ith harmonic frequency zone multiplier for the first time; and generating an Ith harmonic frequency zone output based at least in part on the first tap LUT product for the Ith harmonic frequency zone and an Ith harmonic frequency zone carrier component; for the Jth harmonic frequency zone: generating a Jth harmonic frequency zone exponent based at least in part on the Nth order distortion of the power amplifier generating a Jth harmonic frequency zone multiplier based at least in part on the Jth harmonic frequency zone exponent; selecting a second LUT value from a first tap LUT of the Jth harmonic frequency zone based at least in part on the first magnitude of the complex baseband signal; generating a first tap LUT product for the Jth harmonic frequency zone based at least in part on the second LUT value and the Jth harmonic frequency zone multiplier; and generating a Jth harmonic frequency zone output based at least in part on the first tap LUT product for the Jth harmonic frequency zone and a Jth harmonic frequency zone carrier component.
In Example 20, the subject matter of any one or more of Examples 17-19 optionally include generating an Ith harmonic frequency zone exponent for the Ith harmonic frequency zone based at least in part on the Nth order distortion of the power amplifier; generating a Ith harmonic frequency zone multiplier based at least in part on the Ith harmonic frequency zone exponent; selecting a LUT value from a first tap LUT of the Ith harmonic frequency zone based at least in part on a first magnitude of the complex baseband signal at a first time; generating a first tap LUT product for the Ith harmonic frequency zone based at least in part on the LUT value and the Ith harmonic frequency zone multiplier; and generating an Ith harmonic t frequency zone output based at least in part on the first tap LUT product for the Ith harmonic frequency zone and an Ith harmonic frequency zone carrier component; determining a value for a first complex basis function for the Nth order distortion of the power amplifier at a Jth harmonic frequency zone, wherein the first complex basis function is based at least in part on the complex baseband signal; and applying a first finite impulse response (FIR) filter to generate a first FIR response based at least in part on the value for the first complex basis function.
The above detailed description includes references to the accompanying drawings, which form a part of the detailed description. The drawings show, by way of illustration, specific embodiments in which the invention can be practiced.
These embodiments are also referred to herein as “examples.” Such examples can include elements in addition to those shown or described. However, the present inventors also contemplate examples in which only those elements shown or described are provided. Moreover, the present inventors also contemplate examples using any combination or permutation of those elements shown or described (or one or more aspects thereof), either with respect to a particular example (or one or more aspects thereof), or with respect to other examples (or one or more aspects thereof) shown or described herein.
In the event of inconsistent usages between this document and any documents so incorporated by reference, the usage in this document controls.
In this document, the terms “a” or “an” are used, as is common in patent documents, to include one or more than one, independent of any other instances or usages of “at least one” or “one or more.” In this document, the term “or” is used to refer to a nonexclusive or, such that “A or B” includes “A but not B,” “B but not A,” and “A and B,” unless otherwise indicated. In this document, the terms “including” and “in which” are used as the plain-English equivalents of the respective terms “comprising” and “wherein.” Also, in the following claims, the terms “including” and “comprising” are open-ended, that is, a system, device, article, composition, formulation, or process that includes elements in addition to those listed after such a term in a claim are still deemed to fall within the scope of that claim. Moreover, in the following claims, the terms “first,” “second,” and “third,” etc. are used merely as labels, and are not intended to impose numerical requirements on their objects.
Geometric terms, such as “parallel”, “perpendicular”, “round”, or “square”, are not intended to require absolute mathematical precision, unless the context indicates otherwise. Instead, such geometric terms allow for variations due to manufacturing or equivalent functions. For example, if an element is described as “round” or “generally round,” a component that is not precisely circular (e.g., one that is slightly oblong or is a many-sided polygon) is still encompassed by this description.
The term “circuit” can include a dedicated hardware circuit, a general-purpose microprocessor, digital signal processor, or other processor circuit, and may be structurally configured from a general purpose circuit to a specialized circuit such as using firmware or software.
Any one or more of the techniques (e.g., methodologies) discussed herein may be performed on a machine. In various embodiments, the machine may operate as a standalone device or may be connected (e.g., networked) to other machines. In a networked deployment, the machine may operate in the capacity of a server machine, a client machine, or both in server-client network environments. In an example, the machine may act as a peer machine in peer-to-peer (P2P) (or other distributed) network environment. The machine may be a personal computer (PC), a tablet PC, a set-top box (STB), a personal digital assistant (PDA), a mobile telephone, a web appliance, a network router, switch or bridge, or any machine capable of executing instructions (sequential or otherwise) that specify actions to be taken by that machine. Further, while only a single machine is illustrated, the term “machine” shall also be taken to include any collection of machines that individually or jointly execute a set (or multiple sets) of instructions to perform any one or more of the methodologies discussed herein, such as cloud computing, software as a service (SaaS), other computer cluster configurations.
Examples, as described herein, may include, or may operate by, logic or a number of components, or mechanisms. Circuit sets are a collection of circuits implemented in tangible entities that include hardware (e.g., simple circuits, gates, logic, etc.). Circuit set membership may be flexible over time and underlying hardware variability. Circuit sets include members that may, alone or in combination, perform specified operations when operating. In an example, hardware of the circuit set may be immutably designed to carry out a specific operation (e.g., hardwired). In an example, the hardware of the circuit set may include variably connected physical components (e.g., execution units, transistors, simple circuits, etc.) including a computer readable medium physically modified (e.g., magnetically, electrically, moveable placement of invariant massed particles, etc.) to encode instructions of the specific operation. In connecting the physical components, the underlying electrical properties of a hardware constituent are changed, for example, from an insulator to a conductor or vice versa. The instructions can enable embedded hardware (e.g., the execution units or a loading mechanism) to create members of the circuit set in hardware via the variable connections to carry out portions of the specific operation when in operation. Accordingly, the computer readable medium is communicatively coupled to the other components of the circuit set member when the device is operating. In an example, any of the physical components may be used in more than one member of more than one circuit set. For example, under operation, execution units may be used in a first circuit of a first circuit set at one point in time and reused by a second circuit in the first circuit set, or by a third circuit in a second circuit set at a different time.
Particular implementations of the systems and methods described herein may involve use of a machine (e.g., computer system) that may include a hardware processor (e.g., a central processing unit (CPU), a graphics processing unit (GPU), a hardware processor core, or any combination thereof), a main memory and a static memory, some or all of which may communicate with each other via an interlink (e.g., bus). The machine may further include a display unit, an alphanumeric input device (e.g., a keyboard), and a user interface (UI) navigation device (e.g., a mouse). In an example, the display unit, input device and UI navigation device may be a touch screen display. The machine may additionally include a storage device (e.g., drive unit), a signal generation device (e.g., a speaker), a network interface device, and one or more sensors, such as a global positioning system (GPS) sensor, compass, accelerometer, or other sensor. The machine may include an output controller, such as a serial (e.g., universal serial bus (USB), parallel, or other wired or wireless (e.g., infrared (IR), near field communication (NFC), etc.) connection to communicate or control one or more peripheral devices (e.g., a printer, card reader, etc.).
The storage device may include a machine readable medium on which is stored one or more sets of data structures or instructions (e.g., software) embodying or utilized by any one or more of the techniques or functions described herein. The instructions may also reside, completely or at least partially, within the main memory, within static memory, or within the hardware processor during execution thereof by the machine. In an example, one or any combination of the hardware processor, the main memory, the static memory, or the storage device may constitute machine readable media.
While the machine readable medium can include a single medium, the term “machine readable medium” may include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) configured to store the one or more instructions.
The term “machine readable medium” may include any medium that is capable of storing, encoding, or carrying instructions for execution by the machine and that cause the machine to perform any one or more of the techniques of the present disclosure, or that is capable of storing, encoding or carrying data structures used by or associated with such instructions. Non-limiting machine readable medium examples may include solid-state memories, and optical and magnetic media. In an example, a massed machine readable medium comprises a machine readable medium with a plurality of particles having invariant (e.g., rest) mass. Accordingly, massed machine-readable media are not transitory propagating signals. Specific examples of massed machine readable media may include: non-volatile memory, such as semiconductor memory devices (e.g., Electrically Programmable Read-Only Memory (EPROM), Electrically Erasable Programmable Read-Only Memory (EEPROM)) and flash memory devices; magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks.
The instructions may further be transmitted or received over a communications network using a transmission medium via the network interface device utilizing any one of a number of transfer protocols (e.g., frame relay, internet protocol (IP), transmission control protocol (TCP), user datagram protocol (UDP), hypertext transfer protocol (HTTP), etc.). Example communication networks may include a local area network (LAN), a wide area network (WAN), a packet data network (e.g., the Internet), mobile telephone networks (e.g., cellular networks), Plain Old Telephone (POTS) networks, and wireless data networks (e.g., Institute of Electrical and Electronics Engineers (IEEE) 802.11 family of standards known as Wi-Fi®, IEEE 802.16 family of standards known as WiMax®), IEEE 802.15.4 family of standards, peer-to-peer (P2P) networks, among others. In an example, the network interface device may include one or more physical jacks (e.g., Ethernet, coaxial, or phone jacks) or one or more antennas to connect to the communications network. In an example, the network interface device may include a plurality of antennas to wirelessly communicate using at least one of single-input multiple-output (SIMO), multiple-input multiple-output (MIMO), or multiple-input single-output (MISO) techniques. The term “transmission medium” shall be taken to include any intangible medium that is capable of storing, encoding or carrying instructions for execution by the machine, and includes digital or analog communications signals or other intangible medium to facilitate communication of such software.
Method examples described herein can be machine or computer-implemented at least in part. Some examples can include a computer-readable medium or machine-readable medium encoded with instructions operable to configure an electronic device to perform methods as described in the above examples. An implementation of such methods can include code, such as microcode, assembly language code, a higher-level language code, or the like. Such code can include computer readable instructions for performing various methods. The code may form portions of computer program products. Further, in an example, the code can be tangibly stored on one or more volatile, non-transitory, or non-volatile tangible computer-readable media, such as during execution or at other times. Examples of these tangible computer-readable media can include, but are not limited to, hard disks, removable magnetic disks, removable optical disks (e.g., compact disks and digital video disks), magnetic cassettes, memory cards or sticks, random access memories (RAMs), read only memories (ROMs), and the like.
The above description is intended to be illustrative, and not restrictive. For example, the above-described examples (or one or more aspects thereof) may be used in combination with each other. Other embodiments can be used, such as by one of ordinary skill in the art upon reviewing the above description. The Abstract is provided to comply with 37 C.F.R. §1.72(b), to allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. Also, in the above Detailed Description, various features may be grouped together to streamline the disclosure. This should not be interpreted as intending that an unclaimed disclosed feature is essential to any claim. Rather, inventive subject matter may lie in less than all features of a particular disclosed embodiment. Thus, the following claims are hereby incorporated into the Detailed Description as examples or embodiments, with each claim standing on its own as a separate embodiment, and it is contemplated that such embodiments can be combined with each other in various combinations or permutations. The scope of the invention should be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled.