Various embodiments relate generally to methods and devices for digital predistortion systems for dual-band power amplifiers.
Power Amplifiers (PAs) are used in a number of radio frequency (RF) transmission systems in order to amplify RF signals prior to wireless transmission, and accordingly may be essential for driving transmit antennas. However, PAs may suffer from non-linearity, which may in particular be accentuated when combined with complex modulation schemes that exhibit high Peak-to-Average Power Ratios (PAPR). Among other various solutions, Digital Predistortion (DPD) has been proposed as an effective and cost-efficient technique to counteract PA non-linearity. Such DPD systems may attempt to model the inverse of the PA response and apply this inverse model to input signals to the PA, which may in effect largely negate the non-linearity of the PA in order to produce a relatively linear overall response.
In the drawings, like reference characters generally refer to the same parts throughout the different views. The drawings are not necessarily to scale, emphasis instead generally being placed upon illustrating the principles of the invention. In the following description, various embodiments of the invention are described with reference to the following drawings, in which:
The following detailed description refers to the accompanying drawings that show, by way of illustration, specific details and embodiments in which the invention may be practiced.
The word “exemplary” is used herein to mean “serving as an example, instance, or illustration”. Any embodiment or design described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other embodiments or designs.
The words “plural” and “multiple” in the description and the claims expressly refer to a quantity greater than one. Accordingly, any phrases explicitly invoking the aforementioned words (e.g. “a plurality of [objects]”, “multiple [objects]”) referring to a quantity of objects expressly refers more than one of the said objects. The terms “group (of)”, “set [of]”, “collection (of)”, “series (of)”, “sequence (of)”, “grouping (of)”, etc., and the like in the description and in the claims, if any, refer to a quantity equal to or greater than one, i.e. one or more.
It is appreciated that any vector and/or matrix notation utilized herein is exemplary in nature and is employed solely for purposes of explanation. Accordingly, it is understood that the approaches detailed in this disclosure are not limited to being implemented solely using vectors and/or matrices, and that the associated processes and computations may be equivalently performed with respect to sets, sequences, groups, etc., of data, observations, information, signals, etc. Furthermore, it is appreciated that references to a “vector” may refer to a vector of any size or orientation, e.g. including a 1×1 vector (e.g. a scalar), a 1×M vector (e.g. a row vector), and an M×1 vector (e.g. a column vector). Similarly, it is appreciated that references to a “matrix” may refer to matrix of any size or orientation, e.g. including a 1×1 matrix (e.g. a scalar), a 1×M matrix (e.g. a row vector), and an M×1 matrix (e.g. a column vector).
A “circuit” as user herein is understood as any kind of logic-implementing entity, which may include special-purpose hardware or a processor executing software. A circuit may thus be an analog circuit, digital circuit, mixed-signal circuit, logic circuit, processor, microprocessor, Central Processing Unit (CPU), Graphics Processing Unit (GPU), Digital Signal Processor (DSP), Field Programmable Gate Array (FPGA), integrated circuit, Application Specific Integrated Circuit (ASIC), etc., or any combination thereof. Any other kind of implementation of the respective functions which will be described below in further detail may also be understood as a “circuit”. It is understood that any two (or more) of the circuits detailed herein may be realized as a single circuit with substantially equivalent functionality, and conversely that any single circuit detailed herein may be realized as two (or more) separate circuits with substantially equivalent functionality. Additionally, references to a “circuit” may refer to two or more circuits that collectively form a single circuit.
As used herein, “memory” may be understood as a non-transitory computer-readable medium in which data or information can be stored for retrieval. References to “memory” included herein may thus be understood as referring to volatile or non-volatile memory, including random access memory (RAM), read-only memory (ROM), flash memory, solid-state storage, magnetic tape, hard disk drive, optical drive, etc., or any combination thereof. Furthermore, it is appreciated that registers, shift registers, processor registers, data buffers, etc., are also embraced herein by the term memory. It is appreciated that a single component referred to as “memory” or “a memory” may be composed of more than one different type of memory, and thus may refer to a collective component comprising one or more types of memory. It is readily understood that any single memory component may be separated into multiple collectively equivalent memory components, and vice versa. Furthermore, while memory may be depicted as separate from one or more other components (such as in the drawings), it is understood that memory may be integrated within another component, such as on a common integrated chip.
The term “base station” used in reference to an access point of a mobile communication network may be understood as a macro base station, micro base station, Node B, evolved NodeBs (eNB), Home eNodeB, Remote Radio Head (RRH), relay point, etc. As used herein, a “cell” in the context of telecommunications may be understood as a sector served by a base station. Accordingly, a cell may be a set of geographically co-located antennas that correspond to a particular sectorization of a base station. A base station may thus serve one or more cells (or sectors), where each cell is characterized by a distinct communication channel. Furthermore, the term “cell” may be utilized to refer to any of a macrocell, microcell, femtocell, picocell, etc.
For purposes of this disclosure, radio communication technologies may be classified as one of a Short Range radio communication technology, Metropolitan Area System radio communication technology, or Cellular Wide Area radio communication technology. Short Range radio communication technologies include Bluetooth, WLAN (e.g. according to any IEEE 802.11 standard), and other similar radio communication technologies. Metropolitan Area System radio communication technologies include Worldwide Interoperability for Microwave Access (WiMax) (e.g. according to an IEEE 802.16 radio communication standard, e.g. WiMax fixed or WiMax mobile) and other similar radio communication technologies. Cellular Wide Area radio communication technologies include GSM, UMTS, LTE, LTE-Advanced (LTE-A), CDMA, WCDMA, LTE-A, General Packet Radio Service (GPRS), Enhanced Data Rates for GSM Evolution (EDGE), High Speed Packet Access (HSPA), HSPA Plus (HSPA+), and other similar radio communication technologies. Cellular Wide Area radio communication technologies may be generally referred to herein as “cellular” communication technologies. It is understood that exemplary scenarios detailed herein are demonstrative in nature, and accordingly may be similarly applied to various other mobile communication technologies, both existing and not yet formulated, particularly in cases where such mobile communication technologies share similar features as disclosed regarding the following examples.
The term “network” as utilized herein, e.g. in reference to a communication network such as a mobile communication network, encompasses both an access section of a network (e.g. a radio access network (RAN) section) and a core section of a network (e.g. a core network section). The term “radio idle mode” or “radio idle state” used herein in reference to a mobile terminal refers to a radio control state in which the mobile terminal is not allocated at least one dedicated communication channel of a mobile communication network. The term “radio connected mode” or “radio connected state” used in reference to a mobile terminal refers to a radio control state in which the mobile terminal is allocated at least one dedicated uplink communication channel of a mobile communication network. Unless explicitly specified, the term “transmit” encompasses both direct and indirect transmission. Similarly, the term “receive” encompasses both direct and indirect reception unless explicitly specified.
Digital Predistortion (DPD) may be applied to an input signal of a Power Amplifier (PA) in order to “predistort” the input signal to compensate for nonlinearities of the PA. DPD may be thus used to linearize PAs found in various wireless transmission systems, and may be particularly applicable for implementation in base stations, remote radio heads (RRHs), and point-to-point backhaul links in cellular communication networks. DPD systems may rely on models of the PA response in order to provide a basis for generating the appropriate “predistorion” to apply to PA input signals.
PAs may conventionally be modeled using polynomials or splines (piece-wise polynomial functions) to characterize the non-linear response of various PAs. Polynomial-based DPD systems thus receive PA input signals and apply the polynomial functions of the model to PA input signals in order to produce the predistorted DPD outputs. Specifically, polynomial DPD systems may evaluate each of a set of complex polynomials given one or more input samples, apply the complex polynomial outputs as a complex gain factor to a function of the input samples, and sum the resulting samples to generate the DPD output. Assuming a suitable selection of complex modeling polynomials, the predistorted DPD outputs may represent the “inverse” of the actual nonlinearities of the PA, which may be substantially “canceled” when the DPD outputs are applied as input to the PA.
Polynomial DPD systems may either depend only on the current input sample, i.e. a memoryless polynomial model, or may depend the current input sample in addition to one or more past input samples, i.e. a polynomial model with memory. Such polynomial models may present the DPD model as the sum of a plurality of terms, where each term is the product of a function of the current and/or previous inputs and a complex polynomial that is a function of the magnitude of the current or a previous input. Accordingly, a DPD polynomial model may evaluate each of a set of complex polynomials at one or more input samples, apply each polynomial output as a gain factor to a function of one or more input samples, and sum the resulting products to produce the overall DPD output.
A DPD polynomial model may thus need to evaluate each of the set of complex polynomials in order to produce each DPD output sample. In order to reduce computational burden, polynomial DPD systems may utilize lookup tables (LUTs) to generate the DPD outputs. As opposed to directly evaluating each complex polynomial, DPD LUT systems may evaluate each of the complex polynomials over a wide domain of input samples and store the resulting outputs in a separate LUT, thus producing a separate LUT to represent each complex polynomial. DPD LUT systems may thus evaluate each LUT according to the received input samples and produce an LUT output value for each LUT. DPD LUT systems may then produce the DPD output by applying the LUT output values as a set of complex gains to the corresponding function of input samples, thus avoiding direct evaluation of each complex polynomial. Regardless, polynomial DPD models may suffer from accuracy issues, in particular for PA responses that exhibit discontinuities and other response features that are ill-suited for low-order polynomial modeling. Accordingly, polynomial DPD systems for such PAs may require high order polynomials that may be exceedingly complex and lead to numerical stability problems when estimating the polynomial coefficients.
In recognition of these deficiencies of polynomial DPD systems, an alternative solution may be realized by relying on direct estimation and adaptation of LUT coefficients, i.e. developing the LUT coefficients for each of the LUTs with an adaptation algorithm that adjusts the LUT coefficients for each LUT using feedback from the PA output. Accordingly, such direct LUT estimation may be based on actual PA input and output signals, and may be better suited to estimation of complex PA response in addition to being capable of capturing variations in the PA response over time, such as deviations caused by age, temperature, or other dynamic parameters.
As previously indicated, DPD circuit 104 may utilize adaptable LUTs that dynamically adjust the LUT coefficients for each LUT based on feedback from the output of PA 108. Accordingly, feedback chain 110 may capture the analog, radio-frequency output of PA 108 and perform demodulation to recover a baseband (or intermediate frequency) and subsequent analog-to-digital conversion (ADC, with an ADC circuit) to produce digital, baseband samples representative of the output of PA 108. Feedback processing circuit 116 may receive these samples and perform gain adjustment and timing and phase alignment relative to the DPD input samples, which feedback processing circuit 116 may receive from the input node to DPD circuit 104. Feedback processing circuit 116 may provide the resulting feedback information to DPD adaptation circuit 114 and AGC circuit 112. AGC circuit 112 may apply the feedback information to adjust the gain control signal supplied to gain circuit 102 in accordance with automatic gain control procedures.
DPD adaptation circuit 114 may be responsible for performing adaptation of the LUT coefficients at DPD circuit 104, and accordingly may utilize the feedback information provided by feedback processing circuit 116 in order to evaluate the output of PA 108. Accordingly, DPD adaptation circuit 114 may attempt to correct for any inaccuracies in the LUT coefficients that are observable through nonlinearities detected in the output of PA 108. As further detailed below, DPD adaptation circuit 114 may employ an adaptation scheme such as Least Squares (LS) based on either indirect or direct learning to adapt the LUT coefficients of DPD circuit 104. DPD circuit 104 may thus dynamically adapt the LUT coefficients over time based on observations of the output of PA 108, and accordingly may be able to develop a highly-accurate model of PA 108 in order to subsequently yield linear performance at PA 108 with the assistance of the applied predistortion.
In particular for a single-band PA, DPD circuit 104 employ one-dimensional (1D) LUTs to produce the predistorted output samples that are subsequently supplied to PA 108. As previously indicated above regarding memory models, DPD circuit 104 may realize one or more LUTs according to a memory depth M, where each of the LUTs produces an LUT output based on the current or a past input sample. DPD circuit 104 may then produce the DPD output by applying each LUT output as a complex gain to the corresponding LUT function of input samples and summing the resulting products to obtain the DPD output. For the 1D LUT case, DPD circuit 104 may receive a sequence of complex baseband samples, calculate the magnitude of each complex baseband sample, and, for each of the corresponding 1D LUTs, map the magnitude value for the appropriate baseband sample to the 1D LUT to produce a complex-valued LUT output. DPD circuit 104 may then apply each LUT output as a complex gain factor to the corresponding function of baseband samples and sum the resulting samples to obtain the DPD output.
Each of the 1D LUTs may be defined as a sequence of evenly-spaced LUT coefficients positioned along a one-dimensional axis at multiples of an LUT spacing δ. DPD circuit 104 may then determine each LUT output by mapping an input magnitude to the evenly-spaced grid of LUT coefficients and applying one or more proximate LUT coefficients to generate the LUT output. Each LUT coefficient may be a complex number, and accordingly DPD circuit 104 may produce a complex baseband DPD output sample from each complex baseband input samples received from gain circuit 102.
As each LUT coefficient is located at a discrete point (some multiple of δ) on the one-dimensional axis of the corresponding 1D LUT, input magnitudes may probabilistically not fall exactly at an LUT coefficient. Accordingly, DPD circuit 104 may apply linear interpolation to calculate the LUT outputs for each LUT, where each resulting LUT output may be a linear combination of e.g. the two closest LUT coefficients to the respective input magnitude (i.e. the two LUT coefficients located on each side of the input magnitude if viewed on a 1D grid). As each 1D LUT is limited to some finite size N (i.e. the number of LUT coefficients), high input values may fall outside of the domain of LUT coefficients. In recognition thereof, DPD circuit 104 may apply linear extrapolation for input values that fall outside of the LUT coefficient domain.
DPD circuit 104 may represent each 1D LUT as a function ƒ
where φi are the LUT coefficients. The LUT coefficients φi for each LUT may be complex, thus producing complex LUT outputs ƒ
Accordingly, DPD circuit 104 may apply basis functions Λg(i,N)(x) as defined in Equations (1)-(7) to produce a complex LUT output ƒ
The 1D LUT implementation detailed above for DPD circuit 104 may be suitable for single-band PAs, i.e. PAs that target a single transmission frequency band for amplification. However, the recent introduction of “dual-band” PAs (and accompanying RF chains) that service two transmission bands that are substantially separated in spectrum may pose substantial problems in DPD design. As the targeted bands may be separated by up to e.g. 400 MHz in spectrum, a candidate DPD system may need to accurately apply predistortion over a massive range of frequencies. Effective solutions that rely on a single DPD system may be exceptionally complex and expensive.
In recognition thereof, a dual-band DPD system targeting a dual-band PA may be realized that applies predistortion based on modeling the PA response as a non-linear function of two complex baseband variables, i.e. one each per targeted band of the PA. As introduced above regarding 1D LUTs, conventional schemes may utilize polynomial- or spline-based models for estimating the PA response and subsequently applying predistortion to input signals. The accuracy and complexity issues noted above regarding these solutions may similarly lead to sub-optimal LUT coefficients.
Accordingly, a dual-band DPD system may rely on 2D LUTs that produce a complex output given the magnitude of a complex baseband input sample of each band as the two LUT inputs.
As shown in
As shown in
The outputs y1 and y2 of DPD circuits 304a and 304b may remain “split”, i.e. one output (y1) for the first band and another output (y2) for the second band. As PA 312 receives a single waveform, DPD system 300 may combine y1 and y2 into a single signal, thus including both predistorted outputs y1 and y2 into a single output for provision to PA 312. Accordingly, DPD system 300 may employ interpolation and up-conversion circuits 306a and 306b to up-sample and modulate both y1 and y2 to the appropriate intermediate frequencies (dependent on the spectral placement of the first and second bands) and combine the resulting upsampled signals with combining circuit 308. Combining circuit 308 may supply the combined signal to TX chain 310 for DAC and radio frequency modulation, which may subsequently provide the resulting signal to PA 312 for amplification. Accordingly, DPD system 300 may separately apply predistortion to both bands (as a function of the signals of both bands) and may operate DPD circuits 304a and 304b at substantially reduced sampling rates compared to a wideband DPD solution.
In order to provide AGC and LUT coefficient adaptation, feedback chain 314 may thus demodulate, digitize, and separate the first and second frequency band signals from the output of PA 312 and provide the resulting split digital baseband samples to feedback process circuit 316 for gain adjustment and timing and phase alignment. Feedback process circuit 316 may provide the digital baseband PA outputs zi to AGC circuit 320 for gain control at gain circuits 302 on subsequent inputs to DPD system 300.
Feedback process circuit 316 may also provide zi to DPD adaptation circuits 318a and 318b, which may be responsible for LUT coefficient adaptation of each of the respective 2D LUTs of DPD circuits 304a and 304b. As will be further detailed, DPD adaptation circuits 318a and 318b may apply LS estimation using direct or indirect learning to adapt the LUT coefficients of DPD circuits 304a and 304b based on the observed digital baseband PA outputs zi.
DPD circuits 304a and 304b may thus employ 2D LUTs to generate y1 and y2 based on |x1| and |x2|, where each of the respective 2D LUTs of DPD circuits 304a and 304b may each utilize distinct LUT coefficients. The 2D LUT function of each 2D LUT may be generalized as ƒ
The 2D LUTs of DPD circuits 304a and 304b may apply interpolation and extrapolation to produce output ƒ
The interpolation region shown in
Such bilinear interpolation is demonstrated in
Equations (8)-(10) may be re-written to show the contribution of each LUT point to ƒ
LUT coefficient point (iδ1, jδ2, φi,j) will also provide a contribution to ƒ
The total contribution of (iδ1, jδ2, φi,j) to ƒ
Γ0,0(x1,x2)=Λ0(x1)Λ0(x2) (16)
with Λ0(x) as defined above in Equation (3).
Accordingly, the bilinear interpolation function Γ0,0(x1, x2) is the product of the 1D linear interpolation functions for the 1D LUT case. The contour and 3D mesh plots for bilinear interpolation function Γ0,0(x1, x2) are shown in
The LUT function defined for 0≤x1≤(N1−1)δ1 and 0≤x2≤(N2−1)δ2 (the bilinear interpolation region) may thus be defined as follows:
2D LUT output function ƒ
which holds for each inner rectangular region iδ1≤x1≤(i+1)δ1 and jδ2≤x2≤(j+1)δ2 over all 0≤i≤≤N1−2 and 0≤j≤N2−2.
Accordingly, ƒ
Specifically, the overall LUT function ƒ
where
Γi,j(x1,x2)=Λi(x1)Λj(x2) (20)
with Λi(x) and g(i,N) defined in Equations (2) to (7).
The 2D LUT basis functions Γi,j (x1, x2) of ƒ
The application of 2D LUT output ƒ
Accordingly, the interpolation and extrapolation capabilities ƒ
Each of DPD circuits 304a and 304b may thus receive complex baseband samples x1 and x2 and respectively produce complex outputs y1 and y2 based on the interpolation and extrapolation provided by the LUT output function ƒ
Wideband input x(n) may thus be expressed as the sum of the first and second band signals baseband x1(n) and x2(n) as follows
x(n)=x1(n)ejθ
where the baseband signals x1(n) and x2(n) are modulated by two carrier with respective frequencies θ1/(2πTs) and θ2/(2πTs) with sampling period Ts.
Wideband GMP output yGMP(n) may thus be expressed as yGMP(n)=yGMP,1(n)ejθ
The final dual-band GMP model may thus be given as
The dual-band GMP model of Equation (23) may be adapted to two-dimensional polynomial functions to allow odd polynomial powers and separate model parameters for each band as
The final 2D LUT dual-band DPD outputs y1 and y2 of DPD circuits 304a and 304b may then be obtained by replacing the 2D polynomial functions of Equation (24) with the 2D LUT output function ƒ
where each LUT ƒ
ƒ
where
DPD circuits 304a and 304 may thus generate DPD outputs y1 and y2 where each respective DPD output sample yGMLUT-2D,1(n) and yGMLUT-2D,2(n) is the product of a plurality of terms. As defined in Equation (25), each of the terms may be expressed as the product of a function of current and/or past input samples of x1 and/or x2 and a 2D LUT output, where each 2D LUT output is a function of the magnitude of the current and/or past input samples of x1 and x2. DPD outputs y1 and y2 may thus include the cross-terms expressed in the double-sum operators. DPD circuits 304a and 304b may be structurally embodied as either hardware or software according to the arithmetic logic associated with a particular DPD output generation scheme, such as e.g. according to the logic defined in Equation (25). Accordingly, DPD circuits 304a and 304b may thus be realized as a processor configured to execute program code corresponding to the arithmetic logic (e.g. of Equation (25), such as in a software-implemented Digital Front End (DFE) or “soft DFE”), an FPGA configured according to the arithmetic logic of Equation (25), or an ASIC configured according to the arithmetic logic of Equation (25). DPD circuits 304a and 304b may additionally include a respective memory component configured to store the respective 2D LUT coefficient vectors
As previously indicated, DPD adaptation circuits 318a and 318b may be configured to dynamically adapt the LUT coefficients φi,j of
Both direct and indirect learning may utilize an identical DPD mathematical reference model, where a single-band output yi of DPD circuit 304a or 304b may be expressed as
yi(n)=
where
The basis and coefficient vectors for the complete 2D LUT DPD model in (25) for the first band may thus be given as
g1,0(x1(n),x2(n))=(n))=x1(n)
g1,G−1(x1(n),x2(n))=x1(n−M)x2*(n−M)x2(n−M−lend)·
where the basis and coefficients vectors for the second band may be analogously derived.
Output vectors
For indirect learning, DPD adaptation circuits 318a and 318b may adapt the LUT coefficients
where
DPD adaptation circuits 318a and 318b may alternatively apply direct learning to adapt φi,j for each of the 2D LUTs.
DPD adaptation circuits 318a and 318b may update the LUT coefficients φi,j for each 2D LUT by estimating
Defining GPA as the gain of PA 312, the error vectors at each band may be written as
ēi=
Let θi=ƒi/(2πT), where ƒi are the band center frequency offsets and T is the sampling period. Accordingly, if ƒ2−ƒ1 is sufficiently larger than the signal bandwidth, minimizing the squared error of the combined signal is equivalent to minimizing the squared error of the individual bands, i.e.
The (
Fi(G1(
The optimization problem may then be stated as follows:
As detailed in Y. Ma, Y. Yamao, Y. Akaiwa and K. Ishibashi “Wideband digital predistortion using spectral extrapolation of band-limited feedback signal”, IEEE Trans. Circuits Syst. I, Reg. Papers, vol. 61, no. 7, pp. 2088-2097 2014, Fi may be approximated as the linear functions FiGPA
Equation (36) may be restated as two independent minimization problems as
Defining
where 0≤μ≤1 is a constant and sub-index k is the iteration index.
DPD adaptation circuits 318a and 318b may perform the inverse operation using the pseudo-inverse function with given tolerance in order to control the rank of the basis matrix and the number of eigenvectors used in the solution. DPD adaptation circuits 318a and 318b may additionally apply QR LS and sparse matrix techniques, which are well-established for wide-band cases and available for analogous application in the dual-band case detailed herein.
Accordingly, DPD adaptation circuits 318a and 318b may receive the time-aligned and gain-scaled PA output samples zi(n) and adapt the LUT coefficients
Returning to
As the LUT coefficients are directly estimated (by DPD adaptation circuits 318a and 318b) from input samples xi, some coefficients may be based on more “observations”, i.e. input signals falling within the influenced region of the coefficient, than others. As previously detailed, each LUT coefficient point (iδ1, jδ2, φi,j) may provide a contribution to ƒ
Given the relatively high PAPRs for the individual band signals, the distribution of input points (x1, x2) may be clustered towards the lower-left corner of the 2D LUT as shown in
Accordingly, the 2D LUT coefficients used for extrapolation (i.e. in the outer and exterior regions of the 2D LUT) may be markedly less reliable, which may lead to adaptation stability issues if DPD system 300 exclusively utilizes the extrapolation strategy expressed in Equation (19). In order to address such issues, DPD system 300 may utilize a flexible interpolation/extrapolation (I/E) boundary as opposed to the rectangular I/E boundary shown in
This problem may be stated as follows: given a 2D signal with a known Probability Distribution Function (PDF) and a grid of points (iδ1, jδ2), define a set of interpolation/extrapolation basis functions located at a subset of these points. Each location may be selected so that the value of the PDF is high enough to ensure the associated DPD coefficient has sufficient accuracy. Additionally, it should be possible to generate a flat horizontal surface over the entire region x1≥0, x2≥0 as a linear combination of the basis functions, thus ensuring that the 2D LUT is able to implement a constant linear gain without error (see Equation (18) for the interpolation case). At each point in the domain, ƒ
By selectively assigning each LUT coefficient point a basis function Γi,j, i,j ϵ {0, 1, 2}, DPD system 300 may individually assign each “region” of the 2D LUT as an interpolation or extrapolation region, i.e. bilinear interpolation (interpolation in both the x1 and x2 directions), mixed interpolation/extrapolation (extrapolation in only one of the x1 or x2 direction), or bilinear extrapolation (extrapolation in both the x1 and x2 directions). While the following description may detail implementing this selective I/E region assignment in DPD circuits 304a and 304b, DPD adaptation circuits 318a and 318b may alternatively be configured to realize this functionality without departing from the scope of the present disclosure.
DPD circuits 304a and 304b may dynamically perform this I/E region assignment based on the number of observed input points out of the total number of observed input points that fall within each region. In other words, DPD circuits 304a and 304b may assign regions with a high number (or percentage) of the total observations as interpolation regions while assigning regions with a lower number (or percentage) of the total observations as extrapolation regions, such as by comparing the number of observed input samples in each region to a normalized threshold and assigning each region to interpolation or extrapolation based on whether the number of observed input samples exceeds or falls below the threshold. DPD circuits 304a and 304b may additionally correct for “bubble” regions, i.e. where an extrapolation region is assigned between two interpolation regions in a given row or column. Such may be mathematically expressed as follows:
Accordingly, DPD circuits 304a and 304b may create a continuous interpolation region (absent of “bubble” regions) dependent on the number of input signal points observed for each region of each 2D LUT. The mechanism detailed above may ensure that the interpolation region is an orthogonal convex hull.
As there is a basis function at the corner of each interpolation region, the locations of the basis functions will be (iδ1, jδ2) where i ϵ {0 . . . imax} and j ϵ {0 . . . jmax(i)} with imax=c(0)+1, jmax(i)=r(i−1)+1 and assuming r(−1)=0. Such can be seen the placement of basis functions in
This flexible extrapolation scheme can be expressed as overall LUT function ƒ
The basis functions of Equation (39) are shown in the examples of
The particular assignment of Γx,y as detailed above for the outer basis functions of the interpolation region are essential in order to generate the linear gain case, in which ƒ
The flexible extrapolation assignment shown above is not unique, and other basis assignment schemes may be produced to similarly satisfy the linear gain condition to generate a horizontal flat surface over ƒ
Accordingly, DPD system 300 may utilize the flexible extrapolation scheme detailed above to ensure that interpolation is performed with high-reliability LUT coefficients for each 2D LUT, where coefficient reliability is determined by examining the relative distribution of observed input points within the domain of the 2D LUT. DPD system 300 may assign one or more “internal” regions of each 2D LUT as extrapolation regions if DPD system 300 determines that the associated LUT coefficients of the internal regions have low reliability, i.e. have a low distribution of observed input points (x1, x2) which may lead to inaccurate coefficient adaptation and estimation. DPD system 300 may assign these regions as extrapolation regions by assigning extrapolation basis functions as expressed above in Equation (39), thus causing ƒ
DPD system 300 may be configured to dynamically adapt the flexible extrapolation assignment during runtime, and accordingly may re-assign a given region Rij as interpolation or extrapolation regions based on the comparison of Mij to the normalized threshold Thr. Accordingly, DPD system 300 may adapt the flexible extrapolation assignment based on the actual observed distribution of x1 and x2 over time.
Such may be particularly advantageous when considering the effects of gain circuits 302 and AGC circuit 320. As previously detailed regarding
In terms of LUT initialization, DPD circuits 304a and 304b may be configured to utilize initial LUT coefficients prior to the start of runtime operations. For simplicity, DPD circuits 304a and 304b may be initialized by setting the LUT coefficients of the “main tap” (i.e. the DPD term in which the LUT multiplies the input associated with the DPD delay) for a constant gain, i.e. by assigning all LUT coefficients of the respective 2D LUT to an arbitrary constant value, e.g. 1, and the LUT coefficients of all the other LUTs to zero. Alternatively, DPD circuits 304a and 304b may be initialized to other predefined LUT coefficients, such as LUT coefficients based on a polynomial or other DPD model. DPD adaptation circuits 318a and 318b may then subsequently adapt the LUT coefficients upon start of runtime as detailed above. Alternatively, DPD adaptation circuits 318a and 318b may execute a calibration or learning stage in order to initialize the LUT coefficients of DPD circuits 304a and 304b.
The 2D LUT extrapolation scheme in addition to the flexible extrapolation scheme detailed herein may be applied to various other technologies other than DPD, in particular for computer and digital graphic applications. Furthermore, while detailed above regarding dual-band DPD the 2D LUT schemes may additionally be applicable to single-band or wideband DPD applications that utilize respective real and imaginary signal parts as two-dimensional inputs to a 2D LUT. While particularly applicable for radio transmitters such as base stations, RRHs, and point-to-point backhaul links, the 2D LUT DPD system may be readily applied for predistortion in any system to linearize the response of an electrical component.
Additionally, the 2D LUTs depicted in
The individual components of DPD system 300 (DPD circuits 304a and 304b, interpolation and upconversion circuits 306a and 306b, combining circuit 308, feedback chain 314, feedback process circuit 316, and DPD adaptation circuits 318a and 318b) may be realized as hardware circuits or software circuits. The detailed functionality may thus be structurally embodied as dedicated hardware, such as one or more discrete ASICs or FPGAs configured to implement the functionality of one or more of the individual components of DPD system 300. The detailed functionality may alternatively be structurally embodied as dedicated software, such as one or more processors configured to retrieve program code (defined as arithmetic, logical, control, and input/output (I/O) operations) that when executed by the one or more processors directs the processor to implement the functionality of one or more individual components of DPD system 300. Alternatively, a mixture of such dedicated hardware and software components may be utilized to realize the individual components of DPD system 300.
Although
In one or more further exemplary aspects of the disclosure, one or more of the features described above in reference to
The terms “user equipment”, “I/E”, “mobile terminal”, “user terminal”, etc., may apply to any wireless communication device, including cellular phones, tablets, laptops, personal computers, wearables, multimedia playback devices, consumer/home appliances, vehicles, etc., and any number of additional electronic devices capable of wireless communications.
While the above descriptions and connected figures may depict electronic device components as separate elements, skilled persons will appreciate the various possibilities to combine or integrate discrete elements into a single element. Such may include combining two or more circuits for form a single circuit, mounting two or more circuits onto a common chip or chassis to form an integrated element, executing discrete software components on a common processor core, etc. Conversely, skilled persons will recognize the possibility to separate a single element into two or more discrete elements, such as splitting a single circuit into two or more separate circuits, separating a chip or chassis into discrete elements originally provided thereon, separating a software component into two or more sections and executing each on a separate processor core, etc. Given the well-established parallels between hardware logic and software logic, skilled persons will recognize the ability to realize the logic-implementing components detailed herein as either hardware logic as software logic. Furthermore, skilled persons will recognize the possibility to translate hardware logic into functionally equivalent logic embodied as program code for execution on a processor and conversely translate software logic into functionally equivalent digital hardware logic embodied as a digital logic circuit.
It is appreciated that implementations of methods detailed herein are demonstrative in nature, and are thus understood as capable of being implemented in a corresponding device. Likewise, it is appreciated that implementations of devices detailed herein are understood as capable of being implemented as a corresponding method. It is thus understood that a device corresponding to a method detailed herein may include a one or more components configured to perform each aspect of the related method.
The following examples pertain to further aspects of the disclosure:
Example 1 is a method of preprocessing amplifier input signals, the method including mapping a first dimension input and a second dimension input to a first subset of a plurality of lookup table coefficients of a two-dimensional (2D) lookup table, wherein the first dimension input and the second dimension input each represent a signal level of one or more input signals, extrapolating from the first subset of the plurality of lookup table coefficients to generate a lookup table output, and applying the lookup table output to the one or more input signals to generate a predistorted input signal for an amplifier.
In Example 2, the subject matter of Example 1 can optionally include wherein the first dimension input represents a real part of a first complex sample of a first input signal of the one or more input signals and the second dimension input represents an imaginary part of the first complex sample of the first input signal.
In Example 3, the subject matter of Example 1 can optionally include wherein the first dimension input represents a signal level of a first input signal of the one or more input signals and the second dimension input represents a signal level of a second input signal of the one or more input signals.
In Example 4, the subject matter of any one of Examples 1 to 3 can optionally include wherein applying the lookup table output to the one or more input signals to generate the predistorted input signal for the amplifier includes identifying one or more input samples of the one or more input signals, evaluating a function of the one or more input samples to obtain a function output, and generating the predistorted input signal as the product of the function output and the lookup table output.
In Example 5, the subject matter of any one of Examples 1 to 3 can optionally further include generating one or more additional lookup table outputs from one or more additional 2D lookup tables.
In Example 6, the subject matter of Example 5 can optionally include wherein applying the lookup table output to the one or more input signals to generate the predistorted input signal for the amplifier includes identifying one or more input samples of the one or more input signals, evaluating one or more functions of the one or more input samples to obtain one or more function outputs, and determining one or more intermediate products by multiplying each of the one or more function outputs by a respective lookup table output of the one or more additional lookup table outputs, and generating the predistorted input signal for the amplifier as a sum of the one or more intermediate products.
In Example 7, the subject matter of Example 6 can optionally include wherein the first dimension input and the second dimension input correspond to a current input sample of the one or more input signals, and wherein at least one of the one or more input samples is a past input sample of the one or more input signals.
In Example 8, the subject matter of Example 6 can optionally include wherein the first dimension input and the second dimension input correspond to a current input sample of the one or more input signals, and wherein each of the one or more input samples occur at the same point in time as the current input sample.
In Example 9, the subject matter of any one of Examples 6 to 8 can optionally include wherein each of the one or more input samples are samples of a first input signal of the one or more input signals.
In Example 10, the subject matter of any one of Examples 6 to 8 can optionally include wherein the one or more input samples include input samples of a first input signal and a second input signal of the one or more input signals.
In Example 11, the subject matter of Example 10 can optionally include wherein the amplifier is a dual-band amplifier, and wherein the first input signal corresponds to a first band of the dual-band amplifier and the second input signal corresponds to a second band of the dual-band amplifier.
In Example 12, the subject matter of Example 1 can optionally further include calculating a magnitude of a sample of a first input signal of the one or more input signals to obtain the first dimension input, and calculating a magnitude of a sample of a second input signal of the one or more input signals to obtain the second dimension input.
In Example 13, the subject matter of Example 1 can optionally further include calculating a squared magnitude of a first input signal of the one or more input signals to obtain the first dimension input, and calculating a squared magnitude of a second input signal of the one or more input signals to obtain the second dimension input.
In Example 14, the subject matter of any one of Examples 1 to 13 can optionally further include amplifying the predistorted input signal with the amplifier.
In Example 15, the subject matter of any one of Examples 1 to 14 can optionally further include modulating the predistorted input signal with a radio frequency signal to obtain a modulated predistorted input signal, and amplifying the modulated predistorted input signal with the amplifier.
In Example 16, the subject matter of any one of Examples 1 to 15 can optionally further include mapping an additional first dimension input and an additional second dimension input to a second subset of the plurality of lookup table coefficients of the 2D lookup table, interpolating from the second subset of the plurality of lookup table coefficients to generate an additional lookup table output, and applying the additional lookup table output to the one or more input signals to generate an additional predistorted input signal for the amplifier.
In Example 17, the subject matter of any one of Examples 1 to 15 can optionally further include mapping the first dimension input and the second dimension input to one or more additional 2D lookup tables, interpolating or extrapolating with the one or more additional 2D lookup tables to generate one or more additional lookup table outputs, wherein applying the lookup table output to the one or more input signals to generate the predistorted input signal for the amplifier includes combining the lookup table output and the one or more additional lookup table outputs to generate the predistorted input signal.
In Example 18, the subject matter of Example 17 can optionally include wherein combining the lookup table output and the one or more additional lookup table outputs to generate the predistorted input signal includes identifying one or more samples of the one or more input signals, evaluating one or more functions of the one or more samples to obtain one or more function outputs, determining one or more intermediate products by multiplying each of the one or more function outputs by one of the lookup table output or a respective lookup table output of the one or more lookup table outputs, and generating the predistorted input signal by summing the one or more intermediate products.
In Example 19, the subject matter of any one of Examples 1 to 18 can optionally further include monitoring an output signal of the amplifier, and adapting the plurality of lookup table coefficients based on the output signal of the amplifier.
In Example 20, the subject matter of any one of Examples 1 to 19 can optionally further include assigning each of a plurality of predefined regions of the 2D lookup table as an interpolation region or an extrapolation region, and reassigning at least one of the plurality of predefined regions of the 2D lookup table.
In Example 21, the subject matter of Example 20 can optionally include wherein a point formed by the first dimension input and the second dimension input falls within an extrapolation region.
In Example 22, the subject matter of Example 20 or 21 can optionally include wherein reassigning the at least one of the plurality of predefined regions of the 2D lookup table includes monitoring a plurality of pairs of first dimension inputs and second dimension inputs received for the 2D lookup table, and reassigning a first region of the plurality of predefined regions as an interpolation region if more than a predefined quantity of the plurality of pairs fall within the first region and reassigning the first region as an extrapolation region if less than the predefined quantity of the plurality of pairs fall within the first region.
Example 23 is a digital predistortion circuit configured to perform the method of any one of Examples 1 to 22.
Example 24 is a non-transitory computer readable medium storing instructions that when executed by a processor direct the processor to perform the method of any one of Examples 1 to 22.
Example 25 is a method of preprocessing amplifier input signals, the method including mapping a first dimension input and a second dimension input to one or more first two-dimensional (2D) lookup tables, wherein the first dimension input represents a signal level of a first input signal and the second dimension input represents a signal level of a second input signal, mapping the first dimension input and the second dimension input to one or more second 2D lookup tables, extrapolating from lookup table coefficients of a first 2D lookup table of the one or more first 2D lookup tables to obtain a first intermediate signal, interpolating or extrapolating with lookup table coefficients of the one or more second 2D lookup tables to obtain a second intermediate signal, and combining the first intermediate signal and the second intermediate signal to obtain a predistorted input signal for an amplifier.
In Example 26, the subject matter of Example 25 can optionally include wherein interpolating or extrapolating with lookup table coefficients of the one or more second 2D lookup tables to obtain a second intermediate signal includes interpolating with a first set of lookup table coefficients of a first 2D lookup table of the one or more second 2D lookup tables to obtain a first lookup table output, extrapolating with a second set of lookup table coefficients of a second 2D lookup table of the one or more second 2D lookup tables to obtain a second lookup table output, and combining the first lookup table output and the second lookup table output to obtain the second intermediate signal.
In Example 27, the subject matter of Example 25 or 26 can optionally include wherein extrapolating from the lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables to obtain the first intermediate signal includes selecting a first set of lookup table coefficients from the at least one of the one or more first 2D lookup tables according to the first dimension input and the second dimension input, and extrapolating from the first set of lookup table coefficients.
In Example 28, the subject matter of any one of Examples 25 to 27 can optionally further include mapping an additional first dimension input and an additional second dimension input to the at least one of the one or more first 2D lookup tables, and interpolating between lookup table coefficients of the at least one of the one or more first 2D lookup tables to obtain an additional first intermediate signal.
In Example 29, the subject matter of any one of Examples 25 to 28 can optionally include wherein extrapolating from the lookup table coefficients of the at least one of the one or more first 2D lookup tables to obtain the first intermediate signal includes extrapolating from the lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables to obtain a first lookup table output, interpolating between lookup table coefficients of a second 2D lookup table of the one or more first 2D lookup tables to obtain a second lookup table output, and combining the first lookup table output and the second lookup table output to obtain the first intermediate signal.
In Example 30, the subject matter of any one of Examples 25 to 29 can optionally include wherein interpolating or extrapolating with the lookup table coefficients of the one or more second 2D lookup tables to obtain the second intermediate signal includes selecting a first set of lookup table coefficients from a first 2D lookup table of the one or more second 2D lookup tables according to the first dimension input and the second dimension input, and interpolating between the first set of lookup table coefficients.
In Example 31, the subject matter of any one of Examples 25 to 29 can optionally include wherein interpolating or extrapolating with the lookup table coefficients of the one or more second 2D lookup tables to obtain the second intermediate signal includes selecting a second set of lookup table coefficients from a first 2D lookup table of the one or more second 2D lookup tables according to the first dimension input and the second dimension input, and extrapolating from the second set of lookup table coefficients.
In Example 32, the subject matter of any one of Examples 25 to 31 can optionally include wherein the first dimension input is a magnitude of a complex sample of the first input signal and the second dimension input is a magnitude of a complex sample of the second input signal.
In Example 33, the subject matter of any one of Examples 25 to 32 can optionally further include calculating a magnitude of a complex sample of the first input signal to obtain the first dimension input and calculating a magnitude of a complex sample of the second input signal to obtain the second dimension input.
In Example 34, the subject matter of any one of Examples 25 to 31 can optionally further include calculating a squared magnitude of a complex sample of the first input signal to obtain the first dimension input and calculating a squared magnitude of a complex sample of the second input signal to obtain the second dimension input.
In Example 35, the subject matter of Example 25 can optionally include wherein extrapolating from the lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables to obtain the first intermediate signal includes extrapolating from lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables, and interpolating or extrapolating with lookup table coefficients of one or more additional 2D lookup tables of the one or more first 2D lookup tables.
In Example 36, the subject matter of Example 25 can optionally include wherein extrapolating from the lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables to obtain the first intermediate signal includes generating a lookup table output from each of the one or more first 2D lookup tables to obtain one or more lookup table outputs, identifying one or more samples of the first input signal and the second input signal, evaluating one or more functions of the one or more samples to obtain one or more function outputs, determining one or more intermediate products by multiplying each of the one or more function outputs by a respective lookup table output of the one or more lookup table outputs, generating the first intermediate signal as a sum of the one or more intermediate products.
In Example 37, the subject matter of Example 25 can optionally include wherein interpolating or extrapolating with the lookup table coefficients of the one or more second 2D lookup tables to obtain the second intermediate signal includes generating a lookup table output from each of the one or more second 2D lookup tables to obtain one or more lookup table outputs, identifying one or more samples of the first input signal and the second input signal, evaluating one or more functions of the one or more samples to obtain one or more function outputs, determining one or more intermediate products by multiplying each of the one or more function outputs by a respective lookup table output of the one or more lookup table outputs, generating the second intermediate signal as a sum of the one or more intermediate products.
In Example 38, the subject matter of any one of Examples 25 to 37 can optionally include wherein combining the first intermediate signal and the second intermediate signal to obtain a predistorted input signal for the amplifier includes upsampling and upconverting the first intermediate signal and the second intermediate signal, and summing the first intermediate signal and the second intermediate signal to obtain the predistorted input signal.
In Example 39, the subject matter of Example 38 can optionally further include amplifying the predistorted input signal with the amplifier.
In Example 40, the subject matter of any one of Examples 25 to 38 can optionally further include modulating the predistorted input signal with a radio carrier signal to obtain a modulated predistorted input signal, and amplifying the modulated predistorted input signal with the amplifier.
In Example 41, the subject matter of any one of Examples 25 to 40 can optionally include wherein the amplifier is a dual-band radio amplifier and the first input signal corresponds to a first band of the amplifier and the second input signal corresponds to a second band of the amplifier.
In Example 42, the subject matter of any one of Examples 25 to 41 can optionally further include monitoring an output signal of the amplifier, and adapting one or more lookup table coefficients of the one or more first 2D lookup tables or the one or more second 2D lookup tables based on the output signal of the amplifier.
In Example 43, the subject matter of any one of Examples 25 to 42 can optionally further include assigning each of a plurality of regions of a first 2D lookup table of the one or more first 2D lookup tables as an interpolation region or an extrapolation region, and reassigning at least one of the plurality of predefined regions of the first 2D lookup table.
In Example 44, the subject matter of Example 43 can optionally include wherein reassigning at least one of the plurality of predefined regions of the first 2D lookup table includes monitoring a plurality of pairs of first dimension inputs and second dimension inputs for the first 2D lookup table, and reassigning a first region of the plurality of predefined regions of the first 2D lookup table as an interpolation region if more than a predefined quantity of the plurality of pairs fall within the first region and reassigning the first region as an extrapolation region if less than the predefined quantity of the plurality of pairs fall within the first region.
Example 45 is a digital predistortion circuit configured to perform the method of any one of Examples 25 to 44.
Example 46 is a non-transitory computer readable medium storing instructions that when executed by a processor direct the processor to perform the method of any one of Examples 25 to 44.
Example 47 is a signal processing circuit arrangement including a preamplifier circuit configured to map a first dimension input and a second dimension input to a first subset of a plurality of lookup table coefficients of a two-dimensional (2D) lookup table, wherein the first dimension input and the second dimension input each represent a signal level of one or more input signals, extrapolate from the first subset of the plurality of lookup table coefficients to generate a lookup table output, and apply the lookup table output to the one or more input signals to generate a predistorted input signal for an amplifier.
In Example 48, the subject matter of Example 47 can optionally further include the amplifier.
In Example 49, the subject matter of Example 48 can optionally further include a mixing circuit configured to modulate the predistorted input signal with a radio frequency signal to obtain a modulated predistorted input signal, wherein the amplifier configured is configured to amplify the predistorted input signal.
In Example 50, the subject matter of any one of Examples 47 to 49 can optionally include wherein the first dimension input represents a real part of a first complex sample of a first input signal of the one or more input signals and the second dimension input represents an imaginary part of the first complex sample of the first input signal.
In Example 51, the subject matter of any one of Examples 47 to 49 can optionally include wherein the first dimension input represents a signal level of a first input signal of the one or more input signals and the second dimension input represents a signal level of a second input signal of the one or more input signals.
In Example 52, the subject matter of any one of Examples 47 to 51 can optionally include wherein the preamplifier circuit is configured to apply the lookup table output to the one or more input signals to generate the predistorted input signal for the amplifier by identifying one or more input samples of the one or more input signals, evaluating a function of the one or more input samples to obtain a function output, and generating the predistorted input signal as the product of the function output and the lookup table output.
In Example 53, the subject matter of any one of Examples 47 to 51 can optionally include wherein the preamplifier circuit is further configured to generate one or more additional lookup table outputs from one or more additional 2D lookup tables.
In Example 54, the subject matter of Example 53 can optionally include wherein the preamplifier circuit is configured to apply the lookup table output to the one or more input signals to generate the predistorted input signal for the amplifier by identifying one or more input samples of the one or more input signals, evaluating one or more functions of the one or more input samples to obtain one or more function outputs, and determining one or more intermediate products by multiplying each of the one or more function outputs by a respective lookup table output of the one or more additional lookup table outputs, and generating the predistorted input signal for the amplifier as a sum of the one or more intermediate products.
In Example 55, the subject matter of Example 54 can optionally include wherein the first dimension input and the second dimension input correspond to a current input sample of the one or more input signals, and wherein at least one of the one or more input samples is a past input sample of the one or more input signals.
In Example 56, the subject matter of Example 54 can optionally include wherein the first dimension input and the second dimension input correspond to a current input sample of the one or more input signals, and wherein each of the one or more input samples occur at the same point in time as the current input sample.
In Example 57, the subject matter of any one of Examples 54 to 56 can optionally include wherein each of the one or more input samples are samples of a first input signal of the one or more input signals.
In Example 58, the subject matter of any one of Examples 54 to 56 can optionally include wherein the one or more input samples include input samples of a first input signal of the one or more input signals and a second input signal of the one or more input signals.
In Example 59, the subject matter of Example 58 can optionally include wherein the amplifier is a dual-band amplifier, and wherein the first input signal corresponds to a first band of the dual-band amplifier and the second input signal corresponds to a second band of the dual-band amplifier.
In Example 60, the subject matter of any one of Examples 47 to 49 can optionally include wherein the preamplifier circuit is further configured to calculate a magnitude of a sample of a first input signal of the one or more input signals to obtain the first dimension input, and calculate a magnitude of a sample of a second input signal of the one or more input signals to obtain the second dimension input.
In Example 61, the subject matter of any one of Examples 47 to 49 can optionally include wherein the preamplifier circuit is further configured to calculate a squared magnitude of a sample of a first input signal of the one or more input signals to obtain the first dimension input, and calculate a squared magnitude of a sample of a second input signal of the one or more input signals to obtain the second dimension input.
In Example 62, the subject matter of any one of Examples 47 to 61 can optionally include wherein the preamplifier circuit is further configured to map an additional first dimension input and an additional second dimension input to a second subset of the plurality of lookup table coefficients of the 2D lookup table, interpolate from the second subset of the plurality of lookup table coefficients to generate an additional lookup table output, and apply the additional lookup table output to the one or more input signals to generate an additional predistorted input signal for the amplifier.
In Example 63, the subject matter of any one of Examples 47 to 62 can optionally include wherein the preamplifier circuit is further configured to map the first dimension input and the second dimension input to one or more additional 2D lookup tables, interpolate or extrapolate with the one or more additional 2D lookup tables to generate one or more additional lookup table outputs, wherein the preamplifier circuit is configured to apply the lookup table output to the one or more input signals to generate the predistorted input signal for the amplifier by combining the lookup table output and the one or more additional lookup table outputs to generate the predistorted input signal.
In Example 64, the subject matter of Example 63 can optionally include wherein the preamplifier circuit is configured to combine the lookup table output and the one or more additional lookup table outputs to generate the predistorted input signal by identifying one or more samples of the one or more input signals, evaluating one or more functions of the one or more samples to obtain one or more function outputs, determining one or more intermediate products by multiplying each of the one or more function outputs by one of the lookup table output or a respective lookup table output of the one or more lookup table outputs, and generating the predistorted input signal by summing the one or more intermediate products.
In Example 65, the subject matter of any one of Examples 47 to 64 can optionally further include a feedback circuit configured to monitor an output signal of the amplifier, and an adaptation circuit configured to adapt the plurality of lookup table coefficients based on the output signal of the amplifier.
In Example 66, the subject matter of Example 65 can optionally include wherein the preamplifier circuit is further configured to assign each of a plurality of predefined regions of the 2D lookup table as an interpolation region or an extrapolation region, and reassign at least one of the plurality of predefined regions of the 2D lookup table.
In Example 67, the subject matter of Example 66 can optionally include wherein a point formed by the first dimension input and the second dimension input falls within an extrapolation region.
In Example 68, the subject matter of Example 66 or 67 can optionally include wherein the preamplifier circuit is configured to reassign the at least one of the plurality of predefined regions of the 2D lookup table by monitoring a plurality of pairs of first dimension inputs and second dimension inputs received for the 2D lookup table, and reassigning a first region of the plurality of predefined regions as an interpolation region if more than a predefined quantity of the plurality of pairs fall within the first region and reassigning the first region as an extrapolation region if less than the predefined quantity of the plurality of pairs fall within the first region.
Example 69 is a radio communication device including the signal processing circuit arrangement of any one of Examples 47 to 68.
Example 70 is a signal processing circuit arrangement including a first DPD circuit configured to map a first dimension input and a second dimension input to one or more first two-dimensional (2D) lookup tables, wherein the first dimension input represents a signal level of a first input signal and the second dimension input represents a signal level of a second input signal, and to extrapolate from lookup table coefficients of a first 2D lookup table of the one or more first 2D lookup tables to obtain a first intermediate signal, a second DPD circuit configured to map the first dimension input and the second dimension input to one or more second 2D lookup tables, and to interpolate or extrapolate with lookup table coefficients of the one or more second 2D lookup tables to obtain a second intermediate signal, and a combination circuit configured to combine the first intermediate signal and the second intermediate signal to obtain a predistorted input signal for an amplifier.
In Example 71, the subject matter of Example 70 can optionally further include the amplifier.
In Example 72, the subject matter of Example 71 can optionally further include a mixing circuit configured to modulate the predistorted input signal with a radio frequency signal to obtain a modulated predistorted input signal, wherein the amplifier is configured to amplify the modulated predistorted input signal.
In Example 73, the subject matter of any one of Examples 70 to 72 can optionally include wherein the combination circuit is configured to combine the first intermediate signal and the second intermediate signal to obtain the predistorted input signal by upsampling and upconverting the first intermediate signal and the second intermediate signal, and summing the first intermediate signal and the second intermediate signal to obtain the predistorted input signal.
In Example 74, the subject matter of any one of Examples 70 to 73 can optionally include wherein the second DPD circuit is configured to interpolate or extrapolate with the lookup table coefficients of the one or more second 2D lookup tables to obtain the second intermediate signal by interpolating with a first set of lookup table coefficients of a first 2D lookup table of the one or more second 2D lookup tables to obtain a first lookup table output, extrapolating with a second set of lookup table coefficients of a second 2D lookup table of the one or more second 2D lookup tables to obtain a second lookup table output, and combining the first lookup table output and the second lookup table output to obtain the second intermediate signal.
In Example 75, the subject matter of any one of Examples 70 to 74 can optionally include wherein the first DPD circuit is configured to extrapolate from the lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables to obtain the first intermediate signal by selecting a first set of lookup table coefficients from the first 2D lookup table of the one or more first 2D lookup tables according to the first dimension input and the second dimension input, and extrapolating from the first set of lookup table coefficients.
In Example 76, the subject matter of any one of Examples 70 to 75, wherein the first DPD circuit is further configured to map an additional first dimension input and an additional second dimension input to the first 2D lookup table of the one or more first 2D lookup tables, and interpolate between lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables to obtain an additional first intermediate signal.
In Example 77, the subject matter of any one of Examples 70 to 76 can optionally include wherein the first DPD circuit is configured to extrapolate from the lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables to obtain the first intermediate signal by extrapolating from the lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup table to obtain a first lookup table output, interpolating between lookup table coefficients of a second 2D lookup output of the one or more first 2D lookup tables to obtain a second lookup table output, and combining the first lookup table output and the second lookup table output to obtain the first intermediate signal.
In Example 78, the subject matter of any one of Examples 70 to 77 can optionally include wherein the second DPD circuit is configured to interpolate or extrapolate with the lookup table coefficients of the one or more second 2D lookup tables to obtain the second intermediate signal by selecting a first set of lookup table coefficients from a first 2D lookup table of the one or more second 2D lookup tables according to the first dimension input and the second dimension input, and interpolating between the first set of lookup table coefficients.
In Example 79, the subject matter of any one of Examples 70 to 77 can optionally include wherein the second DPD circuit is configured to interpolate or extrapolate with the lookup table coefficients of the one or more second 2D lookup tables to obtain the second intermediate signal by selecting a second set of lookup table coefficients from a first 2D lookup table of the one or more second 2D lookup tables according to the first dimension input and the second dimension input, and extrapolating from the second set of lookup table coefficients.
In Example 80, the subject matter of any one of Examples 70 to 79 can optionally include wherein the first dimension input is a magnitude of a complex sample of the first input signal and the second dimension input is a magnitude of a complex sample of the second input signal.
In Example 81, the subject matter of any one of Examples 70 to 79 can optionally include wherein the first dimension input is a squared magnitude of a complex sample of the first input signal and the second dimension input is a squared magnitude of a complex sample of the second input signal.
In Example 82, the subject matter of Example 70 or 71 can optionally include wherein the first DPD circuit is configured to extrapolate from the lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables to obtain the first intermediate signal by extrapolating from lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables, and interpolating or extrapolating with lookup table coefficients of one or more additional 2D lookup tables of the one or more first 2D lookup tables.
In Example 83, the subject matter of Example 70 or 71 can optionally include wherein the first DPD circuit is configured to extrapolate from the lookup table coefficients of the first 2D lookup table of the one or more first 2D lookup tables to obtain the first intermediate signal by generating a lookup table output from each of the one or more first 2D lookup tables to obtain one or more lookup table outputs, identifying one or more samples of the first input signal and the second input signal, evaluating one or more functions of the one or more samples to obtain one or more function outputs, determining one or more intermediate products by multiplying each of the one or more function outputs by a respective lookup table output of the one or more lookup table outputs, generating the first intermediate signal as a sum of the one or more intermediate products.
In Example 84, the subject matter of Example 70 or 71 can optionally include wherein the second DPD circuit is configured to interpolate or extrapolate with the lookup table coefficients of the one or more second 2D lookup tables to obtain the second intermediate signal by generating a lookup table output from each of the one or more second 2D lookup tables to obtain one or more lookup table outputs, identifying one or more samples of the first input signal and the second input signal, evaluating one or more functions of the one or more samples to obtain one or more function outputs, determining one or more intermediate products by multiplying each of the one or more function outputs by a respective lookup table output of the one or more lookup table outputs, generating the second intermediate signal as a sum of the one or more intermediate products.
In Example 85, the subject matter of any one of Examples 70 to 84 can optionally include wherein the amplifier is a dual-band radio amplifier and the first input signal corresponds to a first band of the amplifier and the second input signal corresponds to a second band of the amplifier.
In Example 86, the subject matter of any one of Examples 70 to 85 can optionally further include a feedback circuit configured to monitor an output signal of the amplifier, and an adaptation circuit configured to adapt one or more lookup table coefficients of the one or more first 2D lookup tables or the one or more second 2D lookup tables based on the output signal of the amplifier.
In Example 87, the subject matter of any one of Examples 70 to 86 can optionally include wherein the first DPD circuit is further configured to assign each of a plurality of regions of a first 2D lookup table of the one or more first 2D lookup tables as an interpolation region or an extrapolation region, and reassigning at least one of the plurality of predefined regions of the first 2D lookup table.
In Example 88, the subject matter of Example 87 can optionally include wherein the first DPD circuit is configured to reassign the at least one of the plurality of predefined regions of the first 2D lookup table by monitoring a plurality of pairs of first dimension inputs and second dimension inputs for the first 2D lookup table, and reassigning a first region of the plurality of predefined regions of the first 2D lookup table as an interpolation region if more than a predefined quantity of the plurality of pairs fall within the first region and reassigning the first region as an extrapolation region if less than the predefined quantity of the plurality of pairs fall within the first region.
Example 89 is a radio communication device including the signal processing circuit arrangement of any one of Examples 70 to 88.
All acronyms defined in the above description additionally hold in all claims included herein.
While the invention has been particularly shown and described with reference to specific embodiments, it should be understood by those skilled in the art that various changes in form and detail may be made therein without departing from the spirit and scope of the invention as defined by the appended claims. The scope of the invention is thus indicated by the appended claims and all changes which come within the meaning and range of equivalency of the claims are therefore intended to be embraced.
This application is a continuation of International Application No. PCT/EP2016/056810, filed Mar. 29, 2016, and is also a continuation-in-part of U.S. patent application Ser. No. 14/230,607, filed Mar. 31, 2014, which claims the benefit of U.S. Provisional Application No. 61/812,858, filed Apr. 17, 2013.
Number | Name | Date | Kind |
---|---|---|---|
4673941 | Van Der Mark | Jun 1987 | A |
4884265 | Schroeder et al. | Nov 1989 | A |
5276633 | Fox et al. | Jan 1994 | A |
5381357 | Wedgwood et al. | Jan 1995 | A |
5416845 | Qun | May 1995 | A |
5596600 | Dimos et al. | Jan 1997 | A |
5706314 | Davis et al. | Jan 1998 | A |
5896304 | Tiemann | Apr 1999 | A |
5949831 | Coker et al. | Sep 1999 | A |
6118832 | Mayrargue et al. | Sep 2000 | A |
6150976 | Cooley | Nov 2000 | A |
6151682 | van der Wal et al. | Nov 2000 | A |
6158027 | Bush et al. | Dec 2000 | A |
6163788 | Chen et al. | Dec 2000 | A |
6446193 | Alidina et al. | Sep 2002 | B1 |
6529925 | Schenk | Mar 2003 | B1 |
6574649 | McGrath | Jun 2003 | B2 |
6580768 | Jaquette | Jun 2003 | B1 |
6625235 | Coker et al. | Sep 2003 | B1 |
6643814 | Cideciyan et al. | Nov 2003 | B1 |
6801086 | Chandrasekaran | Oct 2004 | B1 |
6996378 | Helms | Feb 2006 | B2 |
7039091 | Mauer | May 2006 | B1 |
7110477 | Suissa et al. | Sep 2006 | B2 |
7133387 | Nakada | Nov 2006 | B2 |
7167513 | Tsui et al. | Jan 2007 | B2 |
7313373 | Laskharian et al. | Dec 2007 | B1 |
7336730 | Auranen et al. | Feb 2008 | B2 |
7349375 | Gerakoulis | Mar 2008 | B2 |
7441105 | Metzgen | Oct 2008 | B1 |
7471739 | Wright | Dec 2008 | B1 |
7477634 | McKown | Jan 2009 | B1 |
7593492 | Lande | Sep 2009 | B1 |
7606292 | Harris et al. | Oct 2009 | B1 |
7613228 | Niedzwiecki | Nov 2009 | B2 |
7656837 | Gerakoulis | Feb 2010 | B2 |
7869482 | Kubota et al. | Jan 2011 | B2 |
7895252 | Sazegari et al. | Feb 2011 | B2 |
8516028 | Yu | Aug 2013 | B2 |
8583152 | Ishii et al. | Nov 2013 | B2 |
8711988 | Chen | Apr 2014 | B2 |
8831133 | Azadet et al. | Sep 2014 | B2 |
8897388 | Molina et al. | Nov 2014 | B2 |
8982992 | Azadet et al. | Mar 2015 | B2 |
20010043582 | Nakada | Nov 2001 | A1 |
20010050592 | Wright et al. | Dec 2001 | A1 |
20010050926 | Kumar | Dec 2001 | A1 |
20020057735 | Piirainen | May 2002 | A1 |
20020062436 | Van Hook et al. | May 2002 | A1 |
20020101835 | Gerakoulis | Aug 2002 | A1 |
20030053552 | Hongo | Mar 2003 | A1 |
20030112904 | Fuller et al. | Jun 2003 | A1 |
20030152165 | Kondo et al. | Aug 2003 | A1 |
20030223505 | Verbin et al. | Dec 2003 | A1 |
20030227981 | Vella-Coleiro | Dec 2003 | A1 |
20040052314 | Copeland | Mar 2004 | A1 |
20040120420 | Hongo | Jun 2004 | A1 |
20040180679 | Porter | Sep 2004 | A1 |
20040202137 | Gerakoulis | Oct 2004 | A1 |
20040248516 | Demir et al. | Dec 2004 | A1 |
20050001675 | Saed | Jan 2005 | A1 |
20050036575 | Kuchi et al. | Feb 2005 | A1 |
20050108002 | Nagai et al. | May 2005 | A1 |
20050111574 | Muller | May 2005 | A1 |
20050243946 | Chung et al. | Nov 2005 | A1 |
20060029149 | Kim et al. | Feb 2006 | A1 |
20060109938 | Challa et al. | May 2006 | A1 |
20060176969 | Trivedi | Aug 2006 | A1 |
20060198466 | Wright et al. | Sep 2006 | A1 |
20060240786 | Liu | Oct 2006 | A1 |
20060276146 | Suzuki | Dec 2006 | A1 |
20070005674 | Sazegari et al. | Jan 2007 | A1 |
20070087770 | Gan | Apr 2007 | A1 |
20070189402 | Yang | Aug 2007 | A1 |
20080019422 | Smith et al. | Jan 2008 | A1 |
20080027720 | Kondo et al. | Jan 2008 | A1 |
20080056403 | Wilson | Mar 2008 | A1 |
20080074155 | Jaklitsch | Mar 2008 | A1 |
20080095265 | Cai et al. | Apr 2008 | A1 |
20080107046 | Kangasmaa et al. | May 2008 | A1 |
20080187057 | Qu | Aug 2008 | A1 |
20080192860 | Harwood et al. | Aug 2008 | A1 |
20080219220 | Gerakoulis | Sep 2008 | A1 |
20080247487 | Cai et al. | Oct 2008 | A1 |
20080267261 | Wang et al. | Oct 2008 | A1 |
20080316076 | Dent et al. | Dec 2008 | A1 |
20090006514 | Kountouris | Jan 2009 | A1 |
20090029664 | Batruni | Jan 2009 | A1 |
20090079627 | Sun et al. | Mar 2009 | A1 |
20090116576 | Dowling | May 2009 | A1 |
20090164542 | Wu et al. | Jun 2009 | A1 |
20090225899 | Dent | Sep 2009 | A1 |
20090245406 | Moffatt et al. | Oct 2009 | A1 |
20090257421 | Nakashima et al. | Oct 2009 | A1 |
20090285335 | Hoshuyama | Nov 2009 | A1 |
20100027592 | Arviv et al. | Feb 2010 | A1 |
20100067511 | Peters | Mar 2010 | A1 |
20100098139 | Braithwaite | Apr 2010 | A1 |
20100124257 | Yahya | May 2010 | A1 |
20100144333 | Kiasaleh et al. | Jun 2010 | A1 |
20100158051 | Hadzic et al. | Jun 2010 | A1 |
20100198893 | Azadet et al. | Aug 2010 | A1 |
20100198894 | Azadet et al. | Aug 2010 | A1 |
20100225390 | Brown | Sep 2010 | A1 |
20100244953 | Brown et al. | Sep 2010 | A1 |
20100246714 | Yang et al. | Sep 2010 | A1 |
20100255867 | Ishii et al. | Oct 2010 | A1 |
20100273427 | Mergen et al. | Oct 2010 | A1 |
20100316112 | Huang et al. | Dec 2010 | A1 |
20110002249 | Gerakoulis | Jan 2011 | A1 |
20110007907 | Park et al. | Jan 2011 | A1 |
20110019724 | Agazzi | Jan 2011 | A1 |
20110025414 | Wolf et al. | Feb 2011 | A1 |
20110055303 | Slavin | Mar 2011 | A1 |
20110059710 | Cai et al. | Mar 2011 | A1 |
20110080902 | Jang | Apr 2011 | A1 |
20110096824 | Agazzi et al. | Apr 2011 | A1 |
20110150130 | Kenington | Jun 2011 | A1 |
20110170421 | Gerakoulis | Jul 2011 | A1 |
20110255011 | Gu et al. | Oct 2011 | A1 |
20110268167 | Sundstroem | Nov 2011 | A1 |
20110302230 | Ekstrand | Dec 2011 | A1 |
20120036174 | Yu | Feb 2012 | A1 |
20120069931 | Gandhi | Mar 2012 | A1 |
20120087406 | Lim et al. | Apr 2012 | A1 |
20120093209 | Schmidt et al. | Apr 2012 | A1 |
20120106614 | Kim et al. | May 2012 | A1 |
20120188994 | Palanki et al. | Jul 2012 | A1 |
20120269293 | Peng | Oct 2012 | A1 |
20120280840 | Kyeong et al. | Nov 2012 | A1 |
20120295657 | Okazaki | Nov 2012 | A1 |
20130007082 | Elenes | Jan 2013 | A1 |
20130022157 | Hollevoet et al. | Jan 2013 | A1 |
20130044794 | Wenzel et al. | Feb 2013 | A1 |
20130070867 | To et al. | Mar 2013 | A1 |
20130114652 | Molina et al. | May 2013 | A1 |
20130114761 | Azadet et al. | May 2013 | A1 |
20130114762 | Azadet et al. | May 2013 | A1 |
20130117342 | Azadet et al. | May 2013 | A1 |
20130195007 | Mazurenko et al. | Aug 2013 | A1 |
20130243123 | Bai | Sep 2013 | A1 |
20140016626 | Dai et al. | Jan 2014 | A1 |
20140064417 | Azadet | Mar 2014 | A1 |
20140072073 | Azadet et al. | Mar 2014 | A1 |
20140075162 | Azadet et al. | Mar 2014 | A1 |
20140086356 | Azadet et al. | Mar 2014 | A1 |
20140086367 | Azadet et al. | Mar 2014 | A1 |
20140108477 | Azadet et al. | Apr 2014 | A1 |
20140314176 | Azadet | Oct 2014 | A1 |
20140314182 | Azadet | Oct 2014 | A1 |
20140317163 | Azadet et al. | Oct 2014 | A1 |
20150070089 | Eliaz et al. | Mar 2015 | A1 |
20150146822 | Copeland | May 2015 | A1 |
Number | Date | Country |
---|---|---|
2256937 | Dec 2010 | EP |
20050064485 | Jun 2005 | KR |
2007010331 | Jan 2007 | WO |
2007104362 | Sep 2007 | WO |
2008057584 | May 2008 | WO |
2011058843 | May 2011 | WO |
2011101233 | Aug 2011 | WO |
2013007188 | Jan 2013 | WO |
2013063434 | May 2013 | WO |
2013063440 | May 2013 | WO |
2013063443 | May 2013 | WO |
2013063447 | May 2013 | WO |
2013063450 | May 2013 | WO |
2013066756 | May 2013 | WO |
Entry |
---|
Lei Ding, Zigang Yang and H. Gandhi, “Concurrent dual-band digital predistortion,” 2012 IEEE/MTT-S International Microwave Symposium Digest, Montreal, QC, Canada, 2012, pp. 1-3. |
A. K. Kwan, S. A. Bassam, M. Helaoui and F. M. Ghannouchi, “Concurrent dual band digital predistortion using look up tables with variable depths,” 2013 IEEE Topical Conference on Power Amplifiers for Wireless and Radio Applications, Santa Clara, CA, 2013, pp. 25-27. |
Notice of Allowance received for U.S. Appl. No. 14/168,615 dated Feb. 4, 2016, 7 pages. |
Wegener, A.: “High-Performance Crest Factor Reduction Processor for W-CDMA and Applications”, Radio Frequency Integrated Circuits (RFIC) Symposium, Jun. 2006, 4 pages, IEEE, USA. |
Gopalan R. et al.: “An Optimization Approach to Single-Bit Quantization”, IEEE Transaction on Circuits and Systems I: Regular Papers, Dec. 2009, pp. 2655-2668, vol. 56, Issue 12, IEEE, USA. |
Gopalan R. et al.: “On an optimum algorithm for waveform synthesis and its applications to digital transmitters”, Wireless Communications and Networking Conference, Mar. 2005, pp. 1108-1113, vol. 2, IEEE, USA. |
Venkatamaran J. et al: “An All-Digital Transmitter with a 1-Bit DAC”, IEEE Transaction on Communications, Oct. 2007, pp. 1951-1962, vol. 55, Issue 10, IEEE, USA. |
Li: “FIR Filtering Using Vector Transformation and Convolution Processor”, 1990, IEEE, pp. 1223-1226. |
Non-Final Office Action received for U.S. Appl. No. 14/255,491 dated Jun. 16, 2016, 11 pages. |
Final Office Action received for U.S. Appl. No. 14/230,635 dated Jun. 30, 2016, 13 pages. |
Final Office Action received for U.S. Appl. No. 14/230,607 dated Jun. 2, 2016, 17 pages. |
Office Action received for the U.S. Appl. No. 14/230,607, dated Apr. 21, 2017, 29 pages. |
Office Action received for the U.S. Appl. No. 14/255,499, dated Jun. 15, 2017, 60 pages. |
International search report received for corresponding International Application No. PCT/EP2016/056810 dated Nov. 29, 2016, 15 pages. |
Office Action received for corresponding U.S. Appl. No. 14/230,607 dated Oct. 7, 2016, 22 pages. |
Kim et al., “Piecewise Pre-Equalized Linearization of the Wireless Transmitter With a Doherty Amplifier”, IEEE Transactions on Microwave Theory and Techniques, 2006, pp. 3469-3478, vol. 54, No. 9. |
Advisory Action received for the U.S. Appl. No. 14/230,607, dated Jul. 12, 2017, 3 pages. |
Office Action received for the U.S. Appl. No. 14/230,607, dated Sep. 7, 2017, 31 pages. |
Lei Ding, “Digital Predistortion of Power Amplifiers for Wireless Applications”, School of Electrical and Computer Engineering Georgia Institute of Technology PhD thesis, Mar. 2004. |
Maarten Schoukens et al., “Parametric Identification of Parallel Wiener Systems”, IEEE Transactions on Instrumentation and Measurement, Oct. 2012, pp. 2825-2832, vol. 61, No. 10, IEEE. |
Notice of Allowance received for the U.S. Appl. No. 14/255,499, dated Nov. 17, 2017, 17 pages. |
Number | Date | Country | |
---|---|---|---|
20160308577 A1 | Oct 2016 | US |
Number | Date | Country | |
---|---|---|---|
61812858 | Apr 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/EP2016/056810 | Mar 2016 | US |
Child | 15191583 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14230607 | Mar 2014 | US |
Child | PCT/EP2016/056810 | US |